UNPKG

@antv/x6

Version:

JavaScript diagramming library that uses SVG and HTML for rendering.

94 lines 4.07 kB
import sinon from 'sinon'; import { DataUri } from './index'; describe('DataUri', () => { describe('#isDataUrl', () => { it('should return true with dataurl', () => { expect(DataUri.isDataUrl('data:image')).toBeTruthy(); }); it('should return false with invalid dataurl', () => { expect(DataUri.isDataUrl('abc')).toBeFalsy(); }); }); describe('#imageToDataUri', () => { const oldXMLHttpRequest = window.XMLHttpRequest; const oldFileReader = window.FileReader; let onLoadHandle; let onErrorHandle; beforeEach(() => { const win = window; win.FileReader = null; win.XMLHttpRequest = sinon.spy(() => ({ open: sinon.spy(), send: sinon.spy(), readyState: 4, status: 200, response: 10, addEventListener: (name, handle) => { if (name === 'load') { onLoadHandle = handle; } if (name === 'error') { onErrorHandle = handle; } }, })); }); afterEach(() => { window.XMLHttpRequest = oldXMLHttpRequest; window.FileReader = oldFileReader; }); it('should run setTimeout with dataurl', (done) => { const spy = sinon.spy(); DataUri.imageToDataUri('data:image', spy); setTimeout(() => { expect(spy.callCount).toBe(1); done(); }, 10); }); it('should return datauri with image loaded', () => { const spy = sinon.spy(); DataUri.imageToDataUri('test.svg', spy); onLoadHandle(); expect(spy.callCount).toBe(1); expect(spy.firstCall.args[1]).toEqual('data:image/svg+xml;base64,AAAAAAAAAAAAAA=='); }); it('should return datauri with image load error', () => { const spy = sinon.spy(); DataUri.imageToDataUri('test.svg', spy); onErrorHandle(); expect(spy.callCount).toBe(1); expect(spy.firstCall.args[0]).toEqual(new Error(`Failed to load image: test.svg`)); }); }); describe('#dataUriToBlob', () => { it('should return correct blob data with base64 datauri', () => { const blob = DataUri.dataUriToBlob('data:image/svg+xml;base64,AAAAAAAAAAAAAGFiY2RlZmc='); expect(blob.type).toBe('image/svg+xml'); }); it('should return correct blob data with datauri', () => { const blob = DataUri.dataUriToBlob('data:image/svg+xml,AAAAAAAAAAAAAGFiY2RlZmc='); expect(blob.type).toBe('image/svg+xml'); }); }); describe('#svgToDataUrl', () => { it('should return dataurl of a svg string', () => { expect(DataUri.svgToDataUrl('<svg width="100" height="100"></svg>', { width: 100, height: 100, })).toBe('data:image/svg+xml,%3Csvg%20width%3D%22100%22%20height%3D%22100%22%3E%3C%2Fsvg%3E'); }); it('should return dataurl of a svg string without option', () => { expect(DataUri.svgToDataUrl('<svg width="100" height="100"></svg>')).toBe('data:image/svg+xml,%3Csvg%20width%3D%22100%22%20height%3D%22100%22%3E%3C%2Fsvg%3E'); expect(DataUri.svgToDataUrl('<svg viewBox="0 0 100 100"></svg>')).toBe('data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%20100%20100%22%3E%3C%2Fsvg%3E'); }); it('should throw error when no width or no height', () => { expect(() => { DataUri.svgToDataUrl('<svg></svg>'); }).toThrowError('Can not parse width from svg string'); expect(() => { DataUri.svgToDataUrl('<svg width="100"></svg>'); }).toThrowError('Can not parse height from svg string'); }); }); }); //# sourceMappingURL=index.test.js.map