mirror of
https://github.com/badges/shields.git
synced 2025-04-18 19:44:04 +03:00
* Sunsetting Shields custom logos * Reinstate info to contribute to SimpleIcons * Mention that no changes are required
125 lines
8.6 KiB
JavaScript
125 lines
8.6 KiB
JavaScript
import { expect } from 'chai'
|
|
import { test, given, forCases } from 'sazerac'
|
|
import {
|
|
prependPrefix,
|
|
isDataUrl,
|
|
prepareNamedLogo,
|
|
getSimpleIcon,
|
|
makeLogo,
|
|
} from './logos.js'
|
|
|
|
describe('Logo helpers', function () {
|
|
test(prependPrefix, () => {
|
|
given('', 'data:').expect(
|
|
'',
|
|
)
|
|
given('foobar', 'data:').expect('data:foobar')
|
|
given(undefined, 'data:').expect(undefined)
|
|
})
|
|
|
|
test(isDataUrl, () => {
|
|
// valid input
|
|
given('').expect(true)
|
|
|
|
// invalid inputs
|
|
forCases([given('data:foobar'), given('foobar')]).expect(false)
|
|
|
|
// attempted XSS attack
|
|
given(
|
|
'"/><script>alert()</script>',
|
|
).expect(false)
|
|
})
|
|
|
|
test(prepareNamedLogo, () => {
|
|
// use simple icon
|
|
given({ name: 'github' }).expect(
|
|
'',
|
|
)
|
|
// use simple icon with color
|
|
given({ name: 'github', color: 'red' }).expect(
|
|
'',
|
|
)
|
|
// use simple icon with auto logo size
|
|
given({ name: 'amd', size: 'auto' }).expect(
|
|
'',
|
|
)
|
|
// use simple icon with color & auto logo size
|
|
given({ name: 'amd', color: 'white', size: 'auto' }).expect(
|
|
'',
|
|
)
|
|
|
|
it('preserves color if light logo on dark background', function () {
|
|
const logo = prepareNamedLogo({ name: 'javascript' })
|
|
const decodedLogo = Buffer.from(
|
|
logo.replace('data:image/svg+xml;base64,', ''),
|
|
'base64',
|
|
).toString('ascii')
|
|
expect(decodedLogo).to.contain('fill="#F7DF1E"')
|
|
})
|
|
it('recolors logo if light logo on light background', function () {
|
|
const logo = prepareNamedLogo({ name: 'javascript', style: 'social' })
|
|
const decodedLogo = Buffer.from(
|
|
logo.replace('data:image/svg+xml;base64,', ''),
|
|
'base64',
|
|
).toString('ascii')
|
|
expect(decodedLogo).to.contain('fill="#333"')
|
|
})
|
|
|
|
it('preserves color if dark logo on light background', function () {
|
|
const logo = prepareNamedLogo({ name: 'nuget', style: 'social' })
|
|
const decodedLogo = Buffer.from(
|
|
logo.replace('data:image/svg+xml;base64,', ''),
|
|
'base64',
|
|
).toString('ascii')
|
|
expect(decodedLogo).to.contain('fill="#004880"')
|
|
})
|
|
it('recolors logo if dark logo on dark background', function () {
|
|
const logo = prepareNamedLogo({ name: 'nuget' })
|
|
const decodedLogo = Buffer.from(
|
|
logo.replace('data:image/svg+xml;base64,', ''),
|
|
'base64',
|
|
).toString('ascii')
|
|
expect(decodedLogo).to.contain('fill="whitesmoke"')
|
|
})
|
|
|
|
it('preserves color if medium logo on dark background', function () {
|
|
const logo = prepareNamedLogo({ name: 'android' })
|
|
const decodedLogo = Buffer.from(
|
|
logo.replace('data:image/svg+xml;base64,', ''),
|
|
'base64',
|
|
).toString('ascii')
|
|
expect(decodedLogo).to.contain('fill="#34A853"')
|
|
})
|
|
it('preserves color if medium logo on light background', function () {
|
|
const logo = prepareNamedLogo({ name: 'android', style: 'social' })
|
|
const decodedLogo = Buffer.from(
|
|
logo.replace('data:image/svg+xml;base64,', ''),
|
|
'base64',
|
|
).toString('ascii')
|
|
expect(decodedLogo).to.contain('fill="#34A853"')
|
|
})
|
|
})
|
|
|
|
test(getSimpleIcon, () => {
|
|
// https://github.com/badges/shields/issues/4016
|
|
given({ name: 'get' }).expect(undefined)
|
|
// https://github.com/badges/shields/issues/4263
|
|
given({ name: 'get', color: 'blue' }).expect(undefined)
|
|
})
|
|
|
|
test(makeLogo, () => {
|
|
forCases([
|
|
given('npm', { logo: 'image/svg+xml;base64,PHN2ZyB4bWxu' }),
|
|
given('npm', { logo: '' }),
|
|
given('npm', { logo: '' }),
|
|
given('npm', { logo: '\n4bWxu' }),
|
|
]).expect('')
|
|
forCases([given('npm', { logo: '' }), given(undefined, {})]).expect(
|
|
undefined,
|
|
)
|
|
given('npm', {}).expect(
|
|
'',
|
|
)
|
|
})
|
|
})
|