1
0
mirror of https://github.com/badges/shields.git synced 2025-11-02 04:13:20 +03:00

Add SymfonyInsight stars badge, run [SymfonyInsight sensiolabs amo chrome-web-store redmine spigetratings vaadin-directory visualstudiomarketplacerating wordpress] (#2971)

* feat: added stars badge for symfony insight

* refactor: changed symfony star determination logic

* feat: updating symfony to handle old scan scenarios

* feat: updated symfony insight to handle older projects

* tests: removed another test for symfony insight per request
This commit is contained in:
Caleb Cartwright
2019-02-20 17:15:31 -06:00
committed by GitHub
parent 96d48dc486
commit a4bd3f5fd6
14 changed files with 827 additions and 608 deletions

View File

@@ -0,0 +1,141 @@
'use strict'
const Joi = require('joi')
const t = (module.exports = require('../tester').createServiceTester())
const { withRegex } = require('../test-validators')
const {
createTest,
goldMockResponse,
runningMockResponse,
prepLiveTest,
sampleProjectUuid,
realTokenExists,
mockSymfonyUser,
mockSymfonyToken,
criticalViolation,
majorViolation,
minorViolation,
infoViolation,
multipleViolations,
} = require('./symfony-test-helpers')
createTest(t, 'live: valid project violations', { withMockCreds: false })
.before(prepLiveTest)
.get(`/${sampleProjectUuid}.json`)
.timeout(15000)
.interceptIf(!realTokenExists, nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.reply(200, multipleViolations)
)
.expectJSONTypes(
Joi.object().keys({
name: 'violations',
value: withRegex(
/\d* critical|\d* critical, \d* major|\d* critical, \d* major, \d* minor|\d* critical, \d* major, \d* minor, \d* info|\d* critical, \d* minor|\d* critical, \d* info|\d* major|\d* major, \d* minor|\d* major, \d* minor, \d* info|\d* major, \d* info|\d* minor|\d* minor, \d* info/
),
})
)
createTest(t, 'pending project grade')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.reply(200, runningMockResponse)
)
.expectJSON({
name: 'violations',
value: 'pending',
color: 'lightgrey',
})
createTest(t, 'zero violations')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.reply(200, goldMockResponse)
)
.expectJSON({
name: 'violations',
value: '0',
color: 'brightgreen',
})
createTest(t, 'critical violations')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.reply(200, criticalViolation)
)
.expectJSON({
name: 'violations',
value: '1 critical',
color: 'red',
})
createTest(t, 'major violations')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.reply(200, majorViolation)
)
.expectJSON({
name: 'violations',
value: '1 major',
color: 'orange',
})
createTest(t, 'minor violations')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.basicAuth({
user: mockSymfonyUser,
pass: mockSymfonyToken,
})
.reply(200, minorViolation)
)
.expectJSON({
name: 'violations',
value: '1 minor',
color: 'yellow',
})
createTest(t, 'info violations')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.basicAuth({
user: mockSymfonyUser,
pass: mockSymfonyToken,
})
.reply(200, infoViolation)
)
.expectJSON({
name: 'violations',
value: '1 info',
color: 'yellowgreen',
})
createTest(t, 'multiple violations grade')
.get(`/${sampleProjectUuid}.json?style=_shields_test`)
.intercept(nock =>
nock('https://insight.symfony.com/api/projects')
.get(`/${sampleProjectUuid}`)
.basicAuth({
user: mockSymfonyUser,
pass: mockSymfonyToken,
})
.reply(200, multipleViolations)
)
.expectJSON({
name: 'violations',
value: '1 critical, 1 info',
color: 'red',
})