2
0
mirror of https://github.com/iconify/iconify.git synced 2025-01-07 07:34:22 +00:00
iconify/packages/utils/tests/load-icon-test.ts

98 lines
2.3 KiB
TypeScript
Raw Normal View History

import { promises as fs } from 'fs';
import type { CustomIconLoader } from '../lib';
import { loadIcon } from '../lib';
const fixturesDir = './tests/fixtures';
const loader: CustomIconLoader = async (name) => {
return await fs.readFile(`${fixturesDir}/${name}.svg`, 'utf8');
};
describe('Testing loadIcon', () => {
test('CustomCollection', async () => {
const svg = await loader('circle');
2022-02-26 16:20:57 +00:00
expect(svg).toBeTruthy();
const result = await loadIcon('a', 'circle', {
customCollections: {
a: {
circle: svg as string,
},
},
});
2022-02-26 16:20:57 +00:00
expect(result).toBeTruthy();
expect(svg).toEqual(result);
});
test('CustomCollection using dynamic import', async () => {
2022-06-17 20:10:54 +00:00
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
2022-03-14 14:39:40 +00:00
// @ts-ignore
const result = await loadIcon('flat-color-icons', 'up-right', {
customCollections: {
2022-03-14 14:39:40 +00:00
'flat-color-icons': () =>
import(
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
'@iconify-json/flat-color-icons/icons.json'
).then((i) => i?.default),
},
});
expect(result).toBeTruthy();
});
test('CustomCollection with transform', async () => {
2022-02-26 16:20:57 +00:00
const svg = await loader('circle');
expect(svg).toBeTruthy();
const result = await loadIcon('a', 'circle', {
customCollections: {
a: {
circle: svg as string,
},
},
customizations: {
transform(svg) {
return svg.replace(
/<svg\s+/,
'<svg width="1em" height="1em" '
);
},
2022-02-26 16:20:57 +00:00
},
});
2022-02-26 16:20:57 +00:00
expect(result).toBeTruthy();
expect(result && result.indexOf('width="1em"') > -1).toBeTruthy();
expect(result && result.indexOf('height="1em"') > -1).toBeTruthy();
});
2022-06-17 20:26:55 +00:00
test('CustomCollection Icon with XML heading', async () => {
2022-02-26 16:20:57 +00:00
const svg = await loader('1f3eb');
expect(svg).toBeTruthy();
// Intercept console.warn
let warned = false;
const warn = console.warn;
console.warn = (/*...args*/) => {
// warn.apply(this, args);
warned = true;
};
const result = await loadIcon('a', '1f3eb', {
customCollections: {
a: {
'1f3eb': svg as string,
},
},
});
// Restore console.warn
console.warn = warn;
2022-06-17 20:26:55 +00:00
expect(svg).not.toEqual(result);
expect(
svg?.replace(
'<?xml version="1.0" encoding="UTF-8" standalone="no"?>',
''
)
).toEqual(result);
// warning should not longer be used
expect(warned).toEqual(false);
});
});