12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- import { isEncodedDataUrl, isSvgDataUrl, isValid } from "../validate";
- describe('isValid', () => {
- it('invalid onload attr', () => {
- const el = {
- nodeType: 1,
- nodeName: 'svg',
- attributes: [{ name: 'onload' }],
- childNodes: []
- };
- expect(isValid(el)).toBe(false);
- });
- it('invalid onclick attr', () => {
- const el = {
- nodeType: 1,
- nodeName: 'svg',
- attributes: [{ name: 'OnClIcK' }],
- childNodes: []
- };
- expect(isValid(el)).toBe(false);
- });
- it('invalid child SCRIPT elm', () => {
- const el = {
- nodeType: 1, nodeName: 'svg', attributes: [], childNodes: [
- { nodeType: 1, nodeName: 'SCRIPT', attributes: [], childNodes: [] }
- ]
- };
- expect(isValid(el)).toBe(false);
- });
- it('invalid script elm', () => {
- const el = { nodeType: 1, nodeName: 'script', attributes: [], childNodes: [] };
- expect(isValid(el)).toBe(false);
- });
- it('is valid circle elm', () => {
- const el = { nodeType: 1, nodeName: 'circle', attributes: [], childNodes: [] };
- expect(isValid(el)).toBe(true);
- });
- it('is valid SVG elm', () => {
- const el = {
- nodeType: 1, nodeName: 'SVG', attributes: [], childNodes: [
- { nodeType: 1, nodeName: 'line', attributes: [], childNodes: [] }
- ]
- };
- expect(isValid(el)).toBe(true);
- });
- it('is valid text node', () => {
- const el = { nodeType: 3, nodeName: '#text' };
- expect(isValid(el)).toBe(true);
- });
- });
- it('isSvgDataUrl', () => {
- expect(isSvgDataUrl('')).toBe(true);
- expect(isSvgDataUrl('data:image/svg+xml;utf8,<svg></svg>')).toBe(true);
- expect(isSvgDataUrl('https://example.com/icon.svg')).toBe(false);
- expect(isSvgDataUrl('http://example.com/icon.svg')).toBe(false);
- });
- it('isEncodedDataUrl', () => {
- expect(isEncodedDataUrl('')).toBe(false);
- expect(isEncodedDataUrl('data:image/svg+xml;utf8,<svg></svg>')).toBe(true);
- expect(isEncodedDataUrl('https://example.com/icon.svg')).toBe(false);
- expect(isEncodedDataUrl('http://example.com/icon.svg')).toBe(false);
- });
|