1
0
mirror of https://github.com/badges/shields.git synced 2025-04-18 19:44:04 +03:00
shields/lib/logos.spec.js
dependabot[bot] 5fdb3f585f
chore(deps): bump simple-icons from 14.9.0 to 14.10.0 (#10947)
* chore(deps): bump simple-icons from 14.9.0 to 14.10.0

Bumps [simple-icons](https://github.com/simple-icons/simple-icons) from 14.9.0 to 14.10.0.
- [Release notes](https://github.com/simple-icons/simple-icons/releases)
- [Commits](https://github.com/simple-icons/simple-icons/compare/14.9.0...14.10.0)

---
updated-dependencies:
- dependency-name: simple-icons
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>

* change test example for logo that is not re-coloured

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: chris48s <git@chris-shaw.dev>
2025-03-14 19:53:33 +00:00

125 lines
8.4 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: 'mastodon' })
const decodedLogo = Buffer.from(
logo.replace('data:image/svg+xml;base64,', ''),
'base64',
).toString('ascii')
expect(decodedLogo).to.contain('fill="#6364FF"')
})
it('preserves color if medium logo on light background', function () {
const logo = prepareNamedLogo({ name: 'mastodon', style: 'social' })
const decodedLogo = Buffer.from(
logo.replace('data:image/svg+xml;base64,', ''),
'base64',
).toString('ascii')
expect(decodedLogo).to.contain('fill="#6364FF"')
})
})
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(
'',
)
})
})