2
0
mirror of https://github.com/iconify/iconify.git synced 2024-09-20 01:09:04 +00:00
iconify/packages/browser-tests/tests/10-finder-v1-test.ts

83 lines
1.9 KiB
TypeScript
Raw Normal View History

2020-04-28 09:47:35 +00:00
import mocha from 'mocha';
import chai from 'chai';
import { getNode } from './node';
2020-07-01 20:29:43 +00:00
import {
addFinder,
findPlaceholders,
} from '@iconify/iconify/lib/modules/finder';
import { IconifyFinder } from '@iconify/iconify/lib/finders/interface';
2020-04-28 09:47:35 +00:00
import { finder as iconifyFinder } from '@iconify/iconify/lib/finders/iconify-v1';
import { finder as iconifyIconFinder } from '@iconify/iconify/lib/finders/iconify-v1-icon';
import { IconifyIconName } from '@iconify/utils/lib/icon/name';
2020-04-28 09:47:35 +00:00
const expect = chai.expect;
describe('Testing legacy finder', () => {
before(() => {
// Add finders
addFinder(iconifyFinder);
addFinder(iconifyIconFinder);
});
2020-04-28 09:47:35 +00:00
it('Finding nodes', () => {
const node = getNode('finder');
node.innerHTML =
2020-12-16 09:48:50 +00:00
'<div><p>List of <span>icon</span> placeholders (this test does not render SVG)</p><ul>' +
2020-04-28 09:47:35 +00:00
'<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: '',
2020-04-28 09:47:35 +00:00
prefix: 'mdi',
name: 'home',
},
iconifyFinder
);
testIcon(
{
provider: '',
2020-04-28 09:47:35 +00:00
prefix: 'mdi',
name: 'account',
},
iconifyFinder
);
testIcon(
{
provider: '',
2020-04-28 09:47:35 +00:00
prefix: 'ic',
name: 'baseline-account',
},
iconifyIconFinder
);
// End of list
expect(items.shift()).to.be.equal(void 0);
});
});