mirror of
https://github.com/Mibew/simple-icons.git
synced 2025-01-06 02:08:14 +03:00
fcec7adc8b
* replace index.js entry point * add types.d.ts * Update documentation * Add Typescript usage example * Drop template file * Readd test * Minor change Co-authored-by: Álvaro Mondéjar Rubio <mondejar1994@gmail.com>
80 lines
2.4 KiB
JavaScript
80 lines
2.4 KiB
JavaScript
import fs from 'node:fs';
|
|
import path from 'node:path';
|
|
import { strict as assert } from 'node:assert';
|
|
import { describe, it } from 'mocha';
|
|
import { URL_REGEX, titleToSlug } from '../scripts/utils.js';
|
|
|
|
const iconsDir = path.resolve(process.cwd(), 'icons');
|
|
|
|
/**
|
|
* Checks if icon data matches a subject icon.
|
|
* @param {import('..').SimpleIcon} icon Icon data
|
|
* @param {import('..').SimpleIcon} subject Icon to check against icon data
|
|
* @param {String} slug Icon data slug
|
|
*/
|
|
export const testIcon = (icon, subject, slug) => {
|
|
const svgPath = path.resolve(iconsDir, `${slug}.svg`);
|
|
|
|
describe(icon.title, () => {
|
|
it('has the correct "title"', () => {
|
|
assert.equal(subject.title, icon.title);
|
|
});
|
|
|
|
it('has the correct "slug"', () => {
|
|
assert.equal(subject.slug, slug);
|
|
});
|
|
|
|
it('has the correct "hex" value', () => {
|
|
assert.equal(subject.hex, icon.hex);
|
|
});
|
|
|
|
it('has the correct "source"', () => {
|
|
assert.equal(subject.source, icon.source);
|
|
assert.match(subject.source, URL_REGEX);
|
|
});
|
|
|
|
it('has an "svg" value', () => {
|
|
assert.equal(typeof subject.svg, 'string');
|
|
});
|
|
|
|
it('has a valid "path" value', () => {
|
|
assert.match(subject.path, /^[MmZzLlHhVvCcSsQqTtAaEe0-9-,.\s]+$/g);
|
|
});
|
|
|
|
it(`has ${icon.guidelines ? 'the correct' : 'no'} "guidelines"`, () => {
|
|
if (icon.guidelines) {
|
|
assert.equal(subject.guidelines, icon.guidelines);
|
|
} else {
|
|
assert.equal(subject.guidelines, undefined);
|
|
}
|
|
});
|
|
|
|
it(`has ${icon.license ? 'the correct' : 'no'} "license"`, () => {
|
|
if (icon.license) {
|
|
assert.equal(subject.license.type, icon.license.type);
|
|
if (icon.license.type === 'custom') {
|
|
assert.equal(subject.license.url, icon.license.url);
|
|
} else {
|
|
assert.match(subject.license.url, URL_REGEX);
|
|
}
|
|
} else {
|
|
assert.equal(subject.license, undefined);
|
|
}
|
|
});
|
|
|
|
it('has a valid svg value', () => {
|
|
const svgFileContents = fs.readFileSync(svgPath, 'utf8');
|
|
assert.equal(subject.svg, svgFileContents);
|
|
});
|
|
|
|
if (icon.slug) {
|
|
// if an icon data has a slug, it must be different to the
|
|
// slug inferred from the title, which prevents adding
|
|
// unnecessary slugs to icons data
|
|
it(`'${icon.title}' slug must be necessary`, () => {
|
|
assert.notEqual(titleToSlug(icon.title), icon.slug);
|
|
});
|
|
}
|
|
});
|
|
};
|