mirror of
https://github.com/iconify/iconify.git
synced 2025-01-15 19:26:51 +00:00
81 lines
1.9 KiB
TypeScript
81 lines
1.9 KiB
TypeScript
import mocha from 'mocha';
|
|
import chai from 'chai';
|
|
|
|
import { getNode } from './node';
|
|
import {
|
|
addFinder,
|
|
findPlaceholders,
|
|
} from '@iconify/iconify/lib/modules/finder';
|
|
import { IconifyFinder } from '@iconify/iconify/lib/finders/interface';
|
|
import { finder as iconifyFinder } from '@iconify/iconify/lib/finders/iconify';
|
|
import { finder as iconifyIconFinder } from '@iconify/iconify/lib/finders/iconify-icon';
|
|
import { IconifyIconName } from '@iconify/core/lib/icon/name';
|
|
|
|
const expect = chai.expect;
|
|
|
|
// Add finders
|
|
addFinder(iconifyFinder);
|
|
addFinder(iconifyIconFinder);
|
|
|
|
describe('Testing finder', () => {
|
|
it('Finding nodes', () => {
|
|
const node = getNode('finder');
|
|
node.innerHTML =
|
|
'<div><p>List of <span>icon</span> placeholders (this test does not render SVG)</p><ul>' +
|
|
'<li>Valid icons:' +
|
|
' <span class="iconify" data-icon="mdi:home"></span>' +
|
|
' <i class="iconify" data-icon="mdi:account"></i>' +
|
|
'</li>' +
|
|
'<li>Icon without name:' +
|
|
' <span class="iconify"></span>' +
|
|
'</li>' +
|
|
'<li>Block icon:' +
|
|
' <iconify-icon data-icon="ic:baseline-account"></iconify-icon>' +
|
|
'</li>' +
|
|
'<li>Icon with wrong tag: <p class="iconify" data-icon="mdi:alert"></p></li>' +
|
|
'</ul></div>';
|
|
|
|
const items = findPlaceholders(node);
|
|
|
|
function testIcon(
|
|
name: IconifyIconName | null,
|
|
expectedFinder: IconifyFinder
|
|
): void {
|
|
const item = items.shift();
|
|
expect(item.name).to.be.eql(name);
|
|
expect(item.finder).to.be.equal(expectedFinder);
|
|
}
|
|
|
|
// Test all icons
|
|
testIcon(
|
|
{
|
|
provider: '',
|
|
prefix: 'mdi',
|
|
name: 'home',
|
|
},
|
|
iconifyFinder
|
|
);
|
|
|
|
testIcon(
|
|
{
|
|
provider: '',
|
|
prefix: 'mdi',
|
|
name: 'account',
|
|
},
|
|
iconifyFinder
|
|
);
|
|
|
|
testIcon(
|
|
{
|
|
provider: '',
|
|
prefix: 'ic',
|
|
name: 'baseline-account',
|
|
},
|
|
iconifyIconFinder
|
|
);
|
|
|
|
// End of list
|
|
expect(items.shift()).to.be.equal(void 0);
|
|
});
|
|
});
|