diff options
Diffstat (limited to 'spec')
71 files changed, 2165 insertions, 1121 deletions
diff --git a/spec/RAFPlugin.js b/spec/RAFPlugin.js index 770212c..c6b96e2 100644 --- a/spec/RAFPlugin.js +++ b/spec/RAFPlugin.js @@ -3,19 +3,18 @@ * Jasmine RequestAnimationFrame: a set of helpers for testing functionality * that uses requestAnimationFrame under the Jasmine BDD framework for JavaScript. */ -function RAFPlugin (jasmine) { - +function RAFPlugin(jasmine) { var index = 0 var callbacks = [] - function MockRAF () { + function MockRAF() { this.nextTime = 0 var _this = this /** - * Mock for window.requestAnimationFrame - */ + * Mock for window.requestAnimationFrame + */ this.mockRAF = function (fn) { if (typeof fn !== 'function') { throw new Error('You should pass a function to requestAnimationFrame') @@ -28,8 +27,8 @@ function RAFPlugin (jasmine) { } /** - * Mock for window.cancelAnimationFrame - */ + * Mock for window.cancelAnimationFrame + */ this.mockCAF = function (requestID) { callbacks.splice(requestID, 1) } @@ -41,8 +40,8 @@ function RAFPlugin (jasmine) { } /** - * Install request animation frame mocks. - */ + * Install request animation frame mocks. + */ this.install = function (global) { _this.realRAF = global.requestAnimationFrame _this.realCAF = global.cancelAnimationFrame @@ -53,8 +52,8 @@ function RAFPlugin (jasmine) { } /** - * Uninstall request animation frame mocks. - */ + * Uninstall request animation frame mocks. + */ this.uninstall = function (global) { global.requestAnimationFrame = _this.realRAF global.cancelAnimationFrame = _this.realCAF @@ -64,12 +63,14 @@ function RAFPlugin (jasmine) { } /** - * Simulate animation frame readiness. - */ + * Simulate animation frame readiness. + */ this.tick = function (dt) { - _this.nextTime += (dt || 1) + _this.nextTime += dt || 1 - var fns = callbacks; var fn; var i + var fns = callbacks + var fn + var i callbacks = [] index = 0 diff --git a/spec/SpecRunner.html b/spec/SpecRunner.html index 56a8885..bd7b59a 100644 --- a/spec/SpecRunner.html +++ b/spec/SpecRunner.html @@ -1,27 +1,31 @@ <!DOCTYPE html> <html> -<head> - <meta charset="utf-8"> - <title>SVG.js - Jasmine Spec Runner</title> - - <link rel="shortcut icon" type="image/png" href="../node_modules/jasmine-core/images/jasmine_favicon.png"> - <link rel="stylesheet" href="../node_modules/jasmine-core/lib/jasmine-core/jasmine.css"> - - <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine.js"></script> - <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine-html.js"></script> - <script src="../node_modules/jasmine-core/lib/jasmine-core/boot.js"></script> - <script src="RAFPlugin.js"></script> - - <link rel="stylesheet" href="fixtures/fixture.css"> - -</head> - -<body> - - - <!-- include spec files here... --> - - <script src="../dist/polyfillsIE.js"></script> - <script src="es5TestBundle.js"></script> -</body> + <head> + <meta charset="utf-8" /> + <title>SVG.js - Jasmine Spec Runner</title> + + <link + rel="shortcut icon" + type="image/png" + href="../node_modules/jasmine-core/images/jasmine_favicon.png" + /> + <link + rel="stylesheet" + href="../node_modules/jasmine-core/lib/jasmine-core/jasmine.css" + /> + + <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine.js"></script> + <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine-html.js"></script> + <script src="../node_modules/jasmine-core/lib/jasmine-core/boot.js"></script> + <script src="RAFPlugin.js"></script> + + <link rel="stylesheet" href="fixtures/fixture.css" /> + </head> + + <body> + <!-- include spec files here... --> + + <script src="../dist/polyfillsIE.js"></script> + <script src="es5TestBundle.js"></script> + </body> </html> diff --git a/spec/SpecRunnerEs6.html b/spec/SpecRunnerEs6.html index eb6b17b..05156bd 100644 --- a/spec/SpecRunnerEs6.html +++ b/spec/SpecRunnerEs6.html @@ -1,45 +1,50 @@ <!DOCTYPE html> <html> -<head> - <meta charset="utf-8"> - <title>SVG.js - Jasmine Spec Runner</title> + <head> + <meta charset="utf-8" /> + <title>SVG.js - Jasmine Spec Runner</title> - <link rel="shortcut icon" type="image/png" href="../node_modules/jasmine-core/images/jasmine_favicon.png"> - <link rel="stylesheet" href="../node_modules/jasmine-core/lib/jasmine-core/jasmine.css"> + <link + rel="shortcut icon" + type="image/png" + href="../node_modules/jasmine-core/images/jasmine_favicon.png" + /> + <link + rel="stylesheet" + href="../node_modules/jasmine-core/lib/jasmine-core/jasmine.css" + /> - <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine.js"></script> - <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine-html.js"></script> - <script src="../node_modules/jasmine-core/lib/jasmine-core/boot.js"></script> - <script src="RAFPlugin.js"></script> + <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine.js"></script> + <script src="../node_modules/jasmine-core/lib/jasmine-core/jasmine-html.js"></script> + <script src="../node_modules/jasmine-core/lib/jasmine-core/boot.js"></script> + <script src="RAFPlugin.js"></script> - <link rel="stylesheet" href="fixtures/fixture.css"> + <link rel="stylesheet" href="fixtures/fixture.css" /> + </head> -</head> - -<body> - - <!-- include spec files here... --> - <script type="module" src="setupBrowser.js"></script> - <script type="module" src="spec/elements/A.js"></script> - <script type="module" src="spec/elements/Circle.js"></script> - <script type="module" src="spec/elements/ClipPath.js"></script> - <script type="module" src="spec/elements/Container.js"></script> - <script type="module" src="spec/elements/Dom.js"></script> - <script type="module" src="spec/elements/Element.js"></script> - <script type="module" src="spec/elements/ForeignObject.js"></script> - <script type="module" src="spec/elements/G.js"></script> - <script type="module" src="spec/elements/Image.js"></script> - <script type="module" src="spec/elements/Marker.js"></script> - <script type="module" src="spec/elements/Svg.js"></script> - <script type="module" src="spec/elements/Text.js"></script> - <script type="module" src="spec/elements/TextPath.js"></script> - <script type="module" src="spec/elements/Tspan.js"></script> - <script type="module" src="spec/modules/core/event.js"></script> - <script type="module" src="spec/modules/core/textable.js"></script> - <script type="module" src="spec/types/ArrayPolyfill.js"></script> - <script type="module" src="spec/types/Base.js"></script> - <script type="module" src="spec/types/Box.js"></script> - <script type="module" src="spec/utils/adopter.js"></script> - <script type="module" src="spec/utils/utils.js"></script> -</body> + <body> + <!-- include spec files here... --> + <script type="module" src="setupBrowser.js"></script> + <script type="module" src="spec/elements/A.js"></script> + <script type="module" src="spec/elements/Circle.js"></script> + <script type="module" src="spec/elements/ClipPath.js"></script> + <script type="module" src="spec/elements/Container.js"></script> + <script type="module" src="spec/elements/Dom.js"></script> + <script type="module" src="spec/elements/Element.js"></script> + <script type="module" src="spec/elements/ForeignObject.js"></script> + <script type="module" src="spec/elements/G.js"></script> + <script type="module" src="spec/elements/Image.js"></script> + <script type="module" src="spec/elements/Marker.js"></script> + <script type="module" src="spec/elements/Svg.js"></script> + <script type="module" src="spec/elements/Text.js"></script> + <script type="module" src="spec/elements/TextPath.js"></script> + <script type="module" src="spec/elements/Tspan.js"></script> + <script type="module" src="spec/modules/core/event.js"></script> + <script type="module" src="spec/modules/core/textable.js"></script> + <script type="module" src="spec/types/ArrayPolyfill.js"></script> + <script type="module" src="spec/types/Base.js"></script> + <script type="module" src="spec/types/Box.js"></script> + <script type="module" src="spec/utils/adopter.js"></script> + <script type="module" src="spec/utils/utils.js"></script> + </body> </html> diff --git a/spec/checkForAllTests.js b/spec/checkForAllTests.js index 99c648e..d25a6a4 100644 --- a/spec/checkForAllTests.js +++ b/spec/checkForAllTests.js @@ -2,7 +2,6 @@ const glob = require('glob') const path = require('path') glob('./spec/*/**/*.js', (err, tests) => { - if (err) { throw err } @@ -14,10 +13,13 @@ glob('./spec/*/**/*.js', (err, tests) => { files = files.map((e) => path.basename(e)) tests = tests.map((e) => path.basename(e)) - const difference = files.filter(x => !tests.includes(x)) + const difference = files.filter((x) => !tests.includes(x)) if (difference.length) { - console.error('The following files dont have a test file:\n\t' + difference.join('\n\t')) + console.error( + 'The following files dont have a test file:\n\t' + + difference.join('\n\t') + ) } else { console.info('All src files are covered by tests') } diff --git a/spec/fixtures/fixture.css b/spec/fixtures/fixture.css index 4fad17b..85d4345 100644 --- a/spec/fixtures/fixture.css +++ b/spec/fixtures/fixture.css @@ -1,6 +1,6 @@ #drawing { - width: 500px; - height: 500px; - position: fixed; - z-index: -1; + width: 500px; + height: 500px; + position: fixed; + z-index: -1; } diff --git a/spec/helpers.js b/spec/helpers.js index 7d63dfa..b5b29c3 100644 --- a/spec/helpers.js +++ b/spec/helpers.js @@ -1,7 +1,7 @@ import { getWindow } from '../src/utils/window.js' import { svg } from '../src/modules/core/namespaces.js' -function tag (name, attrs, children) { +function tag(name, attrs, children) { const doc = getWindow().document const el = doc.createElementNS(svg, name) let i @@ -11,7 +11,9 @@ function tag (name, attrs, children) { } for (i in children) { - if (typeof children[i] === 'string') { children[i] = doc.createTextNode(children[i]) } + if (typeof children[i] === 'string') { + children[i] = doc.createTextNode(children[i]) + } el.appendChild(children[i]) } @@ -19,104 +21,128 @@ function tag (name, attrs, children) { return el } -export function fixtures () { - return tag('svg', { - height: 0, - width: 0, - id: 'inlineSVG' - }, [ - tag('defs', {}, [ - tag('linearGradient', {}, [ - tag('stop', { offset: '5%', 'stop-color': 'green' }), - tag('stop', { offset: '95%', 'stop-color': 'gold' }) +export function fixtures() { + return tag( + 'svg', + { + height: 0, + width: 0, + id: 'inlineSVG' + }, + [ + tag('defs', {}, [ + tag('linearGradient', {}, [ + tag('stop', { offset: '5%', 'stop-color': 'green' }), + tag('stop', { offset: '95%', 'stop-color': 'gold' }) + ]), + tag('radialGradient', {}, [ + tag('stop', { offset: '5%', 'stop-color': 'green' }), + tag('stop', { offset: '95%', 'stop-color': 'gold' }) + ]) ]), - tag('radialGradient', {}, [ - tag('stop', { offset: '5%', 'stop-color': 'green' }), - tag('stop', { offset: '95%', 'stop-color': 'gold' }) - ]) - ]), - tag('desc', {}, [ 'Some description' ]), - tag('path', { - id: 'lineAB', - d: 'M 100 350 l 150 -300', - stroke: 'red', - 'stroke-width': '3', - fill: 'none' - }), - tag('path', { - id: 'lineBC', - d: 'M 250 50 l 150 300', - stroke: 'red', - 'stroke-width': '3', - fill: 'none' - }), - tag('path', { - d: 'M 175 200 l 150 0', - stroke: 'green', - 'stroke-width': '3', - fill: 'none' - }), - tag('path', { - d: 'M 100 350 q 150 -300 300 0', - stroke: 'blue', - 'stroke-width': '5', - fill: 'none' - }), - tag('g', { - stroke: 'black', - 'stroke-width': '2', - fill: 'black', - id: 'pointGroup' - }, [ - tag('circle', { - id: 'pointA', - cx: '100', - cy: '350', - r: '3' + tag('desc', {}, ['Some description']), + tag('path', { + id: 'lineAB', + d: 'M 100 350 l 150 -300', + stroke: 'red', + 'stroke-width': '3', + fill: 'none' }), - tag('circle', { - id: 'pointB', - cx: '250', - cy: '50', - r: '50' + tag('path', { + id: 'lineBC', + d: 'M 250 50 l 150 300', + stroke: 'red', + 'stroke-width': '3', + fill: 'none' }), - tag('circle', { - id: 'pointC', - cx: '400', - cy: '350', - r: '50' - }) - ]), - tag('g', { - 'font-size': '30', - font: 'sans-serif', - fill: 'black', - stroke: 'none', - 'text-anchor': 'middle', - id: 'labelGroup' - }, [ - tag('text', { - x: '100', - y: '350', - dy: '-30' - }, [ 'A' ]), - tag('text', { - x: '250', - y: '50', - dy: '-10' - }, [ 'B' ]), - tag('text', { - x: '400', - y: '350', - dx: '30' - }, [ 'C' ]) - ]), - tag('polygon', { points: '200,10 250,190 160,210' }), - tag('polyline', { points: '20,20 40,25 60,40 80,120 120,140 200,180' }) - ]) + tag('path', { + d: 'M 175 200 l 150 0', + stroke: 'green', + 'stroke-width': '3', + fill: 'none' + }), + tag('path', { + d: 'M 100 350 q 150 -300 300 0', + stroke: 'blue', + 'stroke-width': '5', + fill: 'none' + }), + tag( + 'g', + { + stroke: 'black', + 'stroke-width': '2', + fill: 'black', + id: 'pointGroup' + }, + [ + tag('circle', { + id: 'pointA', + cx: '100', + cy: '350', + r: '3' + }), + tag('circle', { + id: 'pointB', + cx: '250', + cy: '50', + r: '50' + }), + tag('circle', { + id: 'pointC', + cx: '400', + cy: '350', + r: '50' + }) + ] + ), + tag( + 'g', + { + 'font-size': '30', + font: 'sans-serif', + fill: 'black', + stroke: 'none', + 'text-anchor': 'middle', + id: 'labelGroup' + }, + [ + tag( + 'text', + { + x: '100', + y: '350', + dy: '-30' + }, + ['A'] + ), + tag( + 'text', + { + x: '250', + y: '50', + dy: '-10' + }, + ['B'] + ), + tag( + 'text', + { + x: '400', + y: '350', + dx: '30' + }, + ['C'] + ) + ] + ), + tag('polygon', { points: '200,10 250,190 160,210' }), + tag('polyline', { points: '20,20 40,25 60,40 80,120 120,140 200,180' }) + ] + ) } -export function buildFixtures () { +export function buildFixtures() { const doc = getWindow().document const body = doc.body || doc.documentElement @@ -134,7 +160,7 @@ export function buildFixtures () { body.appendChild(div) } -export function buildCanvas () { +export function buildCanvas() { const doc = getWindow().document const body = doc.body || doc.documentElement @@ -150,7 +176,7 @@ export function buildCanvas () { body.appendChild(div) } -export function clear () { +export function clear() { const doc = getWindow().document const canvas = doc.getElementById('canvas') const fixtures = doc.getElementById('fixtures') @@ -158,6 +184,7 @@ export function clear () { // remove if present fixtures && fixtures.parentNode.removeChild(fixtures) canvas.parentNode.removeChild(canvas) - - ;[ ...doc.querySelectorAll('svg') ].forEach((el) => el.parentNode.removeChild(el)) + ;[...doc.querySelectorAll('svg')].forEach((el) => + el.parentNode.removeChild(el) + ) } diff --git a/spec/runSVGDomTest.js b/spec/runSVGDomTest.js index 3ce24cf..cada481 100644 --- a/spec/runSVGDomTest.js +++ b/spec/runSVGDomTest.js @@ -10,12 +10,8 @@ const jasmine = new Jasmine() jasmine.loadConfig({ spec_dir: '/', - spec_files: [ - 'spec/spec/*/**/*.js' - ], - helpers: [ - 'spec/setupSVGDom.js' - ] + spec_files: ['spec/spec/*/**/*.js'], + helpers: ['spec/setupSVGDom.js'] }) jasmine.execute() diff --git a/spec/setupSVGDom.js b/spec/setupSVGDom.js index 22bf565..be5b803 100644 --- a/spec/setupSVGDom.js +++ b/spec/setupSVGDom.js @@ -7,7 +7,7 @@ import { registerWindow } from '../src/main.js' jasmine.DEFAULT_TIMEOUT_INTERVAL = 200 -function setup () { +function setup() { const win = createHTMLWindow() registerWindow(win, win.document) buildCanvas() @@ -15,7 +15,7 @@ function setup () { global.container = win.document.getElementById('canvas') } -function teardown () { +function teardown() { clear() global.container = null registerWindow() diff --git a/spec/spec/animation/Animator.js b/spec/spec/animation/Animator.js index 043beaa..695dca7 100644 --- a/spec/spec/animation/Animator.js +++ b/spec/spec/animation/Animator.js @@ -4,7 +4,6 @@ import { Animator, Queue } from '../../../src/main.js' import { getWindow } from '../../../src/utils/window.js' describe('Animator.js', () => { - beforeEach(() => { jasmine.RequestAnimationFrame.install(getWindow()) Animator.timeouts = new Queue() @@ -19,7 +18,6 @@ describe('Animator.js', () => { describe('timeout()', () => { it('calls a function after a specific time', () => { - var spy = jasmine.createSpy('tester') Animator.timeout(spy, 100) diff --git a/spec/spec/animation/Controller.js b/spec/spec/animation/Controller.js index 8ad074d..b81678b 100644 --- a/spec/spec/animation/Controller.js +++ b/spec/spec/animation/Controller.js @@ -1,12 +1,17 @@ /* globals describe, expect, it, jasmine */ import { easing, defaults } from '../../../src/main.js' -import { Stepper, Ease, Controller, Spring, PID } from '../../../src/animation/Controller.js' +import { + Stepper, + Ease, + Controller, + Spring, + PID +} from '../../../src/animation/Controller.js' const { any, createSpy } = jasmine describe('Controller.js', () => { - describe('easing', () => { var easedValues = { '-': 0.5, @@ -15,7 +20,7 @@ describe('Controller.js', () => { '<': 0.2929 } - ;[ '-', '<>', '<', '>' ].forEach((el) => { + ;['-', '<>', '<', '>'].forEach((el) => { describe(el, () => { it('is 0 at 0', () => { expect(easing[el](0)).toBe(0) diff --git a/spec/spec/animation/Morphable.js b/spec/spec/animation/Morphable.js index 2fa58aa..d5d313a 100644 --- a/spec/spec/animation/Morphable.js +++ b/spec/spec/animation/Morphable.js @@ -1,6 +1,18 @@ /* globals describe, expect, it, jasmine */ -import { Morphable, NonMorphable, ObjectBag, Color, Box, Matrix, PointArray, PathArray, TransformBag, Number as SVGNumber, Array as SVGArray } from '../../../src/main.js' +import { + Morphable, + NonMorphable, + ObjectBag, + Color, + Box, + Matrix, + PointArray, + PathArray, + TransformBag, + Number as SVGNumber, + Array as SVGArray +} from '../../../src/main.js' import { Stepper, easing, Ease } from '../../../src/animation/Controller.js' const { objectContaining, arrayContaining, any } = jasmine @@ -20,7 +32,6 @@ describe('Morphable.js', () => { }) describe('constructors', () => { - it('Morphable with SVGNumber', () => { const morpher = new Morphable().from(10).to(5) @@ -46,16 +57,25 @@ describe('Morphable.js', () => { expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(ObjectBag) expect(morpher.at(0.5)).toEqual(any(Object)) - expect(morpher.at(0.5).valueOf()).toEqual(objectContaining({ a: new SVGNumber(7.5), b: new SVGNumber(15) })) + expect(morpher.at(0.5).valueOf()).toEqual( + objectContaining({ a: new SVGNumber(7.5), b: new SVGNumber(15) }) + ) }) it('Morphable from object containing css values', () => { - const morpher = new Morphable().from({ opacity: '0', 'stroke-width': '10px' }).to({ opacity: 1, 'stroke-width': 20 }) + const morpher = new Morphable() + .from({ opacity: '0', 'stroke-width': '10px' }) + .to({ opacity: 1, 'stroke-width': 20 }) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(ObjectBag) expect(morpher.at(0.5)).toEqual(any(Object)) - expect(morpher.at(0.5).valueOf()).toEqual(objectContaining({ opacity: new SVGNumber(0.5), 'stroke-width': new SVGNumber('15px') })) + expect(morpher.at(0.5).valueOf()).toEqual( + objectContaining({ + opacity: new SVGNumber(0.5), + 'stroke-width': new SVGNumber('15px') + }) + ) }) it('Creates a morphable out of an SVGNumber', () => { @@ -77,48 +97,68 @@ describe('Morphable.js', () => { }) it('Creates a morphable out of an Box', () => { - const morpher = new Box(1, 2, 3, 4).to([ 5, 6, 7, 8 ]) + const morpher = new Box(1, 2, 3, 4).to([5, 6, 7, 8]) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(Box) expect(morpher.at(0.5)).toEqual(any(Box)) - expect(morpher.at(0.5)).toEqual(objectContaining({ x: 3, y: 4, width: 5, height: 6 })) + expect(morpher.at(0.5)).toEqual( + objectContaining({ x: 3, y: 4, width: 5, height: 6 }) + ) }) it('Creates a morphable out of an Matrix', () => { - const morpher = new Matrix(1, 2, 3, 4, 5, 6).to([ 3, 4, 5, 6, 7, 8 ]) + const morpher = new Matrix(1, 2, 3, 4, 5, 6).to([3, 4, 5, 6, 7, 8]) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(Matrix) expect(morpher.at(0.5)).toEqual(any(Matrix)) - expect(morpher.at(0.5)).toEqual(objectContaining(new Matrix(2, 3, 4, 5, 6, 7))) + expect(morpher.at(0.5)).toEqual( + objectContaining(new Matrix(2, 3, 4, 5, 6, 7)) + ) }) it('Creates a morphable out of an SVGArray', () => { - const morpher = new SVGArray([ 1, 2, 3, 4, 5, 6 ]).to([ 3, 4, 5, 6, 7, 8 ]) + const morpher = new SVGArray([1, 2, 3, 4, 5, 6]).to([3, 4, 5, 6, 7, 8]) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(SVGArray) expect(morpher.at(0.5)).toEqual(any(SVGArray)) - expect(morpher.at(0.5).toArray()).toEqual(arrayContaining([ 2, 3, 4, 5, 6, 7 ])) + expect(morpher.at(0.5).toArray()).toEqual( + arrayContaining([2, 3, 4, 5, 6, 7]) + ) }) it('Creates a morphable out of an PointArray', () => { - const morpher = new PointArray([ 1, 2, 3, 4, 5, 6 ]).to([ 3, 4, 5, 6, 7, 8 ]) + const morpher = new PointArray([1, 2, 3, 4, 5, 6]).to([3, 4, 5, 6, 7, 8]) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(PointArray) expect(morpher.at(0.5)).toEqual(any(PointArray)) - expect(morpher.at(0.5).toArray()).toEqual(arrayContaining([ 2, 3, 4, 5, 6, 7 ])) + expect(morpher.at(0.5).toArray()).toEqual( + arrayContaining([2, 3, 4, 5, 6, 7]) + ) }) it('Creates a morphable out of an PathArray', () => { - const morpher = new PathArray([ 'M', 1, 2, 'L', 3, 4, 'L', 5, 6 ]).to([ 'M', 3, 4, 'L', 5, 6, 'L', 7, 8 ]) + const morpher = new PathArray(['M', 1, 2, 'L', 3, 4, 'L', 5, 6]).to([ + 'M', + 3, + 4, + 'L', + 5, + 6, + 'L', + 7, + 8 + ]) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(PathArray) expect(morpher.at(0.5)).toEqual(any(PathArray)) - expect(morpher.at(0.5).toArray()).toEqual(arrayContaining([ 'M', 2, 3, 'L', 4, 5, 'L', 6, 7 ])) + expect(morpher.at(0.5).toArray()).toEqual( + arrayContaining(['M', 2, 3, 'L', 4, 5, 'L', 6, 7]) + ) }) it('creates a morphable from unmorphable types', () => { @@ -132,14 +172,18 @@ describe('Morphable.js', () => { }) it('Creates a morphable out of an TransformBag', () => { - const morpher = new TransformBag({ rotate: 0, translateX: 0 }) - .to({ rotate: 50, translateX: 20 }) + const morpher = new TransformBag({ rotate: 0, translateX: 0 }).to({ + rotate: 50, + translateX: 20 + }) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(TransformBag) expect(morpher.at(0.5)).toEqual(any(TransformBag)) - expect(morpher.at(0.5)).toEqual(objectContaining({ rotate: 25, translateX: 10 })) + expect(morpher.at(0.5)).toEqual( + objectContaining({ rotate: 25, translateX: 10 }) + ) }) it('Creates a morphable out of an ObjectBag', () => { @@ -148,7 +192,9 @@ describe('Morphable.js', () => { expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(ObjectBag) expect(morpher.at(0.5)).toEqual(any(Object)) - expect(morpher.at(0.5).valueOf()).toEqual(objectContaining({ a: new SVGNumber(7.5), b: new SVGNumber(15) })) + expect(morpher.at(0.5).valueOf()).toEqual( + objectContaining({ a: new SVGNumber(7.5), b: new SVGNumber(15) }) + ) }) it('creates a morphable from a color string', () => { @@ -198,16 +244,16 @@ describe('Morphable.js', () => { expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(SVGArray) expect(morpher.at(0.5)).toEqual(any(SVGArray)) - expect(morpher.at(0.5)).toEqual([ 2, 3, 4, 5 ]) + expect(morpher.at(0.5)).toEqual([2, 3, 4, 5]) }) it('creates a morphable from an array', () => { - const morpher = new Morphable().from([ 0, 1, 2, 3 ]).to([ 4, 5, 6, 7 ]) + const morpher = new Morphable().from([0, 1, 2, 3]).to([4, 5, 6, 7]) expect(morpher).toEqual(any(Morphable)) expect(morpher.type()).toBe(SVGArray) expect(morpher.at(0.5)).toEqual(any(SVGArray)) - expect(morpher.at(0.5)).toEqual([ 2, 3, 4, 5 ]) + expect(morpher.at(0.5)).toEqual([2, 3, 4, 5]) }) it('converts the to-color to the from-type', () => { @@ -231,7 +277,7 @@ describe('Morphable.js', () => { it('sets the from attribute to an array representation of the morphable type', () => { const morpher = new Morphable().from(5) - expect(morpher.from()).toEqual(arrayContaining([ 5 ])) + expect(morpher.from()).toEqual(arrayContaining([5])) }) }) @@ -255,7 +301,7 @@ describe('Morphable.js', () => { it('sets the from attribute to an array representation of the morphable type', () => { const morpher = new Morphable().to(5) - expect(morpher.to()).toEqual(arrayContaining([ 5 ])) + expect(morpher.to()).toEqual(arrayContaining([5])) }) }) @@ -270,7 +316,7 @@ describe('Morphable.js', () => { describe('NonMorphable', () => { describe('()', () => { it('wraps any type into a NonMorphable from an array', () => { - const non = new NonMorphable([ 5 ]) + const non = new NonMorphable([5]) expect(non.valueOf()).toBe(5) }) @@ -282,8 +328,8 @@ describe('Morphable.js', () => { describe('toArray()', () => { it('returns array representation of NonMorphable', () => { - expect(new NonMorphable(5).toArray()).toEqual([ 5 ]) - expect(new NonMorphable('Hello').toArray()).toEqual([ 'Hello' ]) + expect(new NonMorphable(5).toArray()).toEqual([5]) + expect(new NonMorphable('Hello').toArray()).toEqual(['Hello']) }) }) }) @@ -291,8 +337,8 @@ describe('Morphable.js', () => { describe('TransformBag', () => { describe('()', () => { it('creates an object which holds transformations for morphing by passing array', () => { - const bag = new TransformBag([ 0, 1, 2, 3, 4, 5, 6, 7 ]) - expect(bag.toArray()).toEqual([ 0, 1, 2, 3, 4, 5, 6, 7 ]) + const bag = new TransformBag([0, 1, 2, 3, 4, 5, 6, 7]) + expect(bag.toArray()).toEqual([0, 1, 2, 3, 4, 5, 6, 7]) }) it('creates an object which holds transformations for morphing by passing object', () => { @@ -307,14 +353,14 @@ describe('Morphable.js', () => { originY: 7 }) - expect(bag.toArray()).toEqual([ 0, 1, 2, 3, 4, 5, 6, 7 ]) + expect(bag.toArray()).toEqual([0, 1, 2, 3, 4, 5, 6, 7]) }) }) describe('toArray()', () => { it('creates an array out of the transform values', () => { - const bag = new TransformBag([ 0, 1, 2, 3, 4, 5, 6, 7 ]) - expect(bag.toArray()).toEqual([ 0, 1, 2, 3, 4, 5, 6, 7 ]) + const bag = new TransformBag([0, 1, 2, 3, 4, 5, 6, 7]) + expect(bag.toArray()).toEqual([0, 1, 2, 3, 4, 5, 6, 7]) }) }) }) @@ -322,51 +368,174 @@ describe('Morphable.js', () => { describe('ObjectBag', () => { describe('()', () => { it('wraps an object into a morphable object by passing an array', () => { - const bag = new ObjectBag([ 'foo', SVGNumber, 2, 1, '', 'bar', SVGNumber, 2, 2, '', 'baz', SVGNumber, 2, 3, '' ]) - expect(bag.values).toEqual([ 'foo', SVGNumber, 2, 1, '', 'bar', SVGNumber, 2, 2, '', 'baz', SVGNumber, 2, 3, '' ]) + const bag = new ObjectBag([ + 'foo', + SVGNumber, + 2, + 1, + '', + 'bar', + SVGNumber, + 2, + 2, + '', + 'baz', + SVGNumber, + 2, + 3, + '' + ]) + expect(bag.values).toEqual([ + 'foo', + SVGNumber, + 2, + 1, + '', + 'bar', + SVGNumber, + 2, + 2, + '', + 'baz', + SVGNumber, + 2, + 3, + '' + ]) }) it('wraps an object into a morphable object by passing an object', () => { const bag = new ObjectBag({ foo: 1, bar: 2, baz: 3 }) - expect(bag.values).toEqual([ 'bar', SVGNumber, 2, 2, '', 'baz', SVGNumber, 2, 3, '', 'foo', SVGNumber, 2, 1, '' ]) + expect(bag.values).toEqual([ + 'bar', + SVGNumber, + 2, + 2, + '', + 'baz', + SVGNumber, + 2, + 3, + '', + 'foo', + SVGNumber, + 2, + 1, + '' + ]) }) it('wraps an object with morphable values in an ObjectBag', () => { const bag = new ObjectBag({ fill: new Color(), bar: 2 }) - expect(bag.values).toEqual([ 'bar', SVGNumber, 2, 2, '', 'fill', Color, 5, 0, 0, 0, 0, 'rgb' ]) + expect(bag.values).toEqual([ + 'bar', + SVGNumber, + 2, + 2, + '', + 'fill', + Color, + 5, + 0, + 0, + 0, + 0, + 'rgb' + ]) }) it('wraps an array with morphable representation in an ObjectBag', () => { - const bag = new ObjectBag([ 'bar', SVGNumber, 2, 2, '', 'fill', Color, 5, 0, 0, 0, 0, 'rgb' ]) - expect(bag.toArray()).toEqual([ 'bar', SVGNumber, 2, 2, '', 'fill', Color, 5, 0, 0, 0, 0, 'rgb' ]) + const bag = new ObjectBag([ + 'bar', + SVGNumber, + 2, + 2, + '', + 'fill', + Color, + 5, + 0, + 0, + 0, + 0, + 'rgb' + ]) + expect(bag.toArray()).toEqual([ + 'bar', + SVGNumber, + 2, + 2, + '', + 'fill', + Color, + 5, + 0, + 0, + 0, + 0, + 'rgb' + ]) }) }) describe('toArray()', () => { it('creates an array out of the object', () => { const bag = new ObjectBag({ foo: 1, bar: 2, baz: 3 }) - expect(bag.toArray()).toEqual( - [ 'bar', SVGNumber, 2, 2, '', 'baz', SVGNumber, 2, 3, '', 'foo', SVGNumber, 2, 1, '' ] - ) + expect(bag.toArray()).toEqual([ + 'bar', + SVGNumber, + 2, + 2, + '', + 'baz', + SVGNumber, + 2, + 3, + '', + 'foo', + SVGNumber, + 2, + 1, + '' + ]) }) it('creates a flattened array out of the object with morphable values', () => { const bag = new ObjectBag({ fill: new Color(), bar: 2 }) - expect(bag.toArray()).toEqual( - [ 'bar', SVGNumber, 2, 2, '', 'fill', Color, 5, 0, 0, 0, 0, 'rgb' ] - ) + expect(bag.toArray()).toEqual([ + 'bar', + SVGNumber, + 2, + 2, + '', + 'fill', + Color, + 5, + 0, + 0, + 0, + 0, + 'rgb' + ]) }) }) describe('valueOf()', () => { it('creates morphable objects from the stored values', () => { const bag = new ObjectBag({ foo: 1, bar: 2, baz: 3 }) - expect(bag.valueOf()).toEqual({ foo: new SVGNumber(1), bar: new SVGNumber(2), baz: new SVGNumber(3) }) + expect(bag.valueOf()).toEqual({ + foo: new SVGNumber(1), + bar: new SVGNumber(2), + baz: new SVGNumber(3) + }) }) it('creates also morphable objects from the stored values', () => { const bag = new ObjectBag({ fill: new Color(), bar: 2 }) - expect(bag.valueOf()).toEqual({ fill: objectContaining(new Color()), bar: new SVGNumber(2) }) + expect(bag.valueOf()).toEqual({ + fill: objectContaining(new Color()), + bar: new SVGNumber(2) + }) }) }) @@ -375,7 +544,21 @@ describe('Morphable.js', () => { const bag1 = new ObjectBag({ x: 1, y: '#fff' }) const bag2 = new ObjectBag({ x: 2, y: new Color().hsl() }) bag1.align(bag2.toArray()) - expect(bag1.toArray()).toEqual([ 'x', SVGNumber, 2, 1, '', 'y', Color, 5, 0, 0, 100, 0, 'hsl' ]) + expect(bag1.toArray()).toEqual([ + 'x', + SVGNumber, + 2, + 1, + '', + 'y', + Color, + 5, + 0, + 0, + 100, + 0, + 'hsl' + ]) }) }) }) diff --git a/spec/spec/animation/Queue.js b/spec/spec/animation/Queue.js index 8386405..b405b62 100644 --- a/spec/spec/animation/Queue.js +++ b/spec/spec/animation/Queue.js @@ -3,9 +3,7 @@ import { Queue } from '../../../src/main.js' describe('Queue.js', function () { - describe('first ()', function () { - it('returns null if no item in the queue', function () { var queue = new Queue() expect(queue.first()).toEqual(null) @@ -21,7 +19,6 @@ describe('Queue.js', function () { }) describe('last ()', function () { - it('returns null if no item in the queue', function () { var queue = new Queue() expect(queue.last()).toEqual(null) @@ -37,7 +34,6 @@ describe('Queue.js', function () { }) describe('push ()', function () { - it('adds an element to the end of the queue', function () { var queue = new Queue() queue.push(1) diff --git a/spec/spec/animation/Runner.js b/spec/spec/animation/Runner.js index 2512dac..2325fd5 100644 --- a/spec/spec/animation/Runner.js +++ b/spec/spec/animation/Runner.js @@ -1,6 +1,22 @@ /* globals describe, expect, it, beforeEach, afterEach, spyOn, jasmine */ -import { Runner, defaults, Ease, Controller, SVG, Timeline, Rect, Morphable, Animator, Queue, Matrix, Color, Box, Polygon, PointArray } from '../../../src/main.js' +import { + Runner, + defaults, + Ease, + Controller, + SVG, + Timeline, + Rect, + Morphable, + Animator, + Queue, + Matrix, + Color, + Box, + Polygon, + PointArray +} from '../../../src/main.js' import { FakeRunner, RunnerArray } from '../../../src/animation/Runner.js' import { getWindow } from '../../../src/utils/window.js' import SVGNumber from '../../../src/types/SVGNumber.js' @@ -8,7 +24,6 @@ import SVGNumber from '../../../src/types/SVGNumber.js' const { any, createSpy, objectContaining, arrayContaining } = jasmine describe('Runner.js', () => { - describe('Runner', () => { var initFn = createSpy('initFn') var runFn = createSpy('runFn') @@ -31,59 +46,73 @@ describe('Runner.js', () => { it('can handle all form of input', () => { var fn = Runner.sanitise - expect(fn(200, 200, 'now')).toEqual(objectContaining({ - duration: 200, - delay: 200, - when: 'now', - times: 1, - wait: 0, - swing: false - })) - - expect(fn(200, 200)).toEqual(objectContaining({ - duration: 200, - delay: 200, - when: 'last', - times: 1, - wait: 0, - swing: false - })) - - expect(fn(200)).toEqual(objectContaining({ - duration: 200, - delay: defaults.timeline.delay, - when: 'last', - times: 1, - wait: 0, - swing: false - })) - - expect(fn(runFn)).toEqual(objectContaining({ - duration: runFn, - delay: defaults.timeline.delay, - when: 'last', - times: 1, - wait: 0, - swing: false - })) - - expect(fn({ delay: 200 })).toEqual(objectContaining({ - duration: defaults.timeline.duration, - delay: 200, - when: 'last', - times: 1, - wait: 0, - swing: false - })) - - expect(fn({ times: 3, delay: 200, when: 'now', swing: true, wait: 200 })).toEqual(objectContaining({ - duration: defaults.timeline.duration, - delay: 200, - when: 'now', - times: 3, - wait: 200, - swing: true - })) + expect(fn(200, 200, 'now')).toEqual( + objectContaining({ + duration: 200, + delay: 200, + when: 'now', + times: 1, + wait: 0, + swing: false + }) + ) + + expect(fn(200, 200)).toEqual( + objectContaining({ + duration: 200, + delay: 200, + when: 'last', + times: 1, + wait: 0, + swing: false + }) + ) + + expect(fn(200)).toEqual( + objectContaining({ + duration: 200, + delay: defaults.timeline.delay, + when: 'last', + times: 1, + wait: 0, + swing: false + }) + ) + + expect(fn(runFn)).toEqual( + objectContaining({ + duration: runFn, + delay: defaults.timeline.delay, + when: 'last', + times: 1, + wait: 0, + swing: false + }) + ) + + expect(fn({ delay: 200 })).toEqual( + objectContaining({ + duration: defaults.timeline.duration, + delay: 200, + when: 'last', + times: 1, + wait: 0, + swing: false + }) + ) + + expect( + fn({ times: 3, delay: 200, when: 'now', swing: true, wait: 200 }) + ).toEqual( + objectContaining({ + duration: defaults.timeline.duration, + delay: 200, + when: 'now', + times: 3, + wait: 200, + swing: true + }) + ) }) }) @@ -115,17 +144,18 @@ describe('Runner.js', () => { var runner = new Runner() runner.queue(initFn, runFn, true) - expect(runner._queue[0]).toEqual(objectContaining({ - initialiser: initFn, - initialised: false, - runner: runFn, - finished: false - })) + expect(runner._queue[0]).toEqual( + objectContaining({ + initialiser: initFn, + initialised: false, + runner: runFn, + finished: false + }) + ) }) }) describe('step()', () => { - it('returns itself', () => { var runner = new Runner() expect(runner.step()).toBe(runner) @@ -163,7 +193,7 @@ describe('Runner.js', () => { expect(runFn.calls.count()).toBe(2) }) - function getLoop (r) { + function getLoop(r) { var loopDuration = r._duration + r._wait var loopsDone = Math.floor(r._time / loopDuration) return loopsDone @@ -447,7 +477,6 @@ describe('Runner.js', () => { }) }) }) - }) describe('active()', () => { @@ -613,7 +642,6 @@ describe('Runner.js', () => { }) describe('position()', () => { - it('gets the position of a runner', () => { var spy = createSpy('stepper') var runner = new Runner(1000).queue(null, spy) @@ -718,9 +746,10 @@ describe('Runner.js', () => { it('throws if no timeline is given', () => { var runner = new Runner() - expect(() => runner.schedule(200, 'now')).toThrowError('Runner cannot be scheduled without timeline') + expect(() => runner.schedule(200, 'now')).toThrowError( + 'Runner cannot be scheduled without timeline' + ) }) - }) describe('unschedule()', () => { @@ -750,10 +779,22 @@ describe('Runner.js', () => { expect(runner2.timeline()).toBe(timeline) expect(runner2.time()).toBe(0) - expect(timeline.schedule()).toEqual(arrayContaining([ - objectContaining({ start: t, duration: 1000, end: t + 1000, runner: runner }), - objectContaining({ start: t + 2000, duration: 500, end: t + 2500, runner: runner2 }) - ])) + expect(timeline.schedule()).toEqual( + arrayContaining([ + objectContaining({ + start: t, + duration: 1000, + end: t + 1000, + runner: runner + }), + objectContaining({ + start: t + 2000, + duration: 500, + end: t + 2500, + runner: runner2 + }) + ]) + ) }) it('reuses timeline and element of current runner', () => { @@ -909,7 +950,7 @@ describe('Runner.js', () => { const runner = rect.animate().move(10, 10) jasmine.RequestAnimationFrame.tick(16) expect(runner._tryRetarget('x', 20)).toBe(true) - expect(runner._history.x.morpher.to()).toEqual([ 20, '' ]) + expect(runner._history.x.morpher.to()).toEqual([20, '']) }) it('throws away the morpher if it was not initialized yet and returns false', () => { @@ -929,10 +970,14 @@ describe('Runner.js', () => { it('does only work with controller for transformations and uses retarget function when retargeting transformations', () => { const rect = new Rect() - const runner = rect.animate(new Controller(() => 0)).transform({ translate: [ 10, 10 ] }) + const runner = rect + .animate(new Controller(() => 0)) + .transform({ translate: [10, 10] }) jasmine.RequestAnimationFrame.tick(16) // In that case tryRetarget is not successful - expect(runner._tryRetarget('transform', { translate: [ 20, 20 ] })).toBe(true) + expect( + runner._tryRetarget('transform', { translate: [20, 20] }) + ).toBe(true) }) it('starts the timeline if retarget was successful', () => { @@ -942,7 +987,7 @@ describe('Runner.js', () => { jasmine.RequestAnimationFrame.tick(16) const spy = spyOn(timeline, 'play') expect(runner._tryRetarget('x', 20)).toBe(true) - expect(runner._history.x.morpher.to()).toEqual([ 20, '' ]) + expect(runner._history.x.morpher.to()).toEqual([20, '']) expect(spy).toHaveBeenCalledTimes(1) }) }) @@ -1002,7 +1047,7 @@ describe('Runner.js', () => { describe('addTransform()', () => { it('adds a transformation by multiplying', () => { const runner = new Runner() - runner.addTransform({ translate: [ 10, 10 ] }) + runner.addTransform({ translate: [10, 10] }) expect(runner.transforms).toEqual(new Matrix(1, 0, 0, 1, 10, 10)) }) }) @@ -1010,7 +1055,7 @@ describe('Runner.js', () => { describe('clearTransform()', () => { it('resets the transformations to identity', () => { const runner = new Runner() - runner.addTransform({ translate: [ 10, 10 ] }) + runner.addTransform({ translate: [10, 10] }) runner.clearTransform() expect(runner.transforms).toEqual(new Matrix()) }) @@ -1019,7 +1064,7 @@ describe('Runner.js', () => { describe('clearTransformsFromQueue', () => { it('deletes all functions from the queue which are transformations', () => { const runner = new Runner().queue(initFn, runFn) - runner.transform({ translate: [ 10, 20 ] }) + runner.transform({ translate: [10, 20] }) runner.clearTransformsFromQueue() expect(runner._queue.length).toBe(1) }) @@ -1062,17 +1107,15 @@ describe('Runner.js', () => { it('calculates the current transformation of this element', () => { const rect = new Rect() rect._prepareRunner() - const runner1 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner1 = new Runner().addTransform({ translate: [10, 20] }) const runner2 = new Runner().addTransform({ rotate: 45 }) - const runner3 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner3 = new Runner().addTransform({ translate: [10, 20] }) rect._addRunner(runner1) rect._addRunner(runner2) rect._addRunner(runner3) expect(rect._currentTransform(runner3)).toEqual( - new Matrix({ translate: [ 10, 20 ] }) - .rotate(45) - .translate(10, 20) + new Matrix({ translate: [10, 20] }).rotate(45).translate(10, 20) ) }) }) @@ -1132,14 +1175,26 @@ describe('Runner.js', () => { const runner = new Runner() runner.styleAttr('attr', 'x', 5) expect(runner._history.attr.morpher).toEqual(any(Morphable)) - expect(runner._history.attr.morpher.to()).toEqual([ 'x', SVGNumber, 2, 5, '' ]) + expect(runner._history.attr.morpher.to()).toEqual([ + 'x', + SVGNumber, + 2, + 5, + '' + ]) }) it('adds a morpher for css', () => { const runner = new Runner() runner.styleAttr('css', 'x', 5) expect(runner._history.css.morpher).toEqual(any(Morphable)) - expect(runner._history.css.morpher.to()).toEqual([ 'x', SVGNumber, 2, 5, '' ]) + expect(runner._history.css.morpher.to()).toEqual([ + 'x', + SVGNumber, + 2, + 5, + '' + ]) }) it('adds init and run fn for execution when runner runs', () => { @@ -1147,8 +1202,20 @@ describe('Runner.js', () => { const runner = new Runner(100).ease('-').element(element) runner.styleAttr('attr', 'x', 5) runner.step(50) - expect(runner._history.attr.morpher.from()).toEqual([ 'x', SVGNumber, 2, 0, '' ]) - expect(runner._history.attr.morpher.to()).toEqual([ 'x', SVGNumber, 2, 5, '' ]) + expect(runner._history.attr.morpher.from()).toEqual([ + 'x', + SVGNumber, + 2, + 0, + '' + ]) + expect(runner._history.attr.morpher.to()).toEqual([ + 'x', + SVGNumber, + 2, + 5, + '' + ]) expect(element.x()).toBe(2.5) }) @@ -1157,18 +1224,54 @@ describe('Runner.js', () => { const runner = new Runner(100).ease('-').element(element) runner.styleAttr('attr', { fill: '#000', stroke: new Color('#fff') }) runner.step(50) - expect(runner._history.attr.morpher.from()).toEqual( - [ 'fill', Color, 5, 255, 255, 255, 0, 'rgb', 'stroke', Color, 5, 0, 0, 0, 0, 'rgb' ] - ) - - expect(runner._history.attr.morpher.to()).toEqual( - [ 'fill', Color, 5, 0, 0, 0, 0, 'rgb', 'stroke', Color, 5, 255, 255, 255, 0, 'rgb' ] - ) + expect(runner._history.attr.morpher.from()).toEqual([ + 'fill', + Color, + 5, + 255, + 255, + 255, + 0, + 'rgb', + 'stroke', + Color, + 5, + 0, + 0, + 0, + 0, + 'rgb' + ]) + + expect(runner._history.attr.morpher.to()).toEqual([ + 'fill', + Color, + 5, + 0, + 0, + 0, + 0, + 'rgb', + 'stroke', + Color, + 5, + 255, + 255, + 255, + 0, + 'rgb' + ]) const result = runner._history.attr.morpher.at(0.5).valueOf() expect(result.fill).toEqual(any(Color)) expect(result.stroke).toEqual(any(Color)) - expect(result.fill.toArray()).toEqual([ 127.5, 127.5, 127.5, 0, 'rgb' ]) - expect(result.stroke.toArray()).toEqual([ 127.5, 127.5, 127.5, 0, 'rgb' ]) + expect(result.fill.toArray()).toEqual([127.5, 127.5, 127.5, 0, 'rgb']) + expect(result.stroke.toArray()).toEqual([ + 127.5, + 127.5, + 127.5, + 0, + 'rgb' + ]) }) it('it changes color space', () => { @@ -1176,16 +1279,30 @@ describe('Runner.js', () => { const runner = new Runner(100).ease('-').element(element) runner.styleAttr('attr', { fill: new Color(100, 12, 12, 'hsl') }) runner.step(50) - expect(runner._history.attr.morpher.from()).toEqual( - [ 'fill', Color, 5, 0, 0, 100, 0, 'hsl' ] - ) - - expect(runner._history.attr.morpher.to()).toEqual( - [ 'fill', Color, 5, 100, 12, 12, 0, 'hsl' ] - ) + expect(runner._history.attr.morpher.from()).toEqual([ + 'fill', + Color, + 5, + 0, + 0, + 100, + 0, + 'hsl' + ]) + + expect(runner._history.attr.morpher.to()).toEqual([ + 'fill', + Color, + 5, + 100, + 12, + 12, + 0, + 'hsl' + ]) const result = runner._history.attr.morpher.at(0.5).valueOf() expect(result.fill).toEqual(any(Color)) - expect(result.fill.toArray()).toEqual([ 50, 6, 56, 0, 'hsl' ]) + expect(result.fill.toArray()).toEqual([50, 6, 56, 0, 'hsl']) expect(element.fill()).toBe('#969388') }) @@ -1195,7 +1312,10 @@ describe('Runner.js', () => { runner.styleAttr('attr', { fill: new Color(100, 12, 12, 'hsl') }) runner.step(50) expect(element.fill()).toBe('#969388') - runner.styleAttr('attr', { fill: new Color(100, 50, 50, 'hsl'), x: 50 }) + runner.styleAttr('attr', { + fill: new Color(100, 50, 50, 'hsl'), + x: 50 + }) runner.step(25) expect(element.fill()).toBe('#b1c37c') expect(element.x()).toBe(37.5) @@ -1213,14 +1333,17 @@ describe('Runner.js', () => { }) }) - function closeTo (number, precision = 2) { + function closeTo(number, precision = 2) { return { /* * The asymmetricMatch function is required, and must return a boolean. */ asymmetricMatch: function (compareTo) { const factor = 10 ** precision - return Math.round((~~(compareTo * factor)) / factor) === Math.round((~~(number * factor)) / factor) + return ( + Math.round(~~(compareTo * factor) / factor) === + Math.round(~~(number * factor) / factor) + ) }, /* @@ -1228,12 +1351,14 @@ describe('Runner.js', () => { * be seen by the user in the message when a test fails. */ jasmineToString: function () { - return '<close to: ' + number + ' with precision: ' + precision + '>' + return ( + '<close to: ' + number + ' with precision: ' + precision + '>' + ) } } } - function equal (obj) { + function equal(obj) { return { /* * The asymmetricMatch function is required, and must return a boolean. @@ -1242,7 +1367,9 @@ describe('Runner.js', () => { if (!(compareTo instanceof obj.constructor)) return false const keys = Object.keys(obj) - const difference = Object.keys(compareTo).filter((el) => !keys.includes(el)) + const difference = Object.keys(compareTo).filter( + (el) => !keys.includes(el) + ) if (difference.length) return false @@ -1269,15 +1396,16 @@ describe('Runner.js', () => { const runner = new Runner(100).ease('-').element(element) runner.zoom(2, { x: 0, y: 0 }) runner.step(50) - expect(runner._history.zoom.morpher.from()).toEqual( - [ 1, '' ] - ) - expect(runner._history.zoom.morpher.to()).toEqual( - [ 2, '' ] - ) + expect(runner._history.zoom.morpher.from()).toEqual([1, '']) + expect(runner._history.zoom.morpher.to()).toEqual([2, '']) expect(element.zoom()).toBeCloseTo(1.5, 10) - expect(element.viewbox().toArray()).toEqual([ 0, 0, closeTo(66.666, 3), closeTo(66.666, 3) ]) + expect(element.viewbox().toArray()).toEqual([ + 0, + 0, + closeTo(66.666, 3), + closeTo(66.666, 3) + ]) }) it('retargets if called twice', () => { @@ -1286,16 +1414,17 @@ describe('Runner.js', () => { runner.zoom(2, { x: 0, y: 0 }) runner.step(50) runner.zoom(4, { x: 0, y: 0 }) - expect(runner._history.zoom.morpher.from()).toEqual( - [ 1, '' ] - ) - expect(runner._history.zoom.morpher.to()).toEqual( - [ 4, '' ] - ) + expect(runner._history.zoom.morpher.from()).toEqual([1, '']) + expect(runner._history.zoom.morpher.to()).toEqual([4, '']) runner.step(25) expect(element.zoom()).toBeCloseTo(3.25, 10) - expect(element.viewbox().toArray()).toEqual([ 0, 0, closeTo(30.769, 3), closeTo(30.769, 3) ]) + expect(element.viewbox().toArray()).toEqual([ + 0, + 0, + closeTo(30.769, 3), + closeTo(30.769, 3) + ]) }) }) @@ -1303,52 +1432,59 @@ describe('Runner.js', () => { it('does not retarget for non-declarative transformations', () => { const runner = new Runner() const spy = spyOn(runner, '_tryRetarget') - runner.transform({ translate: [ 10, 20 ] }) + runner.transform({ translate: [10, 20] }) expect(spy).not.toHaveBeenCalled() }) it('does not retarget for relative transformations', () => { const runner = new Runner(new Controller(() => 0)) const spy = spyOn(runner, '_tryRetarget') - runner.transform({ translate: [ 10, 20 ] }, true) + runner.transform({ translate: [10, 20] }, true) expect(spy).not.toHaveBeenCalled() }) it('does retarget for absolute declarative transformations', () => { const runner = new Runner(new Controller(() => 0)) const spy = spyOn(runner, '_tryRetarget') - runner.transform({ translate: [ 10, 20 ] }) + runner.transform({ translate: [10, 20] }) expect(spy).toHaveBeenCalled() }) it('calls queue with isTransform=true', () => { const runner = new Runner() const spy = spyOn(runner, 'queue') - runner.transform({ translate: [ 10, 20 ] }) - expect(spy).toHaveBeenCalledWith(any(Function), any(Function), any(Function), true) + runner.transform({ translate: [10, 20] }) + expect(spy).toHaveBeenCalledWith( + any(Function), + any(Function), + any(Function), + true + ) }) it('steps an affine transformation correctly', () => { const element = new Rect() const runner = new Runner(100).ease('-').element(element) - runner.transform({ translate: [ 10, 20 ], scale: 2, rotate: 90 }) + runner.transform({ translate: [10, 20], scale: 2, rotate: 90 }) runner.step(50) // transform sets an immediate callback to apply all merged transforms // when every runner had the chance to add its bit of transforms jasmine.RequestAnimationFrame.tick(1) - expect(element.matrix().decompose()).toEqual(objectContaining({ - translateX: 5, - translateY: 10, - scaleX: closeTo(1.5, 10), - scaleY: closeTo(1.5), - rotate: closeTo(45, 10) - })) + expect(element.matrix().decompose()).toEqual( + objectContaining({ + translateX: 5, + translateY: 10, + scaleX: closeTo(1.5, 10), + scaleY: closeTo(1.5), + rotate: closeTo(45, 10) + }) + ) }) it('retargets an affine transformation correctly', () => { const element = new Rect() const runner = new Runner(() => 1).element(element) - runner.transform({ translate: [ 10, 20 ], scale: 2, rotate: 90 }) + runner.transform({ translate: [10, 20], scale: 2, rotate: 90 }) runner.step(50) runner.transform({ scale: 2 }) @@ -1357,26 +1493,26 @@ describe('Runner.js', () => { // on every frame. That is why we step here to see the effect of our retargeting runner.step(25) - expect(runner._history.transform.morpher.to()).toEqual( - [ 2, 2, 0, 0, 0, 0, 0, 0 ] - ) + expect(runner._history.transform.morpher.to()).toEqual([ + 2, 2, 0, 0, 0, 0, 0, 0 + ]) }) it('retargets an affine transformation correctly and sets new origin', () => { const element = new Rect() const runner = new Runner(() => 1).element(element) - runner.transform({ translate: [ 10, 20 ], scale: 2, rotate: 90 }) + runner.transform({ translate: [10, 20], scale: 2, rotate: 90 }) runner.step(50) - runner.transform({ scale: 2, origin: [ 10, 10 ] }) + runner.transform({ scale: 2, origin: [10, 10] }) // transform sets its to-target to the morpher in the initialisation step // because it depends on the from-target. Declaritive animation run the init-step // on every frame. That is why we step here to see the effect of our retargeting runner.step(25) - expect(runner._history.transform.morpher.to()).toEqual( - [ 2, 2, 0, 0, 0, 0, 10, 10 ] - ) + expect(runner._history.transform.morpher.to()).toEqual([ + 2, 2, 0, 0, 0, 0, 10, 10 + ]) }) it('steps multiple relative animations correctly', () => { @@ -1433,9 +1569,7 @@ describe('Runner.js', () => { expect(runner1._queue.length).toBe(0) // The origin is transformed with every - expect(element.matrix()).toEqual( - new Matrix().scale(1.5).rotate(22.5) - ) + expect(element.matrix()).toEqual(new Matrix().scale(1.5).rotate(22.5)) }) it('correctly animates matrices directly', () => { @@ -1456,16 +1590,16 @@ describe('Runner.js', () => { it('correctly animates matrices affine', () => { const element = new Rect() const runner = new Runner(100).ease('-').element(element) - runner.transform(Object.assign({ affine: true }, new Matrix({ rotate: 90 }))) + runner.transform( + Object.assign({ affine: true }, new Matrix({ rotate: 90 })) + ) runner.step(50) // transform sets an immediate callback to apply all merged transforms // when every runner had the chance to add its bit of transforms jasmine.RequestAnimationFrame.tick(1) // The origin is transformed with every - expect(element.matrix()).toEqual( - new Matrix({ rotate: 45 }) - ) + expect(element.matrix()).toEqual(new Matrix({ rotate: 45 })) }) it('correctly animates matrices affine by passing third parameter', () => { @@ -1478,9 +1612,7 @@ describe('Runner.js', () => { jasmine.RequestAnimationFrame.tick(1) // The origin is transformed with every - expect(element.matrix()).toEqual( - new Matrix({ rotate: 45 }) - ) + expect(element.matrix()).toEqual(new Matrix({ rotate: 45 })) }) it('correctly animates a declarative relative rotation', () => { @@ -1563,8 +1695,8 @@ describe('Runner.js', () => { runner._queueNumberDelta('x', 10) runner.step(50) expect(runner._history.x.morpher.type()).toEqual(SVGNumber) - expect(runner._history.x.morpher.from()).toEqual([ 10, '' ]) - expect(runner._history.x.morpher.to()).toEqual([ 20, '' ]) + expect(runner._history.x.morpher.from()).toEqual([10, '']) + expect(runner._history.x.morpher.to()).toEqual([20, '']) expect(element.x()).toBe(15) }) @@ -1576,7 +1708,7 @@ describe('Runner.js', () => { runner.step(25) runner._queueNumberDelta('x', 20) - expect(runner._history.x.morpher.to()).toEqual([ 30, '' ]) + expect(runner._history.x.morpher.to()).toEqual([30, '']) runner.step(25) expect(element.x()).toBe(20) @@ -1590,8 +1722,8 @@ describe('Runner.js', () => { runner._queueObject('x', new SVGNumber(20)) runner.step(50) expect(runner._history.x.morpher.type()).toEqual(SVGNumber) - expect(runner._history.x.morpher.from()).toEqual([ 10, '' ]) - expect(runner._history.x.morpher.to()).toEqual([ 20, '' ]) + expect(runner._history.x.morpher.from()).toEqual([10, '']) + expect(runner._history.x.morpher.to()).toEqual([20, '']) expect(element.x()).toBe(15) }) @@ -1719,25 +1851,25 @@ describe('Runner.js', () => { describe('plot()', () => { it('queues a morphable array', () => { - const element = new Polygon().plot([ 10, 10, 20, 20 ]) + const element = new Polygon().plot([10, 10, 20, 20]) const runner = new Runner(100).ease('-').element(element) runner.plot(20, 20, 30, 30) runner.step(50) - expect(runner._history.plot.morpher.from()).toEqual([ 10, 10, 20, 20 ]) - expect(runner._history.plot.morpher.to()).toEqual([ 20, 20, 30, 30 ]) - expect(element.array()).toEqual(new PointArray([ 15, 15, 25, 25 ])) + expect(runner._history.plot.morpher.from()).toEqual([10, 10, 20, 20]) + expect(runner._history.plot.morpher.to()).toEqual([20, 20, 30, 30]) + expect(element.array()).toEqual(new PointArray([15, 15, 25, 25])) }) it('retargets correctly', () => { - const element = new Polygon().plot([ 10, 10, 20, 20 ]) + const element = new Polygon().plot([10, 10, 20, 20]) const runner = new Runner(100).ease('-').element(element) runner.plot(20, 20, 30, 30) runner.step(25) runner.plot(30, 30, 40, 40) runner.step(25) - expect(runner._history.plot.morpher.from()).toEqual([ 10, 10, 20, 20 ]) - expect(runner._history.plot.morpher.to()).toEqual([ 30, 30, 40, 40 ]) - expect(element.array()).toEqual(new PointArray([ 20, 20, 30, 30 ])) + expect(runner._history.plot.morpher.from()).toEqual([10, 10, 20, 20]) + expect(runner._history.plot.morpher.to()).toEqual([30, 30, 40, 40]) + expect(element.array()).toEqual(new PointArray([20, 20, 30, 30])) }) }) @@ -1755,7 +1887,10 @@ describe('Runner.js', () => { const runner = new Runner() const spy = spyOn(runner, '_queueObject') runner.viewbox(10, 10, 100, 100) - expect(spy).toHaveBeenCalledWith('viewbox', equal(new Box(10, 10, 100, 100))) + expect(spy).toHaveBeenCalledWith( + 'viewbox', + equal(new Box(10, 10, 100, 100)) + ) }) }) @@ -1785,10 +1920,12 @@ describe('Runner.js', () => { describe('mergeWith()', () => { it('merges the transformations of a runner with another and returns a FakeRunner', () => { const fake = new FakeRunner() - const runner = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner = new Runner().addTransform({ translate: [10, 20] }) const newRunner = fake.mergeWith(runner) expect(newRunner).toEqual(any(FakeRunner)) - expect(newRunner.transforms).toEqual(new Matrix({ translate: [ 10, 20 ] })) + expect(newRunner.transforms).toEqual( + new Matrix({ translate: [10, 20] }) + ) }) }) }) @@ -1832,9 +1969,9 @@ describe('Runner.js', () => { describe('merge()', () => { it('merges all runners which are done', () => { - const runner1 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner1 = new Runner().addTransform({ translate: [10, 20] }) const runner2 = new Runner().addTransform({ rotate: 45 }) - const runner3 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner3 = new Runner().addTransform({ translate: [10, 20] }) const arr = new RunnerArray() arr.add(runner1).add(runner2).add(runner3) runner1.done = true @@ -1843,17 +1980,15 @@ describe('Runner.js', () => { arr.merge() expect(arr.runners[0]).toEqual(any(FakeRunner)) expect(arr.runners[0].transforms).toEqual( - new Matrix({ translate: [ 10, 20 ] }) - .rotate(45) - .translate(10, 20) + new Matrix({ translate: [10, 20] }).rotate(45).translate(10, 20) ) }) it('skips runners which are not done', () => { - const runner1 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner1 = new Runner().addTransform({ translate: [10, 20] }) const runner2 = new Runner().addTransform({ rotate: 45 }) const runner3 = new Runner().addTransform({ rotate: 45 }) - const runner4 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner4 = new Runner().addTransform({ translate: [10, 20] }) const runner5 = new Runner().addTransform({ rotate: 45 }) const arr = new RunnerArray() arr.add(runner1).add(runner2).add(runner3).add(runner4).add(runner5) @@ -1865,24 +2000,22 @@ describe('Runner.js', () => { arr.merge() expect(arr.runners[0]).toEqual(any(FakeRunner)) expect(arr.runners[0].transforms).toEqual( - new Matrix({ translate: [ 10, 20 ] }) - .rotate(45) + new Matrix({ translate: [10, 20] }).rotate(45) ) expect(arr.runners[2]).toEqual(any(FakeRunner)) expect(arr.runners[2].transforms).toEqual( - new Matrix({ translate: [ 10, 20 ] }) - .rotate(45) + new Matrix({ translate: [10, 20] }).rotate(45) ) expect(arr.runners[1]).toBe(runner3) }) it('skips runners which have a timeline and are scheduled on that timeline', () => { - const runner1 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner1 = new Runner().addTransform({ translate: [10, 20] }) const runner2 = new Runner().addTransform({ rotate: 45 }) const runner3 = new Runner().addTransform({ rotate: 45 }) - const runner4 = new Runner().addTransform({ translate: [ 10, 20 ] }) + const runner4 = new Runner().addTransform({ translate: [10, 20] }) const runner5 = new Runner().addTransform({ rotate: 45 }) const arr = new RunnerArray() arr.add(runner1).add(runner2).add(runner3).add(runner4).add(runner5) @@ -1896,14 +2029,12 @@ describe('Runner.js', () => { arr.merge() expect(arr.runners[0]).toEqual(any(FakeRunner)) expect(arr.runners[0].transforms).toEqual( - new Matrix({ translate: [ 10, 20 ] }) - .rotate(45) + new Matrix({ translate: [10, 20] }).rotate(45) ) expect(arr.runners[2]).toEqual(any(FakeRunner)) expect(arr.runners[2].transforms).toEqual( - new Matrix({ translate: [ 10, 20 ] }) - .rotate(45) + new Matrix({ translate: [10, 20] }).rotate(45) ) expect(arr.runners[1]).toBe(runner3) @@ -1940,7 +2071,12 @@ describe('Runner.js', () => { arr.add(runner1).add(runner2).add(runner3).add(runner4).add(runner5) arr.clearBefore(runner3.id) expect(arr.length()).toBe(4) - expect(arr.runners).toEqual([ any(FakeRunner), runner3, runner4, runner5 ]) + expect(arr.runners).toEqual([ + any(FakeRunner), + runner3, + runner4, + runner5 + ]) }) }) }) diff --git a/spec/spec/animation/Timeline.js b/spec/spec/animation/Timeline.js index 5f511ff..cbb40f8 100644 --- a/spec/spec/animation/Timeline.js +++ b/spec/spec/animation/Timeline.js @@ -1,6 +1,13 @@ /* globals describe, expect, it, beforeEach, afterEach, spyOn, container, jasmine */ -import { Timeline, SVG, Runner, Animator, Queue, Rect } from '../../../src/main.js' +import { + Timeline, + SVG, + Runner, + Animator, + Queue, + Rect +} from '../../../src/main.js' import { getWindow } from '../../../src/utils/window.js' const { createSpy, any } = jasmine @@ -127,7 +134,9 @@ describe('Timeline.js', () => { it('throws if when is not supported', () => { const timeline = new Timeline().schedule(new Runner(1000), 1000) const runner = new Runner(1000) - expect(() => timeline.schedule(runner, 0, 'not supported')).toThrowError('Invalid value for the "when" parameter') + expect(() => timeline.schedule(runner, 0, 'not supported')).toThrowError( + 'Invalid value for the "when" parameter' + ) }) it('uses persist value of the runner of present', () => { @@ -152,7 +161,9 @@ describe('Timeline.js', () => { it('gets a runner by its id from the timeline', () => { const timeline = new Timeline() const runner = new Runner(1000) - expect(timeline.schedule(runner).getRunnerInfoById(runner.id).runner).toBe(runner) + expect( + timeline.schedule(runner).getRunnerInfoById(runner.id).runner + ).toBe(runner) }) it('returns null of runner not found', () => { @@ -460,7 +471,10 @@ describe('Timeline.js', () => { it('continues if there are still runners left from us when going back in time', () => { const spy = createSpy() - const timeline = new Timeline().on('finished', spy).time(1200).reverse(true) + const timeline = new Timeline() + .on('finished', spy) + .time(1200) + .reverse(true) const runner = new Runner(1000) spy.calls.reset() timeline.schedule(runner, 0).play() // we have to play because its synchronous here diff --git a/spec/spec/elements/A.js b/spec/spec/elements/A.js index 854204e..5fcbe87 100644 --- a/spec/spec/elements/A.js +++ b/spec/spec/elements/A.js @@ -6,7 +6,6 @@ const { any } = jasmine const url = 'https://svgjs.dev' describe('A.js', () => { - describe('()', () => { it('creates a new object of type A', () => { expect(new A()).toEqual(any(A)) @@ -81,7 +80,7 @@ describe('A.js', () => { expect(link.parent()).toBe(null) }) - it('removes also the link when link wasn\'t in document', () => { + it("removes also the link when link wasn't in document", () => { const link = new A().to(url) const rect = link.rect(100, 100) @@ -116,5 +115,4 @@ describe('A.js', () => { }) }) }) - }) diff --git a/spec/spec/elements/ClipPath.js b/spec/spec/elements/ClipPath.js index 1effe6d..5061a10 100644 --- a/spec/spec/elements/ClipPath.js +++ b/spec/spec/elements/ClipPath.js @@ -37,7 +37,7 @@ describe('ClipPath.js', () => { const canvas = SVG().addTo(container) const clip = canvas.clip() const rect = canvas.rect(100, 100).clipWith(clip) - expect(clip.targets()).toEqual([ rect ]) + expect(clip.targets()).toEqual([rect]) }) }) @@ -47,7 +47,7 @@ describe('ClipPath.js', () => { const canvas = SVG() const clip = canvas.clip() expect(clip).toEqual(any(ClipPath)) - expect(canvas.defs().children()).toEqual([ clip ]) + expect(canvas.defs().children()).toEqual([clip]) }) }) }) diff --git a/spec/spec/elements/Container.js b/spec/spec/elements/Container.js index 5d53eb1..f9741ed 100644 --- a/spec/spec/elements/Container.js +++ b/spec/spec/elements/Container.js @@ -61,7 +61,16 @@ describe('Container.js', () => { it('flattens the whole document when called on the root', () => { canvas.flatten() - expect(canvas.children()).toEqual([ rect1, rect2, circle1, circle2, line1, line2, circle3, rect3 ]) + expect(canvas.children()).toEqual([ + rect1, + rect2, + circle1, + circle2, + line1, + line2, + circle3, + rect3 + ]) }) it('flattens a group and places all children into its parent when called on a group - 1', () => { @@ -81,8 +90,15 @@ describe('Container.js', () => { rect3 */ - expect(canvas.children()).toEqual([ rect1, group1, group4 ]) - expect(group1.children()).toEqual([ rect2, circle1, circle2, line1, line2, circle3 ]) + expect(canvas.children()).toEqual([rect1, group1, group4]) + expect(group1.children()).toEqual([ + rect2, + circle1, + circle2, + line1, + line2, + circle3 + ]) }) it('flattens a group and places all children into its parent when called on a group - 2', () => { @@ -103,7 +119,7 @@ describe('Container.js', () => { rect3 */ - expect(group2.children()).toEqual([ circle2, line1, line2, circle3 ]) + expect(group2.children()).toEqual([circle2, line1, line2, circle3]) }) }) @@ -111,21 +127,27 @@ describe('Container.js', () => { it('ungroups a group and inserts all children in the correct order in the parent parent of the group', () => { group1.ungroup() - expect(canvas.children()).toEqual([ rect1, rect2, circle1, group2, group4 ]) + expect(canvas.children()).toEqual([rect1, rect2, circle1, group2, group4]) group4.ungroup() - expect(canvas.children()).toEqual([ rect1, rect2, circle1, group2, rect3 ]) + expect(canvas.children()).toEqual([rect1, rect2, circle1, group2, rect3]) }) it('ungroups a group into another group and appends the elements to the other group', () => { group1.ungroup(group4) - expect(group4.children()).toEqual([ rect3, rect2, circle1, group2 ]) + expect(group4.children()).toEqual([rect3, rect2, circle1, group2]) }) it('ungroups a group into another group at the specified position', () => { group2.ungroup(group1, 1) - expect(group1.children()).toEqual([ rect2, circle2, group3, circle3, circle1 ]) + expect(group1.children()).toEqual([ + rect2, + circle2, + group3, + circle3, + circle1 + ]) }) }) }) diff --git a/spec/spec/elements/Dom.js b/spec/spec/elements/Dom.js index e33883d..3325d93 100644 --- a/spec/spec/elements/Dom.js +++ b/spec/spec/elements/Dom.js @@ -1,12 +1,22 @@ /* globals describe, expect, it, beforeEach, spyOn, jasmine, container */ -import { SVG, G, Rect, Svg, Dom, List, Fragment, Circle, Tspan, create } from '../../../src/main.js' +import { + SVG, + G, + Rect, + Svg, + Dom, + List, + Fragment, + Circle, + Tspan, + create +} from '../../../src/main.js' import { getWindow } from '../../../src/utils/window.js' import { svg, html } from '../../../src/modules/core/namespaces.js' const { any, createSpy, objectContaining } = jasmine describe('Dom.js', function () { - describe('()', () => { it('creates a new object of type Dom', () => { const rect = new Rect() @@ -119,7 +129,7 @@ describe('Dom.js', function () { const rect = g.rect(100, 100) const circle = g.circle(100, 100) const children = g.children() - expect(children).toEqual([ rect, circle ]) + expect(children).toEqual([rect, circle]) expect(children).toEqual(any(List)) }) }) @@ -197,8 +207,8 @@ describe('Dom.js', function () { group.each(spy) expect(spy.calls.all()).toEqual([ - objectContaining({ object: group2, args: [ 0, [ group2, circle ] ] }), - objectContaining({ object: circle, args: [ 1, [ group2, circle ] ] }) + objectContaining({ object: group2, args: [0, [group2, circle]] }), + objectContaining({ object: circle, args: [1, [group2, circle]] }) ]) }) @@ -211,9 +221,9 @@ describe('Dom.js', function () { group.each(spy, true) expect(spy.calls.all()).toEqual([ - objectContaining({ object: group2, args: [ 0, [ group2, circle ] ] }), - objectContaining({ object: rect, args: [ 0, [ rect ] ] }), - objectContaining({ object: circle, args: [ 1, [ group2, circle ] ] }) + objectContaining({ object: group2, args: [0, [group2, circle]] }), + objectContaining({ object: rect, args: [0, [rect]] }), + objectContaining({ object: circle, args: [1, [group2, circle]] }) ]) }) }) @@ -277,7 +287,7 @@ describe('Dom.js', function () { expect(g.has(rect)).toBe(true) }) - it('returns false if the element hasn\'t the passed element as child', () => { + it("returns false if the element hasn't the passed element as child", () => { const g = new G() const rect = new Rect() expect(g.has(rect)).toBe(false) @@ -437,7 +447,7 @@ describe('Dom.js', function () { const rect = new Rect() const ret = rect.putIn(g) expect(ret).toEqual(any(G)) - expect(ret.children()).toEqual([ rect ]) + expect(ret.children()).toEqual([rect]) }) it('works with a query selector', () => { @@ -446,7 +456,7 @@ describe('Dom.js', function () { const rect = canvas.rect(100, 100) const ret = rect.putIn('.test') expect(ret).toBe(g) - expect(g.children()).toEqual([ rect ]) + expect(g.children()).toEqual([rect]) }) }) @@ -460,7 +470,7 @@ describe('Dom.js', function () { it('removes the element from the parent', () => { const canvas = SVG().addTo(container) const rect = canvas.rect(100, 100) - expect(canvas.children()).toEqual([ rect ]) + expect(canvas.children()).toEqual([rect]) rect.remove() expect(canvas.children()).toEqual([]) }) @@ -473,7 +483,7 @@ describe('Dom.js', function () { it('also works when direct child of document-fragment', () => { const fragment = new Fragment() const rect = fragment.rect(100, 100) - expect(fragment.children()).toEqual([ rect ]) + expect(fragment.children()).toEqual([rect]) expect(rect.remove()).toBe(rect) expect(fragment.children()).toEqual([]) }) @@ -518,7 +528,7 @@ describe('Dom.js', function () { const rect3 = g.rect(100, 100) const circle = new Circle() rect2.replace(circle) - expect(g.children()).toEqual([ rect1, circle, rect3 ]) + expect(g.children()).toEqual([rect1, circle, rect3]) }) it('also works without a parent', () => { @@ -531,17 +541,32 @@ describe('Dom.js', function () { describe('round()', () => { it('rounds all attributes whose values are numbers to two decimals by default', () => { const rect = new Rect({ id: 'foo', x: 10.678, y: 3, width: 123.456 }) - expect(rect.round().attr()).toEqual({ id: 'foo', x: 10.68, y: 3, width: 123.46 }) + expect(rect.round().attr()).toEqual({ + id: 'foo', + x: 10.68, + y: 3, + width: 123.46 + }) }) it('rounds all attributes whose values are numbers to the passed precision', () => { const rect = new Rect({ id: 'foo', x: 10.678, y: 3, width: 123.456 }) - expect(rect.round(1).attr()).toEqual({ id: 'foo', x: 10.7, y: 3, width: 123.5 }) + expect(rect.round(1).attr()).toEqual({ + id: 'foo', + x: 10.7, + y: 3, + width: 123.5 + }) }) it('rounds the given attributes whose values are numbers to the passed precision', () => { const rect = new Rect({ id: 'foo', x: 10.678, y: 3, width: 123.456 }) - expect(rect.round(1, [ 'id', 'x' ]).attr()).toEqual({ id: 'foo', x: 10.7, y: 3, width: 123.456 }) + expect(rect.round(1, ['id', 'x']).attr()).toEqual({ + id: 'foo', + x: 10.7, + y: 3, + width: 123.456 + }) }) }) @@ -632,9 +657,9 @@ describe('Dom.js', function () { }) }) - describe('writeDataToDom()', () => { - // not really testable - }) + // describe('writeDataToDom()', () => { + // // not really testable + // }) describe('xml()', () => { describe('as setter', () => { @@ -645,27 +670,27 @@ describe('Dom.js', function () { it('imports a single element', () => { const g = new G().xml('<rect />', undefined, svg) - expect(g.children()).toEqual([ any(Rect) ]) + expect(g.children()).toEqual([any(Rect)]) expect(g.children()[0].node.namespaceURI).toBe(svg) }) it('imports multiple elements', () => { const g = new G().xml('<rect /><circle />', undefined, svg) - expect(g.children()).toEqual([ any(Rect), any(Circle) ]) + expect(g.children()).toEqual([any(Rect), any(Circle)]) }) it('replaces the current element with the imported elements with outerHtml = true', () => { const canvas = new Svg() const g = canvas.group() g.xml('<rect /><circle />', true, svg) - expect(canvas.children()).toEqual([ any(Rect), any(Circle) ]) + expect(canvas.children()).toEqual([any(Rect), any(Circle)]) }) it('returns the parent when outerHtml = true', () => { const canvas = new Svg() const g = canvas.group() expect(g.xml('<rect /><circle />', true, svg)).toBe(canvas) - expect(canvas.children()).toEqual([ any(Rect), any(Circle) ]) + expect(canvas.children()).toEqual([any(Rect), any(Circle)]) }) it('works without a parent', () => { @@ -684,46 +709,58 @@ describe('Dom.js', function () { }) it('returns the svg string of the element by default', () => { - expect(rect.xml(), svg).toBe('<rect width="123.456" height="234.567"></rect>') - expect(canvas.xml(), svg).toBe('<svg><g><rect width="123.456" height="234.567"></rect></g></svg>') + expect(rect.xml(), svg).toBe( + '<rect width="123.456" height="234.567"></rect>' + ) + expect(canvas.xml(), svg).toBe( + '<svg><g><rect width="123.456" height="234.567"></rect></g></svg>' + ) }) it('returns the innerHtml when outerHtml = false', () => { expect(rect.xml(false, svg)).toBe('') - expect(canvas.xml(false, svg)).toBe('<g><rect width="123.456" height="234.567"></rect></g>') + expect(canvas.xml(false, svg)).toBe( + '<g><rect width="123.456" height="234.567"></rect></g>' + ) }) it('runs a function on every exported node', () => { - expect(rect.xml((el) => el.round(1))).toBe('<rect width="123.5" height="234.6"></rect>') + expect(rect.xml((el) => el.round(1))).toBe( + '<rect width="123.5" height="234.6"></rect>' + ) }) it('runs a function on every exported node and replaces node with returned node if return value is not falsy', () => { - expect(rect.xml((el) => new Circle(), svg)).toBe('<circle></circle>') - expect(canvas.xml((el) => new G(), svg)).toBe('<g></g>') // outer <svg> was replaced by an empty g - expect(canvas.xml((el) => { - if (el instanceof Rect) return new Circle() - if (el instanceof Svg) el.removeNamespace() - }, svg)).toBe('<svg><g><circle></circle></g></svg>') + expect(rect.xml(() => new Circle(), svg)).toBe('<circle></circle>') + expect(canvas.xml(() => new G(), svg)).toBe('<g></g>') // outer <svg> was replaced by an empty g + expect( + canvas.xml((el) => { + if (el instanceof Rect) return new Circle() + if (el instanceof Svg) el.removeNamespace() + }, svg) + ).toBe('<svg><g><circle></circle></g></svg>') }) it('runs a function on every exported node and removes node if return value is false', () => { expect(group.xml(() => false, svg)).toBe('') expect(canvas.xml(() => false, svg)).toBe('') - expect(canvas.xml((el) => { - if (el instanceof Svg) { - el.removeNamespace() - } else { - return false - } - }, svg)).toBe('<svg></svg>') + expect( + canvas.xml((el) => { + if (el instanceof Svg) { + el.removeNamespace() + } else { + return false + } + }, svg) + ).toBe('<svg></svg>') }) it('runs a function on every inner node and exports it when outerHtml = false', () => { expect(canvas.xml(() => false, false, svg)).toBe('') - expect(canvas.xml(() => undefined, false, svg)).toBe('<g><rect width="123.456" height="234.567"></rect></g>') + expect(canvas.xml(() => undefined, false, svg)).toBe( + '<g><rect width="123.456" height="234.567"></rect></g>' + ) }) - }) - }) }) diff --git a/spec/spec/elements/Element.js b/spec/spec/elements/Element.js index 70c3a52..53c5028 100644 --- a/spec/spec/elements/Element.js +++ b/spec/spec/elements/Element.js @@ -171,10 +171,10 @@ describe('Element.js', function () { const group3 = group2.group() const rect = group3.rect(100, 100) - expect(rect.parents('.test')).toEqual([ group3, group2, group1 ]) - expect(rect.parents(group2)).toEqual([ group3, group2 ]) + expect(rect.parents('.test')).toEqual([group3, group2, group1]) + expect(rect.parents(group2)).toEqual([group3, group2]) expect(rect.parents(group1).length).toBe(3) - expect(rect.parents()).toEqual([ group3, group2, group1, canvas ]) + expect(rect.parents()).toEqual([group3, group2, group1, canvas]) }) it('returns array of parents until the closest matching parent', () => { @@ -185,9 +185,9 @@ describe('Element.js', function () { const group3 = group2.group().addClass('foo') const rect = group3.rect(100, 100) - expect(rect.parents('.test')).toEqual([ group3, group2 ]) - expect(rect.parents('.foo')).toEqual([ group3 ]) - expect(rect.parents('.test:not(.foo)')).toEqual([ group3, group2, group1 ]) + expect(rect.parents('.test')).toEqual([group3, group2]) + expect(rect.parents('.foo')).toEqual([group3]) + expect(rect.parents('.test:not(.foo)')).toEqual([group3, group2, group1]) }) it('returns null if the passed element is not an ancestor', () => { @@ -198,7 +198,6 @@ describe('Element.js', function () { const group3 = group2.group() const rect = group3.rect(100, 100) - expect(rect.parents('.does-not-exist')).toEqual(null) expect(rect.parents('.test')).toEqual(null) expect(rect.parents(groupA)).toEqual(null) @@ -274,7 +273,9 @@ describe('Element.js', function () { it('writes data from the dom property into the dom', () => { element.dom = { foo: 'bar' } element.writeDataToDom() - expect(element.node.getAttribute('svgjs:data')).toBe(JSON.stringify({ foo: 'bar' })) + expect(element.node.getAttribute('svgjs:data')).toBe( + JSON.stringify({ foo: 'bar' }) + ) }) it('recursively calls writeDataToDom on all children', () => { diff --git a/spec/spec/elements/ForeignObject.js b/spec/spec/elements/ForeignObject.js index 14e9e00..0040d04 100644 --- a/spec/spec/elements/ForeignObject.js +++ b/spec/spec/elements/ForeignObject.js @@ -5,7 +5,6 @@ import { makeInstance, ForeignObject } from '../../../src/main.js' const { any } = jasmine describe('ForeignObject.js', () => { - describe('()', () => { it('creates a new object of type ForeignObject', () => { expect(new ForeignObject()).toEqual(any(ForeignObject)) diff --git a/spec/spec/elements/Fragment.js b/spec/spec/elements/Fragment.js index 8e6503d..dfac3d0 100644 --- a/spec/spec/elements/Fragment.js +++ b/spec/spec/elements/Fragment.js @@ -7,7 +7,6 @@ import { svg } from '../../../src/modules/core/namespaces.js' const { any } = jasmine describe('Fragment.js', () => { - describe('()', () => { it('creates a new object of type Fragment', () => { expect(new Fragment()).toEqual(any(Fragment)) @@ -22,7 +21,7 @@ describe('Fragment.js', () => { const frag = new Fragment() const rect = frag.rect(100, 100) - expect(frag.children()).toEqual([ rect ]) + expect(frag.children()).toEqual([rect]) }) }) @@ -43,7 +42,9 @@ describe('Fragment.js', () => { group.rect(123.456, 234.567) const spy = spyOn(Dom.prototype, 'xml').and.callThrough() - expect(frag.xml(false, svg)).toBe('<g><rect width="123.456" height="234.567"></rect></g>') + expect(frag.xml(false, svg)).toBe( + '<g><rect width="123.456" height="234.567"></rect></g>' + ) expect(spy).toHaveBeenCalledWith(false, svg) }) @@ -53,10 +54,11 @@ describe('Fragment.js', () => { group.rect(123.456, 234.567) const spy = spyOn(Dom.prototype, 'xml').and.callThrough() - expect(frag.xml(true, svg)).toBe('<g><rect width="123.456" height="234.567"></rect></g>') + expect(frag.xml(true, svg)).toBe( + '<g><rect width="123.456" height="234.567"></rect></g>' + ) expect(spy).toHaveBeenCalledWith(false, svg) }) }) - }) }) diff --git a/spec/spec/elements/G.js b/spec/spec/elements/G.js index 58dc07d..b46e232 100644 --- a/spec/spec/elements/G.js +++ b/spec/spec/elements/G.js @@ -5,7 +5,6 @@ import { G, SVG } from '../../../src/main.js' const { any } = jasmine describe('G.js', () => { - describe('()', () => { it('creates a new object of type G', () => { expect(new G()).toEqual(any(G)) diff --git a/spec/spec/elements/Gradient.js b/spec/spec/elements/Gradient.js index 76c36ce..41b896e 100644 --- a/spec/spec/elements/Gradient.js +++ b/spec/spec/elements/Gradient.js @@ -46,7 +46,7 @@ describe('Gradient.js', () => { const canvas = SVG().addTo(container) const gradient = canvas.gradient('linear') const rect = canvas.rect(100, 100).fill(gradient) - expect(gradient.targets()).toEqual([ rect ]) + expect(gradient.targets()).toEqual([rect]) }) }) @@ -69,7 +69,7 @@ describe('Gradient.js', () => { const spy = createSpy('gradient') gradient.update(spy) expect(spy.calls.all()).toEqual([ - objectContaining({ object: gradient, args: [ gradient ] }) + objectContaining({ object: gradient, args: [gradient] }) ]) }) }) @@ -102,7 +102,7 @@ describe('Gradient.js', () => { const gradient = defs.gradient('linear', spy) expect(gradient).toEqual(any(Gradient)) expect(gradient.type).toBe('linearGradient') - expect(defs.children()).toEqual([ gradient ]) + expect(defs.children()).toEqual([gradient]) expect(spy).toHaveBeenCalled() }) }) diff --git a/spec/spec/elements/Image.js b/spec/spec/elements/Image.js index c7b91d2..2e92e13 100644 --- a/spec/spec/elements/Image.js +++ b/spec/spec/elements/Image.js @@ -7,7 +7,6 @@ const { any, objectContaining, createSpy } = jasmine const url = 'spec/fixtures/pixel.png' describe('Image.js', () => { - describe('()', () => { it('creates a new object of type Image', () => { expect(new Image()).toEqual(any(Image)) @@ -28,7 +27,7 @@ describe('Image.js', () => { const spy = createSpy('image', (e) => { expect(e.target.complete).toBe(true) expect(spy.calls.all()).toEqual([ - objectContaining({ object: image, args: [ any(getWindow().Event) ] }) + objectContaining({ object: image, args: [any(getWindow().Event)] }) ]) done() }).and.callThrough() @@ -53,29 +52,37 @@ describe('Image.js', () => { }) it('should not change with and height when size already set', (done) => { - const image = new Image().load(url, () => { - expect(image.attr('height')).toBe(100) - expect(image.attr('width')).toBe(100) - done() - }).size(100, 100) + const image = new Image() + .load(url, () => { + expect(image.attr('height')).toBe(100) + expect(image.attr('width')).toBe(100) + done() + }) + .size(100, 100) }) it('changes size of pattern to image size if parent is pattern and size is 0', (done) => { const pattern = new Pattern().size(0, 0) - new Image().load(url, () => { - expect(pattern.attr('height')).toBe(100) - expect(pattern.attr('width')).toBe(100) - done() - }).size(100, 100).addTo(pattern) + new Image() + .load(url, () => { + expect(pattern.attr('height')).toBe(100) + expect(pattern.attr('width')).toBe(100) + done() + }) + .size(100, 100) + .addTo(pattern) }) it('does not change size of pattern if pattern has a size set', (done) => { const pattern = new Pattern().size(50, 50) - new Image().load(url, () => { - expect(pattern.attr('height')).toBe(50) - expect(pattern.attr('width')).toBe(50) - done() - }).size(100, 100).addTo(pattern) + new Image() + .load(url, () => { + expect(pattern.attr('height')).toBe(50) + expect(pattern.attr('width')).toBe(50) + done() + }) + .size(100, 100) + .addTo(pattern) }) }) @@ -85,7 +92,7 @@ describe('Image.js', () => { const canvas = SVG() const image = canvas.image(url) expect(image).toBe(image) - expect(canvas.children()).toEqual([ image ]) + expect(canvas.children()).toEqual([image]) }) }) }) @@ -95,21 +102,21 @@ describe('Image.js', () => { const canvas = SVG() const image = new Image() canvas.rect(100, 100).attr('something', image) - expect(canvas.defs().children()).toEqual([ any(Pattern) ]) + expect(canvas.defs().children()).toEqual([any(Pattern)]) expect(canvas.defs().findOne('image')).toBe(image) }) it('creates an image from image path in defs with pattern when attr is fill', () => { const canvas = SVG() canvas.rect(100, 100).attr('fill', url) - expect(canvas.defs().children()).toEqual([ any(Pattern) ]) + expect(canvas.defs().children()).toEqual([any(Pattern)]) expect(canvas.defs().findOne('image').attr('href')).toBe(url) }) it('creates an image from image path in defs with pattern when attr is stroke', () => { const canvas = SVG() canvas.rect(100, 100).attr('stroke', url) - expect(canvas.defs().children()).toEqual([ any(Pattern) ]) + expect(canvas.defs().children()).toEqual([any(Pattern)]) expect(canvas.defs().findOne('image').attr('href')).toBe(url) }) }) diff --git a/spec/spec/elements/Line.js b/spec/spec/elements/Line.js index 9f25937..48a02bf 100644 --- a/spec/spec/elements/Line.js +++ b/spec/spec/elements/Line.js @@ -25,7 +25,10 @@ describe('Line.js', () => { it('returns a PointArray containing the points of the line', () => { const array = line.plot(1, 2, 3, 4).array() expect(array).toEqual(any(PointArray)) - expect(array).toEqual([ [ 1, 2 ], [ 3, 4 ] ]) + expect(array).toEqual([ + [1, 2], + [3, 4] + ]) }) }) @@ -38,9 +41,14 @@ describe('Line.js', () => { const canvas = SVG().addTo(container) const line = canvas.line(1, 2, 3, 4) line.move(50, 50) - expect(line.bbox()).toEqual(objectContaining({ - x: 50, y: 50, width: 2, height: 2 - })) + expect(line.bbox()).toEqual( + objectContaining({ + x: 50, + y: 50, + width: 2, + height: 2 + }) + ) }) }) @@ -65,19 +73,27 @@ describe('Line.js', () => { it('calls attr with line attributes when array given', () => { const spy = spyOn(line, 'attr') - line.plot([ 1, 2, 3, 4 ]) + line.plot([1, 2, 3, 4]) expect(spy).toHaveBeenCalledWith({ x1: 1, y1: 2, x2: 3, y2: 4 }) }) it('calls attr with line attributes when multi array given', () => { const spy = spyOn(line, 'attr') - line.plot([ [ 1, 2 ], [ 3, 4 ] ]) + line.plot([ + [1, 2], + [3, 4] + ]) expect(spy).toHaveBeenCalledWith({ x1: 1, y1: 2, x2: 3, y2: 4 }) }) it('calls attr with line attributes when PointArray given', () => { const spy = spyOn(line, 'attr') - line.plot(new PointArray([ [ 1, 2 ], [ 3, 4 ] ])) + line.plot( + new PointArray([ + [1, 2], + [3, 4] + ]) + ) expect(spy).toHaveBeenCalledWith({ x1: 1, y1: 2, x2: 3, y2: 4 }) }) }) @@ -91,27 +107,42 @@ describe('Line.js', () => { const canvas = SVG().addTo(container) const line = canvas.line(1, 2, 3, 4) line.size(50, 50) - expect(line.bbox()).toEqual(objectContaining({ - width: 50, height: 50, x: 1, y: 2 - })) + expect(line.bbox()).toEqual( + objectContaining({ + width: 50, + height: 50, + x: 1, + y: 2 + }) + ) }) it('changes height proportionally', () => { const canvas = SVG().addTo(container) const line = canvas.line(1, 2, 3, 4) line.size(50, null) - expect(line.bbox()).toEqual(objectContaining({ - width: 50, height: 50, x: 1, y: 2 - })) + expect(line.bbox()).toEqual( + objectContaining({ + width: 50, + height: 50, + x: 1, + y: 2 + }) + ) }) it('changes width proportionally', () => { const canvas = SVG().addTo(container) const line = canvas.line(1, 2, 3, 4) line.size(null, 50) - expect(line.bbox()).toEqual(objectContaining({ - width: 50, height: 50, x: 1, y: 2 - })) + expect(line.bbox()).toEqual( + objectContaining({ + width: 50, + height: 50, + x: 1, + y: 2 + }) + ) }) }) @@ -120,14 +151,20 @@ describe('Line.js', () => { it('creates a line with given points', () => { const group = new G() const line = group.line(1, 2, 3, 4) - expect(line.array()).toEqual([ [ 1, 2 ], [ 3, 4 ] ]) + expect(line.array()).toEqual([ + [1, 2], + [3, 4] + ]) expect(line).toEqual(any(Line)) }) it('defaults to zero line', () => { const group = new G() const line = group.line() - expect(line.array()).toEqual([ [ 0, 0 ], [ 0, 0 ] ]) + expect(line.array()).toEqual([ + [0, 0], + [0, 0] + ]) expect(line).toEqual(any(Line)) }) }) diff --git a/spec/spec/elements/Marker.js b/spec/spec/elements/Marker.js index 63e06fe..cddfc50 100644 --- a/spec/spec/elements/Marker.js +++ b/spec/spec/elements/Marker.js @@ -5,7 +5,6 @@ import { Marker, SVG, Defs } from '../../../src/main.js' const { any } = jasmine describe('Marker.js', function () { - describe('()', () => { it('creates a new object of type Marker', () => { expect(new Marker()).toEqual(any(Marker)) @@ -106,7 +105,7 @@ describe('Marker.js', function () { expect(marker.attr('viewBox')).toBe('0 0 10 12') expect(marker.attr('orient')).toBe('auto') expect(marker).toEqual(any(Marker)) - expect(defs.children()).toEqual([ marker ]) + expect(defs.children()).toEqual([marker]) }) }) }) @@ -117,7 +116,9 @@ describe('Marker.js', function () { beforeEach(() => { // because we use `reference` here we need to put it into the live dom canvas = new SVG().addTo(container) - path = canvas.path('M 100 200 C 200 100 300 0 400 100 C 500 200 600 300 700 200 C 800 100 900 100 900 100') + path = canvas.path( + 'M 100 200 C 200 100 300 0 400 100 C 500 200 600 300 700 200 C 800 100 900 100 900 100' + ) }) it('creates an instance of Marker', () => { @@ -172,7 +173,5 @@ describe('Marker.js', function () { expect(path.node.getAttribute('marker-mid')).toBe(marker.toString()) }) }) - }) - }) diff --git a/spec/spec/elements/Mask.js b/spec/spec/elements/Mask.js index 32e5d15..08a1aaa 100644 --- a/spec/spec/elements/Mask.js +++ b/spec/spec/elements/Mask.js @@ -5,7 +5,6 @@ import { Mask, SVG, Container, Rect } from '../../../src/main.js' const { any } = jasmine describe('Mask.js', () => { - describe('()', () => { it('creates a new object of type Mask', () => { expect(new Mask()).toEqual(any(Mask)) @@ -38,7 +37,7 @@ describe('Mask.js', () => { const canvas = SVG().addTo(container) const mask = canvas.mask() const rect = canvas.rect(100, 100).maskWith(mask) - expect(mask.targets()).toEqual([ rect ]) + expect(mask.targets()).toEqual([rect]) }) }) @@ -48,7 +47,7 @@ describe('Mask.js', () => { const canvas = SVG() const mask = canvas.mask() expect(mask).toEqual(any(Mask)) - expect(canvas.defs().children()).toEqual([ mask ]) + expect(canvas.defs().children()).toEqual([mask]) }) }) }) diff --git a/spec/spec/elements/Path.js b/spec/spec/elements/Path.js index d43857e..08105bc 100644 --- a/spec/spec/elements/Path.js +++ b/spec/spec/elements/Path.js @@ -25,7 +25,10 @@ describe('Path.js', () => { it('returns the underlying PathArray', () => { const array = path.plot('M1 2 3 4').array() expect(array).toEqual(any(PathArray)) - expect(array).toEqual([ [ 'M', 1, 2 ], [ 'L', 3, 4 ] ]) + expect(array).toEqual([ + ['M', 1, 2], + ['L', 3, 4] + ]) }) }) @@ -61,9 +64,14 @@ describe('Path.js', () => { const canvas = SVG().addTo(container) const path = canvas.path('M0 0 50, 50') path.move(50, 50) - expect(path.bbox()).toEqual(objectContaining({ - x: 50, y: 50, width: 50, height: 50 - })) + expect(path.bbox()).toEqual( + objectContaining({ + x: 50, + y: 50, + width: 50, + height: 50 + }) + ) }) }) @@ -82,20 +90,37 @@ describe('Path.js', () => { it('works with flat array', () => { const spy = spyOn(path, 'attr') - path.plot([ 'M', 0, 0, 'L', 50, 50 ]) - expect(spy).toHaveBeenCalledWith('d', [ [ 'M', 0, 0 ], [ 'L', 50, 50 ] ]) + path.plot(['M', 0, 0, 'L', 50, 50]) + expect(spy).toHaveBeenCalledWith('d', [ + ['M', 0, 0], + ['L', 50, 50] + ]) }) it('works with multi array', () => { const spy = spyOn(path, 'attr') - path.plot([ [ 'M', 0, 0 ], [ 'L', 50, 50 ] ]) - expect(spy).toHaveBeenCalledWith('d', [ [ 'M', 0, 0 ], [ 'L', 50, 50 ] ]) + path.plot([ + ['M', 0, 0], + ['L', 50, 50] + ]) + expect(spy).toHaveBeenCalledWith('d', [ + ['M', 0, 0], + ['L', 50, 50] + ]) }) it('works with PathArray', () => { const spy = spyOn(path, 'attr') - path.plot(new PathArray([ [ 'M', 0, 0 ], [ 'L', 50, 50 ] ])) - expect(spy).toHaveBeenCalledWith('d', [ [ 'M', 0, 0 ], [ 'L', 50, 50 ] ]) + path.plot( + new PathArray([ + ['M', 0, 0], + ['L', 50, 50] + ]) + ) + expect(spy).toHaveBeenCalledWith('d', [ + ['M', 0, 0], + ['L', 50, 50] + ]) }) }) @@ -108,27 +133,42 @@ describe('Path.js', () => { const canvas = SVG().addTo(container) const path = canvas.path('M0 0 50, 50') path.size(100, 100) - expect(path.bbox()).toEqual(objectContaining({ - width: 100, height: 100, x: 0, y: 0 - })) + expect(path.bbox()).toEqual( + objectContaining({ + width: 100, + height: 100, + x: 0, + y: 0 + }) + ) }) it('changes height proportionally', () => { const canvas = SVG().addTo(container) const path = canvas.path('M0 0 50, 50') path.size(100, null) - expect(path.bbox()).toEqual(objectContaining({ - width: 100, height: 100, x: 0, y: 0 - })) + expect(path.bbox()).toEqual( + objectContaining({ + width: 100, + height: 100, + x: 0, + y: 0 + }) + ) }) it('changes width proportionally', () => { const canvas = SVG().addTo(container) const path = canvas.path('M0 0 50, 50') path.size(null, 100) - expect(path.bbox()).toEqual(objectContaining({ - width: 100, height: 100, x: 0, y: 0 - })) + expect(path.bbox()).toEqual( + objectContaining({ + width: 100, + height: 100, + x: 0, + y: 0 + }) + ) }) }) diff --git a/spec/spec/elements/Pattern.js b/spec/spec/elements/Pattern.js index 670a1af..edc9841 100644 --- a/spec/spec/elements/Pattern.js +++ b/spec/spec/elements/Pattern.js @@ -39,7 +39,7 @@ describe('Pattern.js', () => { const canvas = SVG().addTo(container) const pattern = canvas.pattern() const rect = canvas.rect(100, 100).fill(pattern) - expect(pattern.targets()).toEqual([ rect ]) + expect(pattern.targets()).toEqual([rect]) }) }) @@ -62,7 +62,7 @@ describe('Pattern.js', () => { const spy = createSpy('pattern') pattern.update(spy) expect(spy.calls.all()).toEqual([ - objectContaining({ object: pattern, args: [ pattern ] }) + objectContaining({ object: pattern, args: [pattern] }) ]) }) }) @@ -94,9 +94,14 @@ describe('Pattern.js', () => { const spy = createSpy('pattern') const pattern = defs.pattern(100, 100, spy) expect(pattern).toEqual(any(Pattern)) - expect(defs.children()).toEqual([ pattern ]) + expect(defs.children()).toEqual([pattern]) expect(spy).toHaveBeenCalled() - expect(pattern.attr([ 'x', 'y', 'width', 'height' ])).toEqual({ x: 0, y: 0, width: 100, height: 100 }) + expect(pattern.attr(['x', 'y', 'width', 'height'])).toEqual({ + x: 0, + y: 0, + width: 100, + height: 100 + }) }) }) }) diff --git a/spec/spec/elements/Polygon.js b/spec/spec/elements/Polygon.js index 8a3f226..872aa32 100644 --- a/spec/spec/elements/Polygon.js +++ b/spec/spec/elements/Polygon.js @@ -19,8 +19,11 @@ describe('Polygon.js', () => { describe('polygon()', () => { it('creates a polygon with given points', () => { const group = new G() - const polygon = group.polygon([ 1, 2, 3, 4 ]) - expect(polygon.array()).toEqual([ [ 1, 2 ], [ 3, 4 ] ]) + const polygon = group.polygon([1, 2, 3, 4]) + expect(polygon.array()).toEqual([ + [1, 2], + [3, 4] + ]) expect(polygon).toEqual(any(Polygon)) }) }) @@ -28,7 +31,7 @@ describe('Polygon.js', () => { it('creates a polygon with one point by default', () => { const group = new G() const polygon = group.polygon() - expect(polygon.array()).toEqual([ [ 0, 0 ] ]) + expect(polygon.array()).toEqual([[0, 0]]) expect(polygon).toEqual(any(Polygon)) }) }) diff --git a/spec/spec/elements/Polyline.js b/spec/spec/elements/Polyline.js index 76dca30..e4a571f 100644 --- a/spec/spec/elements/Polyline.js +++ b/spec/spec/elements/Polyline.js @@ -19,15 +19,18 @@ describe('Polyline.js', () => { describe('polyline()', () => { it('creates a polyline with given points', () => { const group = new G() - const polyline = group.polyline([ 1, 2, 3, 4 ]) - expect(polyline.array()).toEqual([ [ 1, 2 ], [ 3, 4 ] ]) + const polyline = group.polyline([1, 2, 3, 4]) + expect(polyline.array()).toEqual([ + [1, 2], + [3, 4] + ]) expect(polyline).toEqual(any(Polyline)) }) it('creates a polyline with one point by default', () => { const group = new G() const polyline = group.polyline() - expect(polyline.array()).toEqual([ [ 0, 0 ] ]) + expect(polyline.array()).toEqual([[0, 0]]) expect(polyline).toEqual(any(Polyline)) }) }) diff --git a/spec/spec/elements/Rect.js b/spec/spec/elements/Rect.js index 230078f..20b5117 100644 --- a/spec/spec/elements/Rect.js +++ b/spec/spec/elements/Rect.js @@ -20,7 +20,10 @@ describe('Rect.js', () => { it('creates a rect with given size', () => { const group = new G() const rect = group.rect(100, 100) - expect(rect.attr([ 'width', 'height' ])).toEqual({ width: 100, height: 100 }) + expect(rect.attr(['width', 'height'])).toEqual({ + width: 100, + height: 100 + }) expect(rect).toEqual(any(Rect)) }) }) diff --git a/spec/spec/elements/Stop.js b/spec/spec/elements/Stop.js index e2ce2a8..e58cb24 100644 --- a/spec/spec/elements/Stop.js +++ b/spec/spec/elements/Stop.js @@ -66,7 +66,11 @@ describe('Stop.js', () => { it('creates stop in the gradient with object given', () => { const gradient = new Gradient('linear') - const stop = gradient.stop({ offset: 0.1, color: '#ffffff', opacity: 0.5 }) + const stop = gradient.stop({ + offset: 0.1, + color: '#ffffff', + opacity: 0.5 + }) expect(stop.attr('offset')).toBe(0.1) expect(stop.attr('stop-color')).toBe('#ffffff') expect(stop.attr('stop-opacity')).toBe(0.5) diff --git a/spec/spec/elements/Style.js b/spec/spec/elements/Style.js index 7b69dd3..fd587a1 100644 --- a/spec/spec/elements/Style.js +++ b/spec/spec/elements/Style.js @@ -33,13 +33,17 @@ describe('Style.js', () => { it('adds a font-face rule to load a custom font and returns itself', () => { const style = new Style() expect(style.font('fontName', 'url')).toBe(style) - expect(style.node.textContent).toBe('@font-face{font-family:fontName;src:url;}') + expect(style.node.textContent).toBe( + '@font-face{font-family:fontName;src:url;}' + ) }) it('adds extra parameters if wanted', () => { const style = new Style() style.font('fontName', 'url', { foo: 'bar' }) - expect(style.node.textContent).toBe('@font-face{font-family:fontName;src:url;foo:bar;}') + expect(style.node.textContent).toBe( + '@font-face{font-family:fontName;src:url;foo:bar;}' + ) }) }) @@ -78,7 +82,9 @@ describe('Style.js', () => { const g = new G() const style = g.fontface('fontName', 'url', { foo: 'bar' }) expect(style).toEqual(any(Style)) - expect(style.node.textContent).toBe('@font-face{font-family:fontName;src:url;foo:bar;}') + expect(style.node.textContent).toBe( + '@font-face{font-family:fontName;src:url;foo:bar;}' + ) }) }) }) diff --git a/spec/spec/elements/Svg.js b/spec/spec/elements/Svg.js index 990992a..6da7729 100644 --- a/spec/spec/elements/Svg.js +++ b/spec/spec/elements/Svg.js @@ -1,13 +1,16 @@ /* globals describe, expect, it, jasmine, container */ import { Svg, SVG, Defs } from '../../../src/main.js' -import { svg as ns, xlink, svgjs } from '../../../src/modules/core/namespaces.js' +import { + svg as ns, + xlink, + svgjs +} from '../../../src/modules/core/namespaces.js' import { getWindow } from '../../../src/utils/window.js' const { any } = jasmine describe('Svg.js', () => { - describe('()', () => { it('creates a new object of type Svg', () => { expect(new Svg()).toEqual(any(Svg)) diff --git a/spec/spec/elements/Symbol.js b/spec/spec/elements/Symbol.js index 12be314..6d9c17e 100644 --- a/spec/spec/elements/Symbol.js +++ b/spec/spec/elements/Symbol.js @@ -21,7 +21,7 @@ describe('Symbol.js', () => { const g = new G() const symbol = g.symbol() expect(symbol).toEqual(any(Symbol)) - expect(g.children()).toEqual([ symbol ]) + expect(g.children()).toEqual([symbol]) }) }) }) diff --git a/spec/spec/elements/Text.js b/spec/spec/elements/Text.js index e1a74d2..b0c5a9a 100644 --- a/spec/spec/elements/Text.js +++ b/spec/spec/elements/Text.js @@ -1,6 +1,13 @@ /* globals describe, expect, it, spyOn jasmine, container */ -import { Text, Number as SVGNumber, SVG, G, Path, TextPath } from '../../../src/main.js' +import { + Text, + Number as SVGNumber, + SVG, + G, + Path, + TextPath +} from '../../../src/main.js' const { any } = jasmine diff --git a/spec/spec/elements/TextPath.js b/spec/spec/elements/TextPath.js index 91c78c8..5e85bdb 100644 --- a/spec/spec/elements/TextPath.js +++ b/spec/spec/elements/TextPath.js @@ -7,7 +7,8 @@ const { any } = jasmine describe('TextPath.js', () => { var canvas, text, path var txt = 'We go up, then we go down, then up again' - var data = 'M 100 200 C 200 100 300 0 400 100 C 500 200 600 300 700 200 C 800 100 900 100 900 100' + var data = + 'M 100 200 C 200 100 300 0 400 100 C 500 200 600 300 700 200 C 800 100 900 100 900 100' beforeEach(() => { canvas = new SVG().addTo(container) @@ -144,9 +145,8 @@ describe('TextPath.js', () => { describe('targets', () => { it('returns all elements referencing this path with href', () => { const textPath = text.path(path) - expect(path.targets()).toEqual([ textPath ]) + expect(path.targets()).toEqual([textPath]) }) }) }) - }) diff --git a/spec/spec/elements/Tspan.js b/spec/spec/elements/Tspan.js index d6f42b2..879267c 100644 --- a/spec/spec/elements/Tspan.js +++ b/spec/spec/elements/Tspan.js @@ -98,11 +98,12 @@ describe('Tspan.js', () => { text.tspan('Second Line').newLine() const third = text.tspan('Third Line').newLine() - const fontSize = getWindow().getComputedStyle(third.node).getPropertyValue('font-size') + const fontSize = getWindow() + .getComputedStyle(third.node) + .getPropertyValue('font-size') const dy = 2 * new SVGNumber(fontSize) expect(third.dy()).toBe(dy) }) - }) describe('Tspan', () => { diff --git a/spec/spec/modules/core/attr.js b/spec/spec/modules/core/attr.js index e73fb53..b47794a 100644 --- a/spec/spec/modules/core/attr.js +++ b/spec/spec/modules/core/attr.js @@ -6,7 +6,6 @@ import { registerAttrHook } from '../../../../src/modules/core/attr.js' const { objectContaining } = jasmine describe('attr.js', () => { - describe('attr()', () => { let element @@ -83,13 +82,13 @@ describe('attr.js', () => { 'fill-opacity': 0.5 }) - const ret = element.attr([ 'x', 'fill-opacity' ]) + const ret = element.attr(['x', 'fill-opacity']) expect(ret).toEqual({ x: 1, 'fill-opacity': 0.5 }) }) it('correctly creates SVG.Array if array given', () => { - element.attr('something', [ 2, 3, 4 ]) + element.attr('something', [2, 3, 4]) expect(element.attr('something')).toBe('2 3 4') }) @@ -120,8 +119,9 @@ describe('attr.js', () => { element.attr('name', 'Bob') } - expect(throwingFn).toThrowError('This hook should only be executed in one test') + expect(throwingFn).toThrowError( + 'This hook should only be executed in one test' + ) }) }) - }) diff --git a/spec/spec/modules/core/circled.js b/spec/spec/modules/core/circled.js index a6324d8..95217c0 100644 --- a/spec/spec/modules/core/circled.js +++ b/spec/spec/modules/core/circled.js @@ -94,5 +94,4 @@ describe('circled.js', () => { expect(element.height()).toBe(100) }) }) - }) diff --git a/spec/spec/modules/core/containerGeometry.js b/spec/spec/modules/core/containerGeometry.js index 740f99f..011d9a8 100644 --- a/spec/spec/modules/core/containerGeometry.js +++ b/spec/spec/modules/core/containerGeometry.js @@ -5,7 +5,6 @@ import { Box, create, Element, G, Rect, SVG } from '../../../../src/main.js' const { any, objectContaining } = jasmine describe('containerGeometry.js', () => { - describe('dmove()', () => { it('moves the bbox of the group by a certain amount (1)', () => { const canvas = SVG().addTo(container) @@ -17,9 +16,14 @@ describe('containerGeometry.js', () => { g.dmove(10, 10) const box = g.bbox() - expect(box).toEqual(objectContaining({ - x: 20, y: 30, width: box.width, height: box.height - })) + expect(box).toEqual( + objectContaining({ + x: 20, + y: 30, + width: box.width, + height: box.height + }) + ) }) it('moves the bbox of the group by a certain amount (2)', () => { @@ -55,9 +59,14 @@ describe('containerGeometry.js', () => { expect(fn).not.toThrowError() const box = g.bbox() - expect(box).toEqual(objectContaining({ - x: 20, y: 30, width: box.width, height: box.height - })) + expect(box).toEqual( + objectContaining({ + x: 20, + y: 30, + width: box.width, + height: box.height + }) + ) }) }) @@ -211,7 +220,6 @@ describe('containerGeometry.js', () => { expect(newBox.w).toBeCloseTo(100, 4) expect(newBox.h).toBeCloseTo(100, 4) }) - }) describe('width()', () => { diff --git a/spec/spec/modules/core/event.js b/spec/spec/modules/core/event.js index a395a4b..e259593 100644 --- a/spec/spec/modules/core/event.js +++ b/spec/spec/modules/core/event.js @@ -1,5 +1,13 @@ /* globals describe, expect, it, spyOn, jasmine */ -import { windowEvents, getEvents, getEventTarget, clearEvents, dispatch, on, off } from '../../../../src/modules/core/event.js' +import { + windowEvents, + getEvents, + getEventTarget, + clearEvents, + dispatch, + on, + off +} from '../../../../src/modules/core/event.js' import { getWindow } from '../../../../src/utils/window.js' import { EventTarget, SVG } from '../../../../src/main.js' @@ -68,7 +76,7 @@ describe('event.js', () => { it('binds to multiple events passed as array', () => { const eventTarget = new EventTarget() const spy = createSpy('spy') - on(eventTarget, [ 'event1', 'event2', 'event3' ], spy) + on(eventTarget, ['event1', 'event2', 'event3'], spy) dispatch(eventTarget, 'event1') dispatch(eventTarget, 'event2') dispatch(eventTarget, 'event3') @@ -112,11 +120,11 @@ describe('event.js', () => { it('unbinds multiple events with space or comma separated string', () => { const eventTarget = new EventTarget() const spy = createSpy('spy') - on(eventTarget, [ 'event1', 'event2', 'event3' ], spy) + on(eventTarget, ['event1', 'event2', 'event3'], spy) dispatch(eventTarget, 'event1') dispatch(eventTarget, 'event2') dispatch(eventTarget, 'event3') - off(eventTarget, [ 'event1', 'event2', 'event3' ], spy) + off(eventTarget, ['event1', 'event2', 'event3'], spy) dispatch(eventTarget, 'event1') dispatch(eventTarget, 'event2') dispatch(eventTarget, 'event3') @@ -136,11 +144,11 @@ describe('event.js', () => { it('unbinds all events including namespaced ones when only event is passed', () => { const eventTarget = new EventTarget() const spy = createSpy('spy') - on(eventTarget, [ 'event1.ns1', 'event2.ns2', 'event3' ], spy) + on(eventTarget, ['event1.ns1', 'event2.ns2', 'event3'], spy) dispatch(eventTarget, 'event1') dispatch(eventTarget, 'event2') dispatch(eventTarget, 'event3') - off(eventTarget, [ 'event1', 'event2', 'event3' ]) + off(eventTarget, ['event1', 'event2', 'event3']) dispatch(eventTarget, 'event1') dispatch(eventTarget, 'event2') dispatch(eventTarget, 'event3') @@ -192,7 +200,12 @@ describe('event.js', () => { it('dispatches a custom event on the EventTarget by calling dispatchEvent()', () => { const eventTarget = new EventTarget() const spy = spyOn(eventTarget, 'dispatchEvent') - const event = dispatch(eventTarget, 'event', { some: 'data' }, { cancelable: false }) + const event = dispatch( + eventTarget, + 'event', + { some: 'data' }, + { cancelable: false } + ) expect(event).toEqual(any(getWindow().CustomEvent)) expect(spy).toHaveBeenCalledWith(event) expect(event.detail).toEqual({ some: 'data' }) diff --git a/spec/spec/modules/core/gradiented.js b/spec/spec/modules/core/gradiented.js index ba159f5..7b2c227 100644 --- a/spec/spec/modules/core/gradiented.js +++ b/spec/spec/modules/core/gradiented.js @@ -3,7 +3,6 @@ import { Gradient } from '../../../../src/main.js' describe('gradiented.js', () => { - describe('from()', () => { it('sets fx and fy for radial gradients and returns itself', () => { const gradient = new Gradient('radial') @@ -35,5 +34,4 @@ describe('gradiented.js', () => { expect(gradient.attr('y2')).toBe(20) }) }) - }) diff --git a/spec/spec/modules/core/pointed.js b/spec/spec/modules/core/pointed.js index bbe2475..77bf2d3 100644 --- a/spec/spec/modules/core/pointed.js +++ b/spec/spec/modules/core/pointed.js @@ -8,12 +8,11 @@ describe('pointed.js', () => { beforeEach(() => { canvas = SVG().addTo(container) const line = canvas.line(1, 2, 3, 4) - const polygon = canvas.polygon([ 1, 2, 3, 4 ]) - const polyline = canvas.polyline([ 1, 2, 3, 4 ]) + const polygon = canvas.polygon([1, 2, 3, 4]) + const polyline = canvas.polyline([1, 2, 3, 4]) lines = { line, polygon, polyline } }) - - ;[ 'line', 'polygon', 'polyline' ].forEach((l) => { + ;['line', 'polygon', 'polyline'].forEach((l) => { describe('for ' + l, () => { describe('x()', () => { it('sets the x value of the ' + l + 'and returns itself', () => { diff --git a/spec/spec/modules/core/poly.js b/spec/spec/modules/core/poly.js index c44bebc..e4c3bed 100644 --- a/spec/spec/modules/core/poly.js +++ b/spec/spec/modules/core/poly.js @@ -15,7 +15,10 @@ describe('Polygon.js', () => { it('returns the underlying PointArray', () => { const array = poly.plot('1 2 3 4').array() expect(array).toEqual(any(PointArray)) - expect(array).toEqual([ [ 1, 2 ], [ 3, 4 ] ]) + expect(array).toEqual([ + [1, 2], + [3, 4] + ]) }) }) @@ -36,9 +39,14 @@ describe('Polygon.js', () => { const canvas = SVG().addTo(container) const poly = canvas.polygon('0 0 50 50') poly.move(50, 50) - expect(poly.bbox()).toEqual(objectContaining({ - x: 50, y: 50, width: 50, height: 50 - })) + expect(poly.bbox()).toEqual( + objectContaining({ + x: 50, + y: 50, + width: 50, + height: 50 + }) + ) }) }) @@ -57,20 +65,37 @@ describe('Polygon.js', () => { it('works with flat array', () => { const spy = spyOn(poly, 'attr') - poly.plot([ 1, 2, 3, 4 ]) - expect(spy).toHaveBeenCalledWith('points', [ [ 1, 2 ], [ 3, 4 ] ]) + poly.plot([1, 2, 3, 4]) + expect(spy).toHaveBeenCalledWith('points', [ + [1, 2], + [3, 4] + ]) }) it('works with multi array', () => { const spy = spyOn(poly, 'attr') - poly.plot([ [ 1, 2 ], [ 3, 4 ] ]) - expect(spy).toHaveBeenCalledWith('points', [ [ 1, 2 ], [ 3, 4 ] ]) + poly.plot([ + [1, 2], + [3, 4] + ]) + expect(spy).toHaveBeenCalledWith('points', [ + [1, 2], + [3, 4] + ]) }) it('works with PointArray', () => { const spy = spyOn(poly, 'attr') - poly.plot(new PointArray([ [ 1, 2 ], [ 3, 4 ] ])) - expect(spy).toHaveBeenCalledWith('points', [ [ 1, 2 ], [ 3, 4 ] ]) + poly.plot( + new PointArray([ + [1, 2], + [3, 4] + ]) + ) + expect(spy).toHaveBeenCalledWith('points', [ + [1, 2], + [3, 4] + ]) }) }) @@ -83,27 +108,42 @@ describe('Polygon.js', () => { const canvas = SVG().addTo(container) const poly = canvas.polygon('0 0 50 50') poly.size(100, 100) - expect(poly.bbox()).toEqual(objectContaining({ - width: 100, height: 100, x: 0, y: 0 - })) + expect(poly.bbox()).toEqual( + objectContaining({ + width: 100, + height: 100, + x: 0, + y: 0 + }) + ) }) it('changes height proportionally', () => { const canvas = SVG().addTo(container) const poly = canvas.polygon('0 0 50 50') poly.size(100, null) - expect(poly.bbox()).toEqual(objectContaining({ - width: 100, height: 100, x: 0, y: 0 - })) + expect(poly.bbox()).toEqual( + objectContaining({ + width: 100, + height: 100, + x: 0, + y: 0 + }) + ) }) it('changes width proportionally', () => { const canvas = SVG().addTo(container) const poly = canvas.polygon('0 0 50 50') poly.size(null, 100) - expect(poly.bbox()).toEqual(objectContaining({ - width: 100, height: 100, x: 0, y: 0 - })) + expect(poly.bbox()).toEqual( + objectContaining({ + width: 100, + height: 100, + x: 0, + y: 0 + }) + ) }) }) }) diff --git a/spec/spec/modules/core/regex.js b/spec/spec/modules/core/regex.js index 5040fbd..37f774c 100644 --- a/spec/spec/modules/core/regex.js +++ b/spec/spec/modules/core/regex.js @@ -96,14 +96,26 @@ describe('regex.js', () => { describe('transforms', () => { it('splits a transform chain', () => { - const split = 'rotate(34) translate(1,2), translate(1 , 3),rotate(12) , something(1,2,3)'.split(regex.transforms) - expect(split).toEqual([ 'rotate(34', 'translate(1,2', 'translate(1 , 3', 'rotate(12', 'something(1,2,3', '' ]) + const split = + 'rotate(34) translate(1,2), translate(1 , 3),rotate(12) , something(1,2,3)'.split( + regex.transforms + ) + expect(split).toEqual([ + 'rotate(34', + 'translate(1,2', + 'translate(1 , 3', + 'rotate(12', + 'something(1,2,3', + '' + ]) }) }) describe('whitespace', () => { it('replaces all whitespaces', () => { - expect(' \n \r \t '.replace(regex.whitespace, ' ')).toBe(' ') + expect(' \n \r \t '.replace(regex.whitespace, ' ')).toBe( + ' ' + ) }) }) @@ -196,7 +208,7 @@ describe('regex.js', () => { describe('delimiter', () => { it('splits at whitespace and comma', () => { const split = '1,2 3 , 4 5,, 6'.split(regex.delimiter) - expect(split).toEqual([ '1', '2', '3', '4', '5', '6' ]) + expect(split).toEqual(['1', '2', '3', '4', '5', '6']) }) }) diff --git a/spec/spec/modules/core/selector.js b/spec/spec/modules/core/selector.js index 1336059..8729b61 100644 --- a/spec/spec/modules/core/selector.js +++ b/spec/spec/modules/core/selector.js @@ -10,17 +10,17 @@ describe('selector.js', () => { const span = SVG('<span />', true).addClass('bar').addTo(div) const span2 = SVG('<span />', true).addTo(div) - expect(find('#canvas').map(el => el.node)).toEqual([ container ]) - expect(find('span')).toEqual([ span, span2 ]) - expect(find('#foo')).toEqual([ div ]) - expect(find('.bar')).toEqual([ span ]) + expect(find('#canvas').map((el) => el.node)).toEqual([container]) + expect(find('span')).toEqual([span, span2]) + expect(find('#foo')).toEqual([div]) + expect(find('.bar')).toEqual([span]) }) it('finds all elements of a selector scoped to an element', () => { const div = SVG('<div />', true).id('foo').addTo(container) expect(find('#canvas', getWindow().document)[0].node).toBe(container) - expect(find('#foo', container)).toEqual([ div ]) + expect(find('#foo', container)).toEqual([div]) expect(find('#canvas', div.node)).toEqual([]) }) }) @@ -34,11 +34,11 @@ describe('selector.js', () => { const g4 = new G().addTo(g2) const g5 = new G().addTo(g3) - expect(g1.find('g')).toEqual([ g2, g4, g3, g5 ]) - expect(g2.find('g')).toEqual([ g4 ]) - expect(g1.find('#foo')).toEqual([ g2 ]) + expect(g1.find('g')).toEqual([g2, g4, g3, g5]) + expect(g2.find('g')).toEqual([g4]) + expect(g1.find('#foo')).toEqual([g2]) expect(g2.find('#foo')).toEqual([]) - expect(g1.find('.bar')).toEqual([ g3 ]) + expect(g1.find('.bar')).toEqual([g3]) }) }) diff --git a/spec/spec/modules/core/textable.js b/spec/spec/modules/core/textable.js index c0a2100..8135c6a 100644 --- a/spec/spec/modules/core/textable.js +++ b/spec/spec/modules/core/textable.js @@ -257,7 +257,10 @@ describe('textable.js', () => { add.tspan('The second.') add.tspan('The third.') }) - expect(text.length()).toBeCloseTo(text.get(0).length() + text.get(1).length() + text.get(2).length(), 3) + expect(text.length()).toBeCloseTo( + text.get(0).length() + text.get(1).length() + text.get(2).length(), + 3 + ) }) it('gets total length of tspan', () => { @@ -266,7 +269,10 @@ describe('textable.js', () => { add.tspan('The second.') add.tspan('The third.') }) - expect(tspan.length()).toBeCloseTo(tspan.get(0).length() + tspan.get(1).length() + tspan.get(2).length(), 3) + expect(tspan.length()).toBeCloseTo( + tspan.get(0).length() + tspan.get(1).length() + tspan.get(2).length(), + 3 + ) }) }) @@ -284,7 +290,9 @@ describe('textable.js', () => { text.tspan('A great piece!') text.tspan('Another great piece!') expect(text.node.childNodes[0].childNodes[0].data).toBe('A great piece!') - expect(text.node.childNodes[1].childNodes[0].data).toBe('Another great piece!') + expect(text.node.childNodes[1].childNodes[0].data).toBe( + 'Another great piece!' + ) }) it('disables adding multiple plain text nodes when given false for Text', () => { @@ -299,7 +307,9 @@ describe('textable.js', () => { text.clear().build(true) text.tspan('A great piece!') text.build(false).tspan('Another great piece!') - expect(text.node.childNodes[0].childNodes[0].data).toBe('Another great piece!') + expect(text.node.childNodes[0].childNodes[0].data).toBe( + 'Another great piece!' + ) expect(text.node.childNodes[1]).toBe(undefined) }) @@ -316,7 +326,9 @@ describe('textable.js', () => { tspan.tspan('A great piece!') tspan.tspan('Another great piece!') expect(tspan.node.childNodes[0].childNodes[0].data).toBe('A great piece!') - expect(tspan.node.childNodes[1].childNodes[0].data).toBe('Another great piece!') + expect(tspan.node.childNodes[1].childNodes[0].data).toBe( + 'Another great piece!' + ) }) it('disables adding multiple plain text nodes when given false for Tspan', () => { @@ -331,9 +343,10 @@ describe('textable.js', () => { tspan.clear().build(true) tspan.tspan('A great piece!') tspan.build(false).tspan('Another great piece!') - expect(tspan.node.childNodes[0].childNodes[0].data).toBe('Another great piece!') + expect(tspan.node.childNodes[0].childNodes[0].data).toBe( + 'Another great piece!' + ) expect(tspan.node.childNodes[1]).toBe(undefined) }) }) - }) diff --git a/spec/spec/modules/optional/arrange.js b/spec/spec/modules/optional/arrange.js index de1a4a0..c665aa5 100644 --- a/spec/spec/modules/optional/arrange.js +++ b/spec/spec/modules/optional/arrange.js @@ -11,7 +11,7 @@ describe('arrange.js', () => { const circle = g.circle(100) const line = g.line(1, 2, 3, 4) - expect(circle.siblings()).toEqual([ rect, circle, line ]) + expect(circle.siblings()).toEqual([rect, circle, line]) }) }) @@ -77,7 +77,7 @@ describe('arrange.js', () => { rect.forward() - expect(g.children()).toEqual([ circle, rect, line ]) + expect(g.children()).toEqual([circle, rect, line]) }) it('does nothing when the element is already the last one', () => { @@ -88,7 +88,7 @@ describe('arrange.js', () => { line.forward() - expect(g.children()).toEqual([ rect, circle, line ]) + expect(g.children()).toEqual([rect, circle, line]) }) }) @@ -107,7 +107,7 @@ describe('arrange.js', () => { line.backward() - expect(g.children()).toEqual([ rect, line, circle ]) + expect(g.children()).toEqual([rect, line, circle]) }) it('does nothing when the element is already the first one', () => { @@ -118,7 +118,7 @@ describe('arrange.js', () => { rect.backward() - expect(g.children()).toEqual([ rect, circle, line ]) + expect(g.children()).toEqual([rect, circle, line]) }) }) @@ -137,7 +137,7 @@ describe('arrange.js', () => { rect.front() - expect(g.children()).toEqual([ circle, line, rect ]) + expect(g.children()).toEqual([circle, line, rect]) }) it('does nothing when the element is already the last one', () => { @@ -148,7 +148,7 @@ describe('arrange.js', () => { line.front() - expect(g.children()).toEqual([ rect, circle, line ]) + expect(g.children()).toEqual([rect, circle, line]) }) }) @@ -167,7 +167,7 @@ describe('arrange.js', () => { line.back() - expect(g.children()).toEqual([ line, rect, circle ]) + expect(g.children()).toEqual([line, rect, circle]) }) it('does nothing when the element is already the first one', () => { @@ -178,7 +178,7 @@ describe('arrange.js', () => { rect.back() - expect(g.children()).toEqual([ rect, circle, line ]) + expect(g.children()).toEqual([rect, circle, line]) }) }) @@ -191,7 +191,7 @@ describe('arrange.js', () => { const line = new Line() circle.before(line) - expect(g.children()).toEqual([ rect, line, circle ]) + expect(g.children()).toEqual([rect, line, circle]) }) }) @@ -204,7 +204,7 @@ describe('arrange.js', () => { const line = new Line() rect.after(line) - expect(g.children()).toEqual([ rect, line, circle ]) + expect(g.children()).toEqual([rect, line, circle]) }) }) @@ -216,7 +216,7 @@ describe('arrange.js', () => { const line = new Line().insertBefore(circle) - expect(g.children()).toEqual([ rect, line, circle ]) + expect(g.children()).toEqual([rect, line, circle]) }) }) @@ -228,7 +228,7 @@ describe('arrange.js', () => { const line = new Line().insertAfter(rect) - expect(g.children()).toEqual([ rect, line, circle ]) + expect(g.children()).toEqual([rect, line, circle]) }) }) }) diff --git a/spec/spec/modules/optional/class.js b/spec/spec/modules/optional/class.js index b6bb42b..461c14f 100644 --- a/spec/spec/modules/optional/class.js +++ b/spec/spec/modules/optional/class.js @@ -7,7 +7,7 @@ describe('class.js', () => { describe('classes()', () => { it('returns all classes on an element', () => { const rect = new Rect({ class: 'myClass myClass2' }) - expect(rect.classes()).toEqual([ 'myClass', 'myClass2' ]) + expect(rect.classes()).toEqual(['myClass', 'myClass2']) }) it('returns an empty array if no class on the element', () => { @@ -35,13 +35,15 @@ describe('class.js', () => { }) it('adds a class to the element', () => { - const rect = new Rect({ class: 'myClass myClass2' }).addClass('myClass3') - expect(rect.classes()).toEqual([ 'myClass', 'myClass2', 'myClass3' ]) + const rect = new Rect({ class: 'myClass myClass2' }).addClass( + 'myClass3' + ) + expect(rect.classes()).toEqual(['myClass', 'myClass2', 'myClass3']) }) it('does nothing if class already present on the element', () => { const rect = new Rect({ class: 'myClass myClass2' }).addClass('myClass') - expect(rect.classes()).toEqual([ 'myClass', 'myClass2' ]) + expect(rect.classes()).toEqual(['myClass', 'myClass2']) }) }) @@ -52,13 +54,17 @@ describe('class.js', () => { }) it('removes a class from the element', () => { - const rect = new Rect({ class: 'myClass myClass2' }).removeClass('myClass2') - expect(rect.classes()).toEqual([ 'myClass' ]) + const rect = new Rect({ class: 'myClass myClass2' }).removeClass( + 'myClass2' + ) + expect(rect.classes()).toEqual(['myClass']) }) it('does nothing if class is not present on the element', () => { - const rect = new Rect({ class: 'myClass myClass2' }).removeClass('myClass3') - expect(rect.classes()).toEqual([ 'myClass', 'myClass2' ]) + const rect = new Rect({ class: 'myClass myClass2' }).removeClass( + 'myClass3' + ) + expect(rect.classes()).toEqual(['myClass', 'myClass2']) }) }) @@ -69,13 +75,17 @@ describe('class.js', () => { }) it('removes a class from the element when its present', () => { - const rect = new Rect({ class: 'myClass myClass2' }).toggleClass('myClass2') - expect(rect.classes()).toEqual([ 'myClass' ]) + const rect = new Rect({ class: 'myClass myClass2' }).toggleClass( + 'myClass2' + ) + expect(rect.classes()).toEqual(['myClass']) }) it('adds a class to the element if its not present', () => { - const rect = new Rect({ class: 'myClass myClass2' }).toggleClass('myClass3') - expect(rect.classes()).toEqual([ 'myClass', 'myClass2', 'myClass3' ]) + const rect = new Rect({ class: 'myClass myClass2' }).toggleClass( + 'myClass3' + ) + expect(rect.classes()).toEqual(['myClass', 'myClass2', 'myClass3']) }) }) }) diff --git a/spec/spec/modules/optional/css.js b/spec/spec/modules/optional/css.js index b6c04bc..8a42acf 100644 --- a/spec/spec/modules/optional/css.js +++ b/spec/spec/modules/optional/css.js @@ -7,7 +7,9 @@ describe('css.js', () => { describe('css()', () => { describe('as getter', () => { it('returns all css as object', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css()).toEqual({ fill: 'none', 'outline-width': '1px', @@ -16,57 +18,80 @@ describe('css.js', () => { }) it('returns an object with selected css properties', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) - expect(rect.css([ 'fill', 'stroke' ])).toEqual({ + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) + expect(rect.css(['fill', 'stroke'])).toEqual({ fill: 'none', stroke: 'none' }) }) it('returns a single property with property name given', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css('fill')).toBe('none') }) it('returns undefined if css property is not set', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css('outline-color')).toBe('') }) }) describe('as setter', () => { it('returns itself', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css('fill', 'black')).toBe(rect) }) it('adds a css property', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) - expect(rect.css('stroke-width', '2px').css('stroke-width')).toBe('2px') + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) + expect(rect.css('stroke-width', '2px').css('stroke-width')).toBe( + '2px' + ) }) it('changes a css property', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css('fill', 'black').css('fill')).toBe('black') }) it('sets an object of properties', () => { const rect = new Rect() - expect(rect.css({ fill: 'none', stroke: 'none' }).css()).toEqual({ fill: 'none', stroke: 'none' }) + expect(rect.css({ fill: 'none', stroke: 'none' }).css()).toEqual({ + fill: 'none', + stroke: 'none' + }) }) it('removes property if empty string is passed as value', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css('fill', '').css('fill')).toBe('') }) it('removes property if null is passed as value', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css('fill', null).css('fill')).toBe('') }) it('removes property if null is passed as part of object', () => { - const rect = new Rect({ style: 'fill: none; outline-width: 1px; stroke: none' }) + const rect = new Rect({ + style: 'fill: none; outline-width: 1px; stroke: none' + }) expect(rect.css({ fill: null, stroke: 'black' }).css('fill')).toBe('') }) }) diff --git a/spec/spec/modules/optional/data.js b/spec/spec/modules/optional/data.js index 211fef3..5265dd1 100644 --- a/spec/spec/modules/optional/data.js +++ b/spec/spec/modules/optional/data.js @@ -7,7 +7,11 @@ describe('data.js', () => { describe('data()', () => { describe('as getter', () => { it('returns all data as object', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) expect(rect.data()).toEqual({ fill: 'none', 'outline-width': '1px', @@ -16,65 +20,108 @@ describe('data.js', () => { }) it('returns an object with selected data properties', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) - expect(rect.data([ 'fill', 'stroke' ])).toEqual({ + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) + expect(rect.data(['fill', 'stroke'])).toEqual({ fill: 'none', stroke: 'none' }) }) it('returns a single property with property name given', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) expect(rect.data('fill')).toBe('none') }) it('returns undefined if data property is not set', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) expect(rect.data('outline-color')).toBe(undefined) }) }) describe('as setter', () => { it('returns itself', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) expect(rect.data('fill', 'black')).toBe(rect) }) it('adds a data property', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) - expect(rect.data('stroke-width', '2px').data('stroke-width')).toBe('2px') + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) + expect(rect.data('stroke-width', '2px').data('stroke-width')).toBe( + '2px' + ) }) it('changes a data property', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) expect(rect.data('fill', 'black').data('fill')).toBe('black') }) it('sets an object of properties', () => { const rect = new Rect() - expect(rect.data({ fill: 'none', stroke: 'none' }).data()).toEqual({ fill: 'none', stroke: 'none' }) + expect(rect.data({ fill: 'none', stroke: 'none' }).data()).toEqual({ + fill: 'none', + stroke: 'none' + }) }) it('removes property if null is passed as value', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) expect(rect.data('fill', null).data('fill')).toBe(undefined) }) it('removes property if null is passed as part of object', () => { - const rect = new Rect({ 'data-fill': 'none', 'data-outline-width': '1px', 'data-stroke': 'none' }) - expect(rect.data({ fill: null, stroke: 'black' }).data('fill')).toBe(undefined) + const rect = new Rect({ + 'data-fill': 'none', + 'data-outline-width': '1px', + 'data-stroke': 'none' + }) + expect(rect.data({ fill: null, stroke: 'black' }).data('fill')).toBe( + undefined + ) }) it('converts everything except number and strings to JSON', () => { const rect = new Rect() - expect(rect.data('fill', { some: 'object' }).attr('data-fill')).toBe(JSON.stringify({ some: 'object' })) + expect(rect.data('fill', { some: 'object' }).attr('data-fill')).toBe( + JSON.stringify({ some: 'object' }) + ) expect(rect.data('fill', 5).attr('data-fill')).toBe(5) expect(rect.data('fill', 'string').attr('data-fill')).toBe('string') }) it('does not convert to json with third parameter true', () => { const rect = new Rect() - expect(rect.data('fill', { some: 'object' }, true).attr('data-fill')).toBe({}.toString()) + expect( + rect.data('fill', { some: 'object' }, true).attr('data-fill') + ).toBe({}.toString()) }) }) }) diff --git a/spec/spec/modules/optional/memory.js b/spec/spec/modules/optional/memory.js index 3199456..7472078 100644 --- a/spec/spec/modules/optional/memory.js +++ b/spec/spec/modules/optional/memory.js @@ -6,7 +6,11 @@ describe('memory.js', () => { describe('Dom', () => { describe('memory()', () => { it('returns all memory as object', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.memory()).toEqual({ fill: 'none', 'outline-width': '1px', @@ -18,52 +22,90 @@ describe('memory.js', () => { describe('remember()', () => { describe('as getter', () => { it('returns a single property with property name given', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.remember('fill')).toBe('none') }) it('returns undefined if memory property is not set', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.remember('outline-color')).toBe(undefined) }) }) describe('as setter', () => { it('returns itself', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.remember('fill', 'black')).toBe(rect) }) it('adds a memory property', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) - expect(rect.remember('stroke-width', '2px').remember('stroke-width')).toBe('2px') + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) + expect( + rect.remember('stroke-width', '2px').remember('stroke-width') + ).toBe('2px') }) it('changes a memory property', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.remember('fill', 'black').remember('fill')).toBe('black') }) it('sets an object of properties', () => { const rect = new Rect() - expect(rect.remember({ fill: 'none', stroke: 'none' }).memory()).toEqual({ fill: 'none', stroke: 'none' }) + expect( + rect.remember({ fill: 'none', stroke: 'none' }).memory() + ).toEqual({ fill: 'none', stroke: 'none' }) }) }) }) describe('forget()', () => { it('removes property', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.forget('fill').remember('fill')).toBe(undefined) }) it('removes multiple properties', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) - expect(rect.forget('fill', 'stroke').memory()).toEqual({ 'outline-width': '1px' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) + expect(rect.forget('fill', 'stroke').memory()).toEqual({ + 'outline-width': '1px' + }) }) it('erases the whole object with nothing passed', () => { - const rect = new Rect().remember({ fill: 'none', 'outline-width': '1px', stroke: 'none' }) + const rect = new Rect().remember({ + fill: 'none', + 'outline-width': '1px', + stroke: 'none' + }) expect(rect.forget().memory()).toEqual({}) }) }) diff --git a/spec/spec/modules/optional/sugar.js b/spec/spec/modules/optional/sugar.js index 84c95b0..74cef62 100644 --- a/spec/spec/modules/optional/sugar.js +++ b/spec/spec/modules/optional/sugar.js @@ -32,15 +32,18 @@ describe('sugar.js', () => { it('sets an object of fill properties', () => { const rect = new Rect() - expect(rect.fill({ - color: 'black', - opacity: 0.5, - rule: 'even-odd' - }).attr()).toEqual({ + expect( + rect + .fill({ + color: 'black', + opacity: 0.5, + rule: 'even-odd' + }) + .attr() + ).toEqual({ fill: 'black', 'fill-opacity': 0.5, - 'fill-rule': - 'even-odd' + 'fill-rule': 'even-odd' }) }) }) @@ -86,16 +89,20 @@ describe('sugar.js', () => { it('sets an object of stroke properties', () => { const rect = new Rect() - expect(rect.stroke({ - color: 'black', - width: 2, - opacity: 0.5, - linecap: 'butt', - linejoin: 'miter', - miterlimit: 10, - dasharray: '2 2', - dashoffset: 15 - }).attr()).toEqual({ + expect( + rect + .stroke({ + color: 'black', + width: 2, + opacity: 0.5, + linecap: 'butt', + linejoin: 'miter', + miterlimit: 10, + dasharray: '2 2', + dashoffset: 15 + }) + .attr() + ).toEqual({ stroke: 'black', 'stroke-width': 2, 'stroke-opacity': 0.5, @@ -108,7 +115,7 @@ describe('sugar.js', () => { }) it('sets stroke dasharray with array passed', () => { - const rect = new Rect().stroke({ dasharray: [ 2, 2 ] }) + const rect = new Rect().stroke({ dasharray: [2, 2] }) expect(rect.attr()).toEqual({ 'stroke-dasharray': '2 2' }) }) }) @@ -157,21 +164,30 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.skew() - expect(spy).toHaveBeenCalledWith({ skew: [ undefined, undefined ], ox: undefined, oy: undefined }, true) + expect(spy).toHaveBeenCalledWith( + { skew: [undefined, undefined], ox: undefined, oy: undefined }, + true + ) }) it('redirects to transform() with one argument', function () { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.skew(5) - expect(spy).toHaveBeenCalledWith({ skew: 5, ox: undefined, oy: undefined }, true) + expect(spy).toHaveBeenCalledWith( + { skew: 5, ox: undefined, oy: undefined }, + true + ) }) it('redirects to transform() with two argument', function () { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.skew(5, 6) - expect(spy).toHaveBeenCalledWith({ skew: [ 5, 6 ], ox: undefined, oy: undefined }, true) + expect(spy).toHaveBeenCalledWith( + { skew: [5, 6], ox: undefined, oy: undefined }, + true + ) }) it('redirects to transform() with three arguments', function () { @@ -185,7 +201,7 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.skew(5, 6, 7, 8) - expect(spy).toHaveBeenCalledWith({ skew: [ 5, 6 ], ox: 7, oy: 8 }, true) + expect(spy).toHaveBeenCalledWith({ skew: [5, 6], ox: 7, oy: 8 }, true) }) }) @@ -203,21 +219,30 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.scale() - expect(spy).toHaveBeenCalledWith({ scale: [ undefined, undefined ], ox: undefined, oy: undefined }, true) + expect(spy).toHaveBeenCalledWith( + { scale: [undefined, undefined], ox: undefined, oy: undefined }, + true + ) }) it('redirects to transform() with one argument', function () { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.scale(5) - expect(spy).toHaveBeenCalledWith({ scale: 5, ox: undefined, oy: undefined }, true) + expect(spy).toHaveBeenCalledWith( + { scale: 5, ox: undefined, oy: undefined }, + true + ) }) it('redirects to transform() with two argument', function () { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.scale(5, 6) - expect(spy).toHaveBeenCalledWith({ scale: [ 5, 6 ], ox: undefined, oy: undefined }, true) + expect(spy).toHaveBeenCalledWith( + { scale: [5, 6], ox: undefined, oy: undefined }, + true + ) }) it('redirects to transform() with three arguments', function () { @@ -231,7 +256,7 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.scale(5, 6, 7, 8) - expect(spy).toHaveBeenCalledWith({ scale: [ 5, 6 ], ox: 7, oy: 8 }, true) + expect(spy).toHaveBeenCalledWith({ scale: [5, 6], ox: 7, oy: 8 }, true) }) }) @@ -240,7 +265,7 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.translate(1, 2) - expect(spy).toHaveBeenCalledWith({ translate: [ 1, 2 ] }, true) + expect(spy).toHaveBeenCalledWith({ translate: [1, 2] }, true) }) }) @@ -249,7 +274,7 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.relative(1, 2) - expect(spy).toHaveBeenCalledWith({ relative: [ 1, 2 ] }, true) + expect(spy).toHaveBeenCalledWith({ relative: [1, 2] }, true) }) }) @@ -265,7 +290,10 @@ describe('sugar.js', () => { const rect = new Rect() const spy = spyOn(rect, 'transform') rect.flip() - expect(spy).toHaveBeenCalledWith({ flip: 'both', origin: 'center' }, true) + expect(spy).toHaveBeenCalledWith( + { flip: 'both', origin: 'center' }, + true + ) }) // this works because only x and y are valid flip values. Everything else flips on both axis @@ -347,7 +375,6 @@ describe('sugar.js', () => { expect(spy).toHaveBeenCalledWith('font-size', undefined) }) }) - }) describe('radius()', () => { @@ -395,7 +422,8 @@ describe('sugar.js', () => { }) describe('events', () => { - [ 'click', + ;[ + 'click', 'dblclick', 'mousedown', 'mouseup', @@ -408,7 +436,8 @@ describe('sugar.js', () => { 'touchmove', 'touchleave', 'touchend', - 'touchcancel' ].forEach(ev => { + 'touchcancel' + ].forEach((ev) => { describe(ev, () => { it('calls on() with the eventname set to ' + ev, () => { const rect = new Rect() @@ -418,12 +447,17 @@ describe('sugar.js', () => { expect(spy).toHaveBeenCalledWith(ev, fn) }) - it('calls off() with the eventname set to ' + ev + ' when null is passed as second argument', () => { - const rect = new Rect() - const spy = spyOn(rect, 'off') - rect[ev](null) - expect(spy).toHaveBeenCalledWith(ev) - }) + it( + 'calls off() with the eventname set to ' + + ev + + ' when null is passed as second argument', + () => { + const rect = new Rect() + const spy = spyOn(rect, 'off') + rect[ev](null) + expect(spy).toHaveBeenCalledWith(ev) + } + ) }) }) }) diff --git a/spec/spec/modules/optional/transform.js b/spec/spec/modules/optional/transform.js index db59784..41d403c 100644 --- a/spec/spec/modules/optional/transform.js +++ b/spec/spec/modules/optional/transform.js @@ -23,12 +23,19 @@ describe('transform.js', () => { it('reduces all transformations of the transform list into one matrix - 2', () => { const rect = new Rect().attr('transform', 'translate(10, 20) rotate(45)') - expect(rect.matrixify()).toEqual(new Matrix().rotate(45).translate(10, 20)) + expect(rect.matrixify()).toEqual( + new Matrix().rotate(45).translate(10, 20) + ) }) it('reduces all transformations of the transform list into one matrix - 3', () => { - const rect = new Rect().attr('transform', 'translate(10, 20) rotate(45) skew(1,2) skewX(10) skewY(20)') - expect(rect.matrixify()).toEqual(new Matrix().skewY(20).skewX(10).skew(1, 2).rotate(45).translate(10, 20)) + const rect = new Rect().attr( + 'transform', + 'translate(10, 20) rotate(45) skew(1,2) skewX(10) skewY(20)' + ) + expect(rect.matrixify()).toEqual( + new Matrix().skewY(20).skewX(10).skew(1, 2).rotate(45).translate(10, 20) + ) }) }) @@ -69,7 +76,9 @@ describe('transform.js', () => { const expected = new Matrix().translate(10, 20).rotate(-10) // funny enough the dom seems to shorten the floats and precision gets lost - ;[ ...'abcdef' ].forEach(prop => expect(actual[prop]).toBeCloseTo(expected[prop], 5)) + ;[...'abcdef'].forEach((prop) => + expect(actual[prop]).toBeCloseTo(expected[prop], 5) + ) }) it('inserts the element at the specified position', () => { @@ -110,21 +119,25 @@ describe('transform.js', () => { }) it('sets the transformation with an object', () => { - const rect = new Rect().transform({ rotate: 45, translate: [ 10, 20 ] }) + const rect = new Rect().transform({ rotate: 45, translate: [10, 20] }) expect(rect.transform('rotate')).toBe(45) expect(rect.transform('translateX')).toBe(10) expect(rect.transform('translateY')).toBe(20) }) it('performs a relative transformation with flag=true', () => { - const rect = new Rect().transform({ rotate: 45, translate: [ 10, 20 ] }).transform({ rotate: 10 }, true) + const rect = new Rect() + .transform({ rotate: 45, translate: [10, 20] }) + .transform({ rotate: 10 }, true) expect(rect.transform('rotate')).toBeCloseTo(55, 5) // rounding errors expect(rect.transform('translateX')).toBe(10) expect(rect.transform('translateY')).toBe(20) }) it('performs a relative transformation with flag=other matrix', () => { - const rect = new Rect().transform({ rotate: 45, translate: [ 10, 20 ] }).transform({ rotate: 10 }, new Matrix().rotate(30)) + const rect = new Rect() + .transform({ rotate: 45, translate: [10, 20] }) + .transform({ rotate: 10 }, new Matrix().rotate(30)) expect(rect.transform('rotate')).toBeCloseTo(40, 5) // rounding errors expect(rect.transform('translateX')).toBe(0) expect(rect.transform('translateY')).toBe(0) @@ -132,7 +145,9 @@ describe('transform.js', () => { it('performs a relative transformation with flag=other element', () => { const referenceElement = new Rect().transform({ rotate: 30 }) - const rect = new Rect().transform({ rotate: 45, translate: [ 10, 20 ] }).transform({ rotate: 10 }, referenceElement) + const rect = new Rect() + .transform({ rotate: 45, translate: [10, 20] }) + .transform({ rotate: 10 }, referenceElement) expect(rect.transform('rotate')).toBeCloseTo(40, 5) // rounding errors expect(rect.transform('translateX')).toBe(0) expect(rect.transform('translateY')).toBe(0) diff --git a/spec/spec/types/Box.js b/spec/spec/types/Box.js index e220cea..e0f13e1 100644 --- a/spec/spec/types/Box.js +++ b/spec/spec/types/Box.js @@ -1,12 +1,6 @@ /* globals describe, expect, it, beforeEach, afterEach, spyOn, jasmine, container */ -import { - Box, - Matrix, - Rect, - G, - makeInstance as SVG -} from '../../../src/main.js' +import { Box, Matrix, Rect, G, makeInstance as SVG } from '../../../src/main.js' import { withWindow, getWindow } from '../../../src/utils/window.js' import { isNulledBox, domContains } from '../../../src/types/Box.js' @@ -70,48 +64,69 @@ describe('Box.js', () => { it('creates a new Box with default attributes', () => { const box = new Box() expect(box).toEqual(any(Box)) - expect(box).toEqual(objectContaining({ - width: 0, height: 0, x: 0, y: 0, w: 0, h: 0, cx: 0, cy: 0, x2: 0, y2: 0 - })) + expect(box).toEqual( + objectContaining({ + width: 0, + height: 0, + x: 0, + y: 0, + w: 0, + h: 0, + cx: 0, + cy: 0, + x2: 0, + y2: 0 + }) + ) }) }) describe('init()', () => { it('inits or reinits the box according to input', () => { - expect(new Box().init(1, 2, 3, 4).toArray()).toEqual([ 1, 2, 3, 4 ]) + expect(new Box().init(1, 2, 3, 4).toArray()).toEqual([1, 2, 3, 4]) }) it('works with array input', () => { - expect(new Box().init([ 1, 2, 3, 4 ]).toArray()).toEqual([ 1, 2, 3, 4 ]) + expect(new Box().init([1, 2, 3, 4]).toArray()).toEqual([1, 2, 3, 4]) }) it('works with 3 arguments as input', () => { - expect(new Box().init(1, 2, 3, 4).toArray()).toEqual([ 1, 2, 3, 4 ]) + expect(new Box().init(1, 2, 3, 4).toArray()).toEqual([1, 2, 3, 4]) }) it('works with string input', () => { - expect(new Box().init('1,2,3,4').toArray()).toEqual([ 1, 2, 3, 4 ]) + expect(new Box().init('1,2,3,4').toArray()).toEqual([1, 2, 3, 4]) }) it('creates a new box from parsed string with exponential values', function () { - expect(new Box().init('-1.12e1 1e-2 +2e2 +.3e+4').toArray()) - .toEqual([ -11.2, 0.01, 200, 3000 ]) + expect(new Box().init('-1.12e1 1e-2 +2e2 +.3e+4').toArray()).toEqual([ + -11.2, 0.01, 200, 3000 + ]) }) it('works with object input', () => { - expect(new Box().init({ x: 1, y: 2, width: 3, height: 4 }).toArray()) - .toEqual([ 1, 2, 3, 4 ]) + expect( + new Box().init({ x: 1, y: 2, width: 3, height: 4 }).toArray() + ).toEqual([1, 2, 3, 4]) }) it('calculates all derived values correctly', () => { - expect(new Box().init(2, 4, 6, 8)).toEqual(objectContaining({ - cx: 5, cy: 8, x2: 8, y2: 12, w: 6, h: 8 - })) + expect(new Box().init(2, 4, 6, 8)).toEqual( + objectContaining({ + cx: 5, + cy: 8, + x2: 8, + y2: 12, + w: 6, + h: 8 + }) + ) }) it('can handle input with left instead of x and top instead of y', () => { - expect(new Box().init({ left: 1, top: 2, width: 3, height: 4 }).toArray()) - .toEqual([ 1, 2, 3, 4 ]) + expect( + new Box().init({ left: 1, top: 2, width: 3, height: 4 }).toArray() + ).toEqual([1, 2, 3, 4]) }) }) @@ -122,7 +137,7 @@ describe('Box.js', () => { var box3 = new Box(500, 100, 100, 100) var merged = box1.merge(box2).merge(box3) - expect(merged.toArray()).toEqual([ 50, 50, 550, 450 ]) + expect(merged.toArray()).toEqual([50, 50, 550, 450]) }) it('returns a new instance', () => { @@ -136,23 +151,35 @@ describe('Box.js', () => { describe('transform()', () => { it('transforms the box with given matrix', () => { - var box1 = new Box(50, 50, 100, 100).transform(new Matrix(1, 0, 0, 1, 20, 20)) - var box2 = new Box(50, 50, 100, 100).transform(new Matrix(2, 0, 0, 2, 0, 0)) - var box3 = new Box(-200, -200, 100, 100).transform(new Matrix(1, 0, 0, 1, -20, -20)) + var box1 = new Box(50, 50, 100, 100).transform( + new Matrix(1, 0, 0, 1, 20, 20) + ) + var box2 = new Box(50, 50, 100, 100).transform( + new Matrix(2, 0, 0, 2, 0, 0) + ) + var box3 = new Box(-200, -200, 100, 100).transform( + new Matrix(1, 0, 0, 1, -20, -20) + ) - expect(box1.toArray()).toEqual([ 70, 70, 100, 100 ]) - expect(box2.toArray()).toEqual([ 100, 100, 200, 200 ]) - expect(box3.toArray()).toEqual([ -220, -220, 100, 100 ]) + expect(box1.toArray()).toEqual([70, 70, 100, 100]) + expect(box2.toArray()).toEqual([100, 100, 200, 200]) + expect(box3.toArray()).toEqual([-220, -220, 100, 100]) }) it('also works with matrix like input', () => { - var box1 = new Box(50, 50, 100, 100).transform(new Matrix(1, 0, 0, 1, 20, 20).toArray()) - var box2 = new Box(50, 50, 100, 100).transform(new Matrix(2, 0, 0, 2, 0, 0).toArray()) - var box3 = new Box(-200, -200, 100, 100).transform(new Matrix(1, 0, 0, 1, -20, -20).toArray()) - - expect(box1.toArray()).toEqual([ 70, 70, 100, 100 ]) - expect(box2.toArray()).toEqual([ 100, 100, 200, 200 ]) - expect(box3.toArray()).toEqual([ -220, -220, 100, 100 ]) + var box1 = new Box(50, 50, 100, 100).transform( + new Matrix(1, 0, 0, 1, 20, 20).toArray() + ) + var box2 = new Box(50, 50, 100, 100).transform( + new Matrix(2, 0, 0, 2, 0, 0).toArray() + ) + var box3 = new Box(-200, -200, 100, 100).transform( + new Matrix(1, 0, 0, 1, -20, -20).toArray() + ) + + expect(box1.toArray()).toEqual([70, 70, 100, 100]) + expect(box2.toArray()).toEqual([100, 100, 200, 200]) + expect(box3.toArray()).toEqual([-220, -220, 100, 100]) }) }) @@ -171,7 +198,7 @@ describe('Box.js', () => { withWindow({ pageXOffset: 50, pageYOffset: 25 }, () => { const box = new Box(100, 100, 100, 100).addOffset() - expect(box.toArray()).toEqual([ 150, 125, 100, 100 ]) + expect(box.toArray()).toEqual([150, 125, 100, 100]) }) }) }) @@ -184,7 +211,7 @@ describe('Box.js', () => { describe('toArray()', () => { it('returns an array representation of the box', () => { - expect(new Box(1, 2, 3, 4).toArray()).toEqual([ 1, 2, 3, 4 ]) + expect(new Box(1, 2, 3, 4).toArray()).toEqual([1, 2, 3, 4]) }) }) @@ -203,17 +230,21 @@ describe('Box.js', () => { const rect = new Rect().size(100, 200).move(20, 30).addTo(canvas) expect(rect.bbox()).toEqual(any(Box)) - expect(rect.bbox().toArray()).toEqual([ 20, 30, 100, 200 ]) + expect(rect.bbox().toArray()).toEqual([20, 30, 100, 200]) }) it('returns the bounding box of the element even if the node is not in the dom', () => { const rect = new Rect().size(100, 200).move(20, 30) - expect(rect.bbox().toArray()).toEqual([ 20, 30, 100, 200 ]) + expect(rect.bbox().toArray()).toEqual([20, 30, 100, 200]) }) it('throws when it is not possible to get a bbox', () => { - const spy = spyOn(getWindow().SVGGraphicsElement.prototype, 'getBBox') - .and.callFake(() => { throw new Error('No BBox for you') }) + const spy = spyOn( + getWindow().SVGGraphicsElement.prototype, + 'getBBox' + ).and.callFake(() => { + throw new Error('No BBox for you') + }) const rect = new Rect() expect(() => rect.bbox()).toThrow() expect(spy).toHaveBeenCalled() @@ -223,21 +254,27 @@ describe('Box.js', () => { describe('rbox()', () => { it('returns the BoundingClientRect of the element', () => { const canvas = SVG().addTo(container) - const rect = new Rect().size(100, 200).move(20, 30).addTo(canvas) - .attr('transform', new Matrix({ scale: 2, translate: [ 40, 50 ] })) + const rect = new Rect() + .size(100, 200) + .move(20, 30) + .addTo(canvas) + .attr('transform', new Matrix({ scale: 2, translate: [40, 50] })) expect(rect.rbox()).toEqual(any(Box)) - expect(rect.rbox().toArray()).toEqual([ 80, 110, 200, 400 ]) + expect(rect.rbox().toArray()).toEqual([80, 110, 200, 400]) }) it('returns the rbox box of the element in the coordinate system of the passed element', () => { const canvas = SVG().addTo(container) const group = canvas.group().translate(1, 1) - const rect = new Rect().size(100, 200).move(20, 30).addTo(canvas) - .attr('transform', new Matrix({ scale: 2, translate: [ 40, 50 ] })) + const rect = new Rect() + .size(100, 200) + .move(20, 30) + .addTo(canvas) + .attr('transform', new Matrix({ scale: 2, translate: [40, 50] })) expect(rect.rbox(group)).toEqual(any(Box)) - expect(rect.rbox(group).toArray()).toEqual([ 79, 109, 200, 400 ]) + expect(rect.rbox(group).toArray()).toEqual([79, 109, 200, 400]) }) // svgdom actually only throws here because a new Rect without dimensions has no bounding box @@ -267,30 +304,47 @@ describe('Box.js', () => { it('gets the viewbox of the element', () => { const canvas = SVG().addTo(container).viewbox(10, 10, 200, 200) expect(canvas.viewbox()).toEqual(any(Box)) - expect(canvas.viewbox().toArray()).toEqual([ 10, 10, 200, 200 ]) + expect(canvas.viewbox().toArray()).toEqual([10, 10, 200, 200]) }) }) describe('zoom()', () => { it('zooms around the center by default', () => { - const canvas = SVG().size(100, 50).viewbox(0, 0, 100, 50).addTo(container).zoom(2) + const canvas = SVG() + .size(100, 50) + .viewbox(0, 0, 100, 50) + .addTo(container) + .zoom(2) expect(canvas.attr('viewBox')).toEqual('25 12.5 50 25') }) it('zooms around a point', () => { - const canvas = SVG().size(100, 50).viewbox(0, 0, 100, 50).addTo(container).zoom(2, [ 0, 0 ]) + const canvas = SVG() + .size(100, 50) + .viewbox(0, 0, 100, 50) + .addTo(container) + .zoom(2, [0, 0]) expect(canvas.attr('viewBox')).toEqual('0 0 50 25') }) it('gets the zoom', () => { // We use a nested here because its actually harder to get a width and height for a nested svg because clientHeight // is not available - const svg = SVG().size(100, 50).addTo(container).nested().size(100, 50).viewbox(0, 0, 100, 50).zoom(2) + const svg = SVG() + .size(100, 50) + .addTo(container) + .nested() + .size(100, 50) + .viewbox(0, 0, 100, 50) + .zoom(2) expect(svg.zoom()).toEqual(2) }) it('gets the zoom with clientHeight', () => { - const svg = SVG().css({ width: '100px', height: '50px' }).addTo(container).viewbox(25, 12.5, 50, 25) + const svg = SVG() + .css({ width: '100px', height: '50px' }) + .addTo(container) + .viewbox(25, 12.5, 50, 25) const node = svg.node @@ -305,17 +359,32 @@ describe('Box.js', () => { }) it('throws an error if it is impossible to get an absolute value', () => { - const svg = SVG().size(100, 50).addTo(container).nested().viewbox(0, 0, 100, 50) - expect(() => svg.zoom()).toThrowError('Impossible to get absolute width and height. Please provide an absolute width and height attribute on the zooming element') + const svg = SVG() + .size(100, 50) + .addTo(container) + .nested() + .viewbox(0, 0, 100, 50) + expect(() => svg.zoom()).toThrowError( + 'Impossible to get absolute width and height. Please provide an absolute width and height attribute on the zooming element' + ) }) it('handles zoom level 0 which is - which basically sets the viewbox to a very high value', () => { - const svg = SVG().size(100, 50).viewbox(0, 0, 100, 50).addTo(container).zoom(0) + const svg = SVG() + .size(100, 50) + .viewbox(0, 0, 100, 50) + .addTo(container) + .zoom(0) expect(svg.zoom()).toBeCloseTo(0, 10) }) it('handles zoom level 0 and can recover from it', () => { - const svg = SVG().size(100, 50).viewbox(0, 0, 100, 50).addTo(container).zoom(0).zoom(1) + const svg = SVG() + .size(100, 50) + .viewbox(0, 0, 100, 50) + .addTo(container) + .zoom(0) + .zoom(1) expect(svg.zoom()).toBe(1) }) }) diff --git a/spec/spec/types/Color.js b/spec/spec/types/Color.js index 64161eb..4bbd626 100644 --- a/spec/spec/types/Color.js +++ b/spec/spec/types/Color.js @@ -12,7 +12,6 @@ describe('Color.js', () => { }) describe('()', () => { - describe('constructs a color from an object in the correct color space', () => { it('rgb', () => { const color = new Color({ r: 255, g: 0, b: 128 }) @@ -73,7 +72,7 @@ describe('Color.js', () => { }) it('constructs a color from an array', () => { - const color = new Color([ 30, 24, 50 ]) + const color = new Color([30, 24, 50]) expect(color.r).toBe(30) expect(color.g).toBe(24) expect(color.b).toBe(50) @@ -81,7 +80,7 @@ describe('Color.js', () => { }) it('constructs a color from an array with space in array', () => { - const color = new Color([ 50, 50, 5, 'lab' ]) + const color = new Color([50, 50, 5, 'lab']) expect(color.l).toBe(50) expect(color.a).toBe(50) expect(color.b).toBe(5) @@ -89,7 +88,7 @@ describe('Color.js', () => { }) it('constructs a color from an array with space given', () => { - const color = new Color([ 50, 50, 5 ], 'lab') + const color = new Color([50, 50, 5], 'lab') expect(color.l).toBe(50) expect(color.a).toBe(50) expect(color.b).toBe(5) @@ -118,7 +117,9 @@ describe('Color.js', () => { }) it('throws an error if unsupported string format was given', () => { - expect(() => new Color('#0066')).toThrowError('Unsupported string format, can\'t construct Color') + expect(() => new Color('#0066')).toThrowError( + "Unsupported string format, can't construct Color" + ) }) }) @@ -137,7 +138,6 @@ describe('Color.js', () => { }) describe('color spaces: The color spaces supported by our library', () => { - describe('lab()', () => { it('can convert rgb to lab', () => { const color = new Color(255, 0, 128) @@ -225,7 +225,6 @@ describe('Color.js', () => { }) describe('hsl()', () => { - it('can convert from rgb to hsl', () => { const color = new Color(255, 0, 128) const hsl = color.hsl() @@ -315,7 +314,6 @@ describe('Color.js', () => { // }) describe('cmyk()', () => { - it('can convert from rgb to cmyk', () => { const color = new Color(255, 0, 128) const cmyk = color.cmyk() @@ -357,9 +355,7 @@ describe('Color.js', () => { expect(color.b).toBeCloseTo(255, 0) expect(color.toHex()).toBe('#ffffff') }) - }) - }) describe('static methods', () => { @@ -397,7 +393,9 @@ describe('Color.js', () => { }) it('throws an error if mode is unknown', () => { - expect(() => Color.random('foo')).toThrowError('Unsupported random color mode') + expect(() => Color.random('foo')).toThrowError( + 'Unsupported random color mode' + ) }) }) @@ -446,5 +444,4 @@ describe('Color.js', () => { }) }) }) - }) diff --git a/spec/spec/types/EventTarget.js b/spec/spec/types/EventTarget.js index 82e5a94..f19fe11 100644 --- a/spec/spec/types/EventTarget.js +++ b/spec/spec/types/EventTarget.js @@ -32,7 +32,9 @@ describe('EventTarget.js', () => { const options = { cancelable: false } const event = target.dispatch('bla', 'foo', options) expect(spy).toHaveBeenCalledWith(event) - expect(event).toEqual(objectContaining({ type: 'bla', detail: 'foo', cancelable: false })) + expect(event).toEqual( + objectContaining({ type: 'bla', detail: 'foo', cancelable: false }) + ) }) }) diff --git a/spec/spec/types/List.js b/spec/spec/types/List.js index eb0b40b..a6cab09 100644 --- a/spec/spec/types/List.js +++ b/spec/spec/types/List.js @@ -7,7 +7,7 @@ const { any, createSpy, objectContaining } = jasmine describe('List.js', () => { describe('()', () => { it('creates a new List from Array', () => { - const list = new List([ 1, 2, 3 ]) + const list = new List([1, 2, 3]) expect(list).toEqual(any(List)) }) @@ -17,55 +17,57 @@ describe('List.js', () => { }) it('is instance of Array', () => { - const list = new List([ 1, 2, 3 ]) + const list = new List([1, 2, 3]) expect(list).toEqual(any(Array)) }) it('allows index access', () => { - const list = new List([ 1, 2, 3 ]) + const list = new List([1, 2, 3]) expect(list[1]).toBe(2) }) }) describe('each()', () => { it('works like map but with context set to the element when a function is passed', () => { - const list = new List([ 1, 2, 3 ]).each((el) => el * 2) + const list = new List([1, 2, 3]).each((el) => el * 2) expect(list).toEqual(any(List)) - expect(list).toEqual([ 2, 4, 6 ]) + expect(list).toEqual([2, 4, 6]) const spy = createSpy() const obj = {} - const list2 = new List([ obj ]) + const list2 = new List([obj]) list2.each(spy) - expect(spy.calls.first()).toEqual(objectContaining({ - object: obj, - args: [ obj, 0, list2 ] - })) + expect(spy.calls.first()).toEqual( + objectContaining({ + object: obj, + args: [obj, 0, list2] + }) + ) }) it('calls a method on every element in the list and passes arguments when a string is passed', () => { - const list = new List([ 10, 11, 12 ]) - expect(list.each('toString', 16)).toEqual([ 'a', 'b', 'c' ]) + const list = new List([10, 11, 12]) + expect(list.each('toString', 16)).toEqual(['a', 'b', 'c']) }) }) describe('toArray()', () => { it('returns a plain array from the contents of the list', () => { - const list = new List([ 1, 2, 3 ]) + const list = new List([1, 2, 3]) const arr = list.toArray() expect(arr).toEqual(any(Array)) expect(arr).not.toEqual(any(List)) - expect(arr).toEqual([ 1, 2, 3 ]) + expect(arr).toEqual([1, 2, 3]) }) }) describe('static extend()', () => { it('adds new method names to the List', () => { - List.extend([ 'fooBar' ]) + List.extend(['fooBar']) expect(new List().fooBar).toEqual(any(Function)) const obj = { fooBar: createSpy() } - new List([ obj ]).fooBar() + new List([obj]).fooBar() expect(obj.fooBar).toHaveBeenCalled() delete List.prototype.fooBar @@ -73,12 +75,14 @@ describe('List.js', () => { it('skips reserved names', () => { const { constructor, each, toArray } = List.prototype - List.extend([ 'constructor', 'each', 'toArray' ]) - expect(List.prototype).toEqual(objectContaining({ constructor, each, toArray })) + List.extend(['constructor', 'each', 'toArray']) + expect(List.prototype).toEqual( + objectContaining({ constructor, each, toArray }) + ) }) it('skips private methods starting with an underscore', () => { - List.extend([ '_private' ]) + List.extend(['_private']) expect(new List()._private).toBe(undefined) }) }) diff --git a/spec/spec/types/Matrix.js b/spec/spec/types/Matrix.js index bddf6fd..f395c43 100644 --- a/spec/spec/types/Matrix.js +++ b/spec/spec/types/Matrix.js @@ -9,12 +9,11 @@ describe('Matrix.js', () => { const comp = { a: 2, b: 0, c: 0, d: 2, e: 100, f: 50 } describe('initialization', () => { - it('creates a new matrix with default values', () => { const matrix = new Matrix() - expect(matrix).toEqual(objectContaining( - { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0 } - )) + expect(matrix).toEqual( + objectContaining({ a: 1, b: 0, c: 0, d: 1, e: 0, f: 0 }) + ) }) it('parses the current transform matrix from an element', () => { @@ -29,7 +28,7 @@ describe('Matrix.js', () => { }) it('parses an array correctly', () => { - const matrix = new Matrix([ 2, 0, 0, 2, 100, 50 ]) + const matrix = new Matrix([2, 0, 0, 2, 100, 50]) expect(matrix).toEqual(objectContaining(comp)) }) @@ -39,7 +38,7 @@ describe('Matrix.js', () => { }) it('parses a transform object correctly', () => { - const matrix = new Matrix({ scale: 2, translate: [ 100, 50 ] }) + const matrix = new Matrix({ scale: 2, translate: [100, 50] }) expect(matrix).toEqual(objectContaining(comp)) }) @@ -79,7 +78,11 @@ describe('Matrix.js', () => { describe('decompose()', () => { it('decomposes a matrix properly', () => { - var matrix = new Matrix().scale(3, 2.5).shear(4).rotate(30).translate(20, 30) + var matrix = new Matrix() + .scale(3, 2.5) + .shear(4) + .rotate(30) + .translate(20, 30) var decomposed = matrix.decompose() expect(decomposed.scaleX).toBeCloseTo(3) expect(decomposed.scaleY).toBeCloseTo(2.5) @@ -90,7 +93,11 @@ describe('Matrix.js', () => { }) it('can be recomposed to the same matrix', () => { - var matrix = new Matrix().scale(3, 2.5).shear(4).rotate(30).translate(20, 30) + var matrix = new Matrix() + .scale(3, 2.5) + .shear(4) + .rotate(30) + .translate(20, 30) var decomposed = matrix.decompose() // Get rid of the matrix values before recomposing with the matrix constructor @@ -141,7 +148,7 @@ describe('Matrix.js', () => { it('inverses matrix', () => { var matrix1 = new Matrix(2, 0, 0, 5, 4, 3) var matrix2 = matrix1.inverse() - var abcdef = [ 0.5, 0, 0, 0.2, -2, -0.6 ] + var abcdef = [0.5, 0, 0, 0.2, -2, -0.6] for (var i in 'abcdef') { expect(matrix2['abcdef'[i]]).toBeCloseTo(abcdef[i]) @@ -150,7 +157,9 @@ describe('Matrix.js', () => { it('throws if matrix is not invertible', () => { const matrix = new Matrix(0, 0, 0, 0, 0, 0) - expect(() => matrix.inverse()).toThrowError('Cannot invert matrix(0,0,0,0,0,0)') + expect(() => matrix.inverse()).toThrowError( + 'Cannot invert matrix(0,0,0,0,0,0)' + ) }) }) @@ -411,13 +420,21 @@ describe('Matrix.js', () => { describe('around()', () => { it('performs a matrix operation around an origin by shifting the origin to 0,0', () => { - const matrix = new Matrix(1, 0, 0, 1, 0, 0).around(10, 10, new Matrix().scale(2)) + const matrix = new Matrix(1, 0, 0, 1, 0, 0).around( + 10, + 10, + new Matrix().scale(2) + ) expect(matrix).toEqual(new Matrix(2, 0, 0, 2, -10, -10)) }) it('defaults to around center of 0,0', () => { - const matrix = new Matrix(1, 0, 0, 1, 0, 0).around(0, 0, new Matrix().scale(2)) + const matrix = new Matrix(1, 0, 0, 1, 0, 0).around( + 0, + 0, + new Matrix().scale(2) + ) expect(matrix).toEqual(new Matrix(2, 0, 0, 2, 0, 0)) }) @@ -451,14 +468,14 @@ describe('Matrix.js', () => { describe('toArray', () => { it('converts matrix to array', () => { const arr = new Matrix().toArray() - expect(arr).toEqual([ 1, 0, 0, 1, 0, 0 ]) + expect(arr).toEqual([1, 0, 0, 1, 0, 0]) }) }) describe('static', () => { describe('fromArray()', () => { it('creates a matrix like object from an array', () => { - const matrix = Matrix.fromArray([ 1, 2, 3, 4, 5, 6 ]) + const matrix = Matrix.fromArray([1, 2, 3, 4, 5, 6]) expect(matrix).not.toEqual(any(Matrix)) expect(matrix).toEqual(new Matrix(1, 2, 3, 4, 5, 6).valueOf()) }) @@ -478,47 +495,74 @@ describe('Matrix.js', () => { describe('formatTransforms()', () => { it('formats all transform input varieties to a canonical form', () => { - expect(Matrix.formatTransforms({ - flip: true, - skew: 5, - scale: 5, - originX: 5, - originY: 5, - positionX: 5, - positionY: 5, - translateX: 5, - translateY: 5, - relativeX: 5, - relativeY: 5 - })).toEqual({ scaleX: -5, scaleY: -5, skewX: 5, skewY: 5, shear: 0, theta: 0, rx: 5, ry: 5, tx: 5, ty: 5, ox: 5, oy: 5, px: 5, py: 5 }) + expect( + Matrix.formatTransforms({ + flip: true, + skew: 5, + scale: 5, + originX: 5, + originY: 5, + positionX: 5, + positionY: 5, + translateX: 5, + translateY: 5, + relativeX: 5, + relativeY: 5 + }) + ).toEqual({ + scaleX: -5, + scaleY: -5, + skewX: 5, + skewY: 5, + shear: 0, + theta: 0, + rx: 5, + ry: 5, + tx: 5, + ty: 5, + ox: 5, + oy: 5, + px: 5, + py: 5 + }) }) it('respects flip=x', () => { - expect(Matrix.formatTransforms({ - flip: 'x', - scale: [ 1, 2 ], - skew: [ 1, 2 ] - })).toEqual(objectContaining({ scaleX: -1, scaleY: 2, skewX: 1, skewY: 2 })) + expect( + Matrix.formatTransforms({ + flip: 'x', + scale: [1, 2], + skew: [1, 2] + }) + ).toEqual( + objectContaining({ scaleX: -1, scaleY: 2, skewX: 1, skewY: 2 }) + ) }) it('respects flip=y', () => { - expect(Matrix.formatTransforms({ - flip: 'y', - scaleX: 1, - scaleY: 2, - skewX: 1, - skewY: 2 - })).toEqual(objectContaining({ scaleX: 1, scaleY: -2, skewX: 1, skewY: 2 })) + expect( + Matrix.formatTransforms({ + flip: 'y', + scaleX: 1, + scaleY: 2, + skewX: 1, + skewY: 2 + }) + ).toEqual( + objectContaining({ scaleX: 1, scaleY: -2, skewX: 1, skewY: 2 }) + ) }) it('makes position NaN if not passed', () => { - expect(Matrix.formatTransforms({ - flip: 'y', - scaleX: 1, - scaleY: 2, - skewX: 1, - skewY: 2 - })).toEqual(objectContaining({ px: NaN, py: NaN })) + expect( + Matrix.formatTransforms({ + flip: 'y', + scaleX: 1, + scaleY: 2, + skewX: 1, + skewY: 2 + }) + ).toEqual(objectContaining({ px: NaN, py: NaN })) }) }) }) @@ -542,7 +586,10 @@ describe('Matrix.js', () => { }) it('does extra work for nested svgs because firefox needs it', () => { - const spy = spyOn(getWindow().SVGGraphicsElement.prototype, 'getScreenCTM') + const spy = spyOn( + getWindow().SVGGraphicsElement.prototype, + 'getScreenCTM' + ) const svg = SVG().nested() svg.screenCTM() expect(spy).toHaveBeenCalled() diff --git a/spec/spec/types/PathArray.js b/spec/spec/types/PathArray.js index 454252a..5c3991c 100644 --- a/spec/spec/types/PathArray.js +++ b/spec/spec/types/PathArray.js @@ -7,17 +7,19 @@ describe('PathArray.js', () => { beforeEach(() => { p1 = new PathArray('m10 10 h 80 v 80 h -80 l 300 400 z') - p2 = new PathArray('m10 80 c 40 10 65 10 95 80 s 150 150 180 80 t 300 300 q 52 10 95 80 z') + p2 = new PathArray( + 'm10 80 c 40 10 65 10 95 80 s 150 150 180 80 t 300 300 q 52 10 95 80 z' + ) p3 = new PathArray('m80 80 A 45 45, 0, 0, 0, 125 125 L 125 80 z') }) it('parses flat arrays correctly', () => { - const arr = new PathArray([ 'M', 0, 0, 'L', 100, 100, 'z' ]) + const arr = new PathArray(['M', 0, 0, 'L', 100, 100, 'z']) expect(arr.toString()).toBe('M0 0L100 100Z ') }) it('parses nested arrays correctly', () => { - const arr = new PathArray([ [ 'M', 0, 0 ], [ 'L', 100, 100 ], [ 'z' ] ]) + const arr = new PathArray([['M', 0, 0], ['L', 100, 100], ['z']]) expect(arr.toString()).toBe('M0 0L100 100Z ') }) @@ -25,20 +27,26 @@ describe('PathArray.js', () => { it('returns the valueOf when PathArray is given', () => { const p = new PathArray('m10 10 h 80 v 80 h -80 l 300 400 z') - expect((new PathArray(p))).toEqual(p) + expect(new PathArray(p)).toEqual(p) }) describe('move()', () => { it('moves all points in a straight path', () => { - expect(p1.move(100, 200).toString()).toBe('M100 200H180V280H100L400 680Z ') + expect(p1.move(100, 200).toString()).toBe( + 'M100 200H180V280H100L400 680Z ' + ) }) it('moves all points in a curved path', () => { - expect(p2.move(100, 200).toString()).toBe('M100 200C140 210 165 210 195 280S345 430 375 360T675 660Q727 670 770 740Z ') + expect(p2.move(100, 200).toString()).toBe( + 'M100 200C140 210 165 210 195 280S345 430 375 360T675 660Q727 670 770 740Z ' + ) }) it('moves all points in a arc path', () => { - expect(p3.move(100, 200).toString()).toBe('M100 200A45 45 0 0 0 145 245L145 200Z ') + expect(p3.move(100, 200).toString()).toBe( + 'M100 200A45 45 0 0 0 145 245L145 200Z ' + ) }) it('does nothing if passed number is not a number', () => { @@ -48,26 +56,32 @@ describe('PathArray.js', () => { describe('size()', () => { it('resizes all points in a straight path', () => { - expect(p1.size(600, 200).toString()).toBe('M10 10H170V43.333333333333336H10L610 210Z ') + expect(p1.size(600, 200).toString()).toBe( + 'M10 10H170V43.333333333333336H10L610 210Z ' + ) }) it('resizes all points in a curved path', () => { - expect(p2.size(600, 200).toString()).toBe('M10 80C45.82089552238806 83.70370370370371 68.2089552238806 83.70370370370371 95.07462686567165 109.62962962962963S229.40298507462686 165.1851851851852 256.2686567164179 139.25925925925927T524.9253731343283 250.37037037037038Q571.4925373134329 254.07407407407408 610 280Z ') + expect(p2.size(600, 200).toString()).toBe( + 'M10 80C45.82089552238806 83.70370370370371 68.2089552238806 83.70370370370371 95.07462686567165 109.62962962962963S229.40298507462686 165.1851851851852 256.2686567164179 139.25925925925927T524.9253731343283 250.37037037037038Q571.4925373134329 254.07407407407408 610 280Z ' + ) }) it('resizes all points in a arc path', () => { const expected = [ - [ 'M', 80, 80 ], - [ 'A', 600, 200, 0, 0, 0, 680, 280 ], - [ 'L', 680, 80 ], - [ 'Z' ] + ['M', 80, 80], + ['A', 600, 200, 0, 0, 0, 680, 280], + ['L', 680, 80], + ['Z'] ] const toBeTested = p3.size(600, 200) - for (let i = toBeTested.length; i--;) { - expect(toBeTested[i].shift().toUpperCase()).toBe(expected[i].shift().toUpperCase()) - for (let j = toBeTested[i].length; j--;) { + for (let i = toBeTested.length; i--; ) { + expect(toBeTested[i].shift().toUpperCase()).toBe( + expected[i].shift().toUpperCase() + ) + for (let j = toBeTested[i].length; j--; ) { expect(toBeTested[i][j]).toBeCloseTo(expected[i][j]) } } diff --git a/spec/spec/types/Point.js b/spec/spec/types/Point.js index ef0b6f6..ff167b3 100644 --- a/spec/spec/types/Point.js +++ b/spec/spec/types/Point.js @@ -6,9 +6,7 @@ describe('Point.js', () => { var point describe('initialization', () => { - describe('without a source', () => { - beforeEach(() => { point = new Point() }) @@ -17,7 +15,6 @@ describe('Point.js', () => { expect(point.x).toBe(0) expect(point.y).toBe(0) }) - }) describe('with x and y given', () => { @@ -40,7 +37,7 @@ describe('Point.js', () => { describe('with array given', () => { it('creates a point from array', () => { - var point = new Point([ 2, 4 ]) + var point = new Point([2, 4]) expect(point.x).toBe(2) expect(point.y).toBe(4) @@ -68,11 +65,15 @@ describe('Point.js', () => { describe('transform()', () => { it('transforms a point with a matrix', () => { - expect(new Point().transform(new Matrix({ translate: [ 10, 10 ] }))).toEqual(new Point(10, 10)) + expect( + new Point().transform(new Matrix({ translate: [10, 10] })) + ).toEqual(new Point(10, 10)) }) it('transforms a point with a transformation object', () => { - expect(new Point().transform({ translate: [ 10, 10 ] })).toEqual(new Point(10, 10)) + expect(new Point().transform({ translate: [10, 10] })).toEqual( + new Point(10, 10) + ) }) }) @@ -89,7 +90,7 @@ describe('Point.js', () => { describe('toArray()', () => { it('creates an array representation of Point', () => { const p = new Point(1, 2) - expect(p.toArray()).toEqual([ 1, 2 ]) + expect(p.toArray()).toEqual([1, 2]) }) }) @@ -97,7 +98,9 @@ describe('Point.js', () => { describe('point()', () => { it('transforms a screen point into the coordinate system of the element', () => { const rect = new Rect() - spyOn(rect, 'screenCTM').and.callFake(() => new Matrix(1, 0, 0, 1, 20, 20)) + spyOn(rect, 'screenCTM').and.callFake( + () => new Matrix(1, 0, 0, 1, 20, 20) + ) expect(rect.point({ x: 10, y: 10 })).toEqual(new Point(-10, -10)) }) }) diff --git a/spec/spec/types/PointArray.js b/spec/spec/types/PointArray.js index cbcc3c1..74cc21f 100644 --- a/spec/spec/types/PointArray.js +++ b/spec/spec/types/PointArray.js @@ -6,45 +6,76 @@ describe('PointArray.js', () => { const squareString = '0,0 1,0 1,1 0,1' describe('()', () => { - it('parses a string to a point array', () => { var array = new PointArray('0,1 -.05,7.95 1000.0001,-200.222') - expect(array.valueOf()).toEqual([ [ 0, 1 ], [ -0.05, 7.95 ], [ 1000.0001, -200.222 ] ]) + expect(array.valueOf()).toEqual([ + [0, 1], + [-0.05, 7.95], + [1000.0001, -200.222] + ]) }) it('parses a points array correctly to string', () => { - var array = new PointArray([ [ 0, 0.15 ], [ -100, -3.141592654 ], [ 50, 100 ] ]) + var array = new PointArray([ + [0, 0.15], + [-100, -3.141592654], + [50, 100] + ]) expect(array + '').toBe('0,0.15 -100,-3.141592654 50,100') }) it('parses a flat array of x/y coordinates to a point array', () => { - var array = new PointArray([ 1, 4, 5, 68, 12, 24 ]) - expect(array.valueOf()).toEqual([ [ 1, 4 ], [ 5, 68 ], [ 12, 24 ] ]) + var array = new PointArray([1, 4, 5, 68, 12, 24]) + expect(array.valueOf()).toEqual([ + [1, 4], + [5, 68], + [12, 24] + ]) }) it('parses points with space delimitered x/y coordinates', () => { - var array = new PointArray('221.08 191.79 0.46 191.79 0.46 63.92 63.8 0.46 284.46 0.46 284.46 128.37 221.08 191.79') - expect(array + '').toBe('221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79') + var array = new PointArray( + '221.08 191.79 0.46 191.79 0.46 63.92 63.8 0.46 284.46 0.46 284.46 128.37 221.08 191.79' + ) + expect(array + '').toBe( + '221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79' + ) }) it('parses points with comma delimitered x/y coordinates', () => { - var array = new PointArray('221.08,191.79,0.46,191.79,0.46,63.92,63.8,0.46,284.46,0.46,284.46,128.37,221.08,191.79') - expect(array + '').toBe('221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79') + var array = new PointArray( + '221.08,191.79,0.46,191.79,0.46,63.92,63.8,0.46,284.46,0.46,284.46,128.37,221.08,191.79' + ) + expect(array + '').toBe( + '221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79' + ) }) it('parses points with comma and space delimitered x/y coordinates', () => { - var array = new PointArray('221.08, 191.79, 0.46, 191.79, 0.46, 63.92, 63.8, 0.46, 284.46, 0.46, 284.46, 128.37, 221.08, 191.79') - expect(array + '').toBe('221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79') + var array = new PointArray( + '221.08, 191.79, 0.46, 191.79, 0.46, 63.92, 63.8, 0.46, 284.46, 0.46, 284.46, 128.37, 221.08, 191.79' + ) + expect(array + '').toBe( + '221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79' + ) }) it('parses points with space and comma delimitered x/y coordinates', () => { - var array = new PointArray('221.08 ,191.79 ,0.46 ,191.79 ,0.46 ,63.92 ,63.8 ,0.46 ,284.46 ,0.46 ,284.46 ,128.37 ,221.08 ,191.79') - expect(array + '').toBe('221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79') + var array = new PointArray( + '221.08 ,191.79 ,0.46 ,191.79 ,0.46 ,63.92 ,63.8 ,0.46 ,284.46 ,0.46 ,284.46 ,128.37 ,221.08 ,191.79' + ) + expect(array + '').toBe( + '221.08,191.79 0.46,191.79 0.46,63.92 63.8,0.46 284.46,0.46 284.46,128.37 221.08,191.79' + ) }) it('parses points with redundant spaces at the end', () => { - var array = new PointArray('2176.6,1708.8 2176.4,1755.8 2245.8,1801.5 2297,1787.8 ') - expect(array + '').toBe('2176.6,1708.8 2176.4,1755.8 2245.8,1801.5 2297,1787.8') + var array = new PointArray( + '2176.6,1708.8 2176.4,1755.8 2245.8,1801.5 2297,1787.8 ' + ) + expect(array + '').toBe( + '2176.6,1708.8 2176.4,1755.8 2245.8,1801.5 2297,1787.8' + ) }) it('parses points with space delimitered x/y coordinates - even with leading or trailing space', () => { @@ -60,38 +91,48 @@ describe('PointArray.js', () => { it('parses odd number of points in a flat array of x/y coordinates and silently remove the odd point', () => { // this is according to spec: https://svgwg.org/svg2-draft/shapes.html#DataTypePoints - var array = new PointArray([ 1, 2, 3 ]) - expect(array.valueOf()).toEqual([ [ 1, 2 ] ]) + var array = new PointArray([1, 2, 3]) + expect(array.valueOf()).toEqual([[1, 2]]) }) - }) describe('move()', () => { it('moves the whole array by the passed value', () => { - const arr = new PointArray([ 1, 2, 3, 4 ]).move(10, 10) - expect(arr.toArray()).toEqual([ 10, 10, 12, 12 ]) + const arr = new PointArray([1, 2, 3, 4]).move(10, 10) + expect(arr.toArray()).toEqual([10, 10, 12, 12]) }) it('does nothing if values not numbers', () => { - const arr = new PointArray([ 1, 2, 3, 4 ]).move() - expect(arr.toArray()).toEqual([ 1, 2, 3, 4 ]) + const arr = new PointArray([1, 2, 3, 4]).move() + expect(arr.toArray()).toEqual([1, 2, 3, 4]) }) }) describe('size()', () => { it('correctly sizes the points over the whole area', () => { - var array = new PointArray([ 10, 10, 20, 20, 30, 30 ]) - expect(array.size(60, 60).valueOf()).toEqual([ [ 10, 10 ], [ 40, 40 ], [ 70, 70 ] ]) + var array = new PointArray([10, 10, 20, 20, 30, 30]) + expect(array.size(60, 60).valueOf()).toEqual([ + [10, 10], + [40, 40], + [70, 70] + ]) }) it('let coordinates untouched when width/height is zero', () => { - var array = new PointArray([ 10, 10, 10, 20, 10, 30 ]) - expect(array.size(60, 60).valueOf()).toEqual([ [ 10, 10 ], [ 10, 40 ], [ 10, 70 ] ]) - - array = new PointArray([ 10, 10, 20, 10, 30, 10 ]) - expect(array.size(60, 60).valueOf()).toEqual([ [ 10, 10 ], [ 40, 10 ], [ 70, 10 ] ]) + var array = new PointArray([10, 10, 10, 20, 10, 30]) + expect(array.size(60, 60).valueOf()).toEqual([ + [10, 10], + [10, 40], + [10, 70] + ]) + + array = new PointArray([10, 10, 20, 10, 30, 10]) + expect(array.size(60, 60).valueOf()).toEqual([ + [10, 10], + [40, 10], + [70, 10] + ]) }) - }) describe('toString()', () => { @@ -103,7 +144,7 @@ describe('PointArray.js', () => { describe('toLine', () => { it('returns an object which can be passed to a line as point attributes', () => { - const arr = new PointArray([ 1, 2, 3, 4 ]) + const arr = new PointArray([1, 2, 3, 4]) expect(arr.toLine()).toEqual({ x1: 1, y1: 2, x2: 3, y2: 4 }) }) }) @@ -111,7 +152,7 @@ describe('PointArray.js', () => { describe('transform()', () => { it('translates correctly', () => { const square = new PointArray(squareString) - const translation = new Matrix({ translate: [ 2, 1 ] }) + const translation = new Matrix({ translate: [2, 1] }) const newSquare = square.transform(translation) expect(newSquare.toString()).toEqual('2,1 3,1 3,2 2,2') }) @@ -129,7 +170,7 @@ describe('PointArray.js', () => { it('works with transform object instead of matrix', () => { const square = new PointArray(squareString) - const newSquare = square.transform({ translate: [ 2, 1 ] }) + const newSquare = square.transform({ translate: [2, 1] }) expect(newSquare.toString()).toEqual('2,1 3,1 3,2 2,2') }) }) diff --git a/spec/spec/types/SVGArray.js b/spec/spec/types/SVGArray.js index dc58a89..35c4b85 100644 --- a/spec/spec/types/SVGArray.js +++ b/spec/spec/types/SVGArray.js @@ -6,7 +6,6 @@ const { any } = jasmine describe('SVGArray.js', () => { describe('()', () => { - it('preallocates memory if only number is passed', () => { const arr = new SVGArray(1) expect(arr.length).toBe(1) @@ -14,29 +13,28 @@ describe('SVGArray.js', () => { it('parses a matrix array correctly to string', () => { const array = new SVGArray([ - 0.343, 0.669, 0.119, 0, 0, - 0.249, -0.626, 0.130, 0, 0, - 0.172, 0.334, 0.111, 0, 0, - 0.000, 0.000, 0.000, 1, -0 + 0.343, 0.669, 0.119, 0, 0, 0.249, -0.626, 0.13, 0, 0, 0.172, 0.334, + 0.111, 0, 0, 0.0, 0.0, 0.0, 1, -0 ]) - expect(array + '').toBe('0.343 0.669 0.119 0 0 0.249 -0.626 0.13 0 0 0.172 0.334 0.111 0 0 0 0 0 1 0') + expect(array + '').toBe( + '0.343 0.669 0.119 0 0 0.249 -0.626 0.13 0 0 0.172 0.334 0.111 0 0 0 0 0 1 0' + ) }) it('parses space separated string and converts it to array', () => { - expect((new SVGArray('1 2 3 4')).valueOf()).toEqual([ 1, 2, 3, 4 ]) + expect(new SVGArray('1 2 3 4').valueOf()).toEqual([1, 2, 3, 4]) }) it('parses comma separated string and converts it to array', () => { - expect((new SVGArray('1,2,3,4')).valueOf()).toEqual([ 1, 2, 3, 4 ]) + expect(new SVGArray('1,2,3,4').valueOf()).toEqual([1, 2, 3, 4]) }) - }) describe('reverse()', () => { it('reverses the array', () => { - const array = new SVGArray([ 1, 2, 3, 4, 5 ]).reverse() - expect(array.valueOf()).toEqual([ 5, 4, 3, 2, 1 ]) + const array = new SVGArray([1, 2, 3, 4, 5]).reverse() + expect(array.valueOf()).toEqual([5, 4, 3, 2, 1]) }) it('returns itself', () => { @@ -47,7 +45,7 @@ describe('SVGArray.js', () => { describe('clone()', () => { it('creates a shallow clone of the array', () => { - const array = new SVGArray([ 1, 2, 3, 4, 5 ]) + const array = new SVGArray([1, 2, 3, 4, 5]) const clone = array.clone() expect(array).toEqual(clone) @@ -55,25 +53,33 @@ describe('SVGArray.js', () => { }) it('also works with PointArray (one depths clone)', () => { - const array = new PointArray([ [ 1, 2 ], [ 3, 4 ], [ 5, 6 ] ]) + const array = new PointArray([ + [1, 2], + [3, 4], + [5, 6] + ]) const clone = array.clone() expect(array).toEqual(clone) expect(array).not.toBe(clone) - for (let i = array.length; i--;) { + for (let i = array.length; i--; ) { expect(array[i]).not.toBe(clone[i]) } }) it('also works with PathArray (one depths clone)', () => { - const array = new PathArray([ [ 'M', 1, 2 ], [ 'L', 3, 4 ], [ 'L', 5, 6 ] ]) + const array = new PathArray([ + ['M', 1, 2], + ['L', 3, 4], + ['L', 5, 6] + ]) const clone = array.clone() expect(array).toEqual(clone) expect(array).not.toBe(clone) - for (let i = array.length; i--;) { + for (let i = array.length; i--; ) { expect(array[i]).not.toBe(clone[i]) } }) @@ -81,9 +87,9 @@ describe('SVGArray.js', () => { describe('toSet()', () => { it('creates a Set from the Array', () => { - const set = new SVGArray([ 1, 1, 2, 3 ]).toSet() + const set = new SVGArray([1, 1, 2, 3]).toSet() expect(set).toEqual(any(Set)) - expect(set).toEqual(new Set([ 1, 2, 3 ])) + expect(set).toEqual(new Set([1, 2, 3])) }) }) }) diff --git a/spec/spec/types/SVGNumber.js b/spec/spec/types/SVGNumber.js index 1660724..2002833 100644 --- a/spec/spec/types/SVGNumber.js +++ b/spec/spec/types/SVGNumber.js @@ -56,13 +56,15 @@ describe('Number.js', () => { }) it('falls back to maximum value if given number is positive infinite', () => { - number = new SVGNumber(1.7976931348623157E+10308) - expect(number.value).toBe(3.4e+38) + // eslint-disable-next-line no-loss-of-precision + number = new SVGNumber(1.7976931348623157e10308) + expect(number.value).toBe(3.4e38) }) it('falls back to minimum value if given number is negative infinite', () => { - number = new SVGNumber(-1.7976931348623157E+10308) - expect(number.value).toBe(-3.4e+38) + // eslint-disable-next-line no-loss-of-precision + number = new SVGNumber(-1.7976931348623157e10308) + expect(number.value).toBe(-3.4e38) }) }) diff --git a/spec/spec/utils/adopter.js b/spec/spec/utils/adopter.js index 60c1642..3c12790 100644 --- a/spec/spec/utils/adopter.js +++ b/spec/spec/utils/adopter.js @@ -69,7 +69,9 @@ describe('adopter.js', () => { const rect = makeInstance('<rect width="200px" />') expect(adoptSpy).toHaveBeenCalledWith(any(Node)) - expect(adoptSpy).toHaveBeenCalledWith(objectContaining({ nodeName: 'rect' })) + expect(adoptSpy).toHaveBeenCalledWith( + objectContaining({ nodeName: 'rect' }) + ) expect(rect).toEqual(any(Rect)) expect(rect.parent()).toBe(null) }) @@ -78,7 +80,12 @@ describe('adopter.js', () => { const div = makeInstance('<div />', true) expect(adoptSpy).toHaveBeenCalledWith(any(Node)) - expect(adoptSpy).toHaveBeenCalledWith(objectContaining({ nodeName: 'DIV', namespaceURI: 'http://www.w3.org/1999/xhtml' })) + expect(adoptSpy).toHaveBeenCalledWith( + objectContaining({ + nodeName: 'DIV', + namespaceURI: 'http://www.w3.org/1999/xhtml' + }) + ) expect(div).toEqual(any(Dom)) expect(div.parent()).toBe(null) }) @@ -106,7 +113,9 @@ describe('adopter.js', () => { const rect = makeInstance(create('rect')) expect(adoptSpy).toHaveBeenCalledWith(any(Node)) - expect(adoptSpy).toHaveBeenCalledWith(objectContaining({ nodeName: 'rect' })) + expect(adoptSpy).toHaveBeenCalledWith( + objectContaining({ nodeName: 'rect' }) + ) expect(rect).toEqual(any(Rect)) }) }) @@ -206,7 +215,10 @@ describe('adopter.js', () => { const A = class {} extend(A, { - test () { this.prop = 'test'; return this } + test() { + this.prop = 'test' + return this + } }) expect(typeof A.prototype.test).toBe('function') @@ -218,8 +230,11 @@ describe('adopter.js', () => { const B = class {} const C = class {} - extend([ A, B, C ], { - test () { this.prop = 'test'; return this } + extend([A, B, C], { + test() { + this.prop = 'test' + return this + } }) expect(typeof A.prototype.test).toBe('function') @@ -238,7 +253,8 @@ describe('adopter.js', () => { const A = class {} extend(A, { test: wrapWithAttrCheck(function () { - this.prop = 'test'; return this + this.prop = 'test' + return this }), attr: attrSpy }) diff --git a/spec/spec/utils/methods.js b/spec/spec/utils/methods.js index 10d50d8..457a078 100644 --- a/spec/spec/utils/methods.js +++ b/spec/spec/utils/methods.js @@ -1,6 +1,10 @@ /* globals describe, expect, it */ -import { registerMethods, getMethodsFor, getMethodNames } from '../../../src/utils/methods.js' +import { + registerMethods, + getMethodsFor, + getMethodNames +} from '../../../src/utils/methods.js' describe('methods.js', () => { describe('registerMethods() / getMethodsFor() / addMethodNames / getMethodNames()', () => { diff --git a/spec/spec/utils/pathParser.js b/spec/spec/utils/pathParser.js index 09cfa4a..15d0453 100644 --- a/spec/spec/utils/pathParser.js +++ b/spec/spec/utils/pathParser.js @@ -5,136 +5,159 @@ import { pathParser } from '../../../src/utils/pathParser.js' describe('pathParser.js', () => { describe('pathParser()', () => { it('parses all paths correctly', () => { - expect(pathParser('M2,0a2 2 0 00-2 2a2 2 0 002 2a.5.5 0 011 0z')).toEqual([ - [ 'M', 2, 0 ], - [ 'A', 2, 2, 0, 0, 0, 0, 2 ], - [ 'A', 2, 2, 0, 0, 0, 2, 4 ], - [ 'A', 0.5, 0.5, 0, 0, 1, 3, 4 ], - [ 'Z' ] - ]) - - expect(pathParser('M2,0a2 2 0 00-2 2a2 2 0 002 2a.5.5 0 111 0z')).toEqual([ - [ 'M', 2, 0 ], - [ 'A', 2, 2, 0, 0, 0, 0, 2 ], - [ 'A', 2, 2, 0, 0, 0, 2, 4 ], - [ 'A', 0.5, 0.5, 0, 1, 1, 3, 4 ], - [ 'Z' ] - ]) + expect(pathParser('M2,0a2 2 0 00-2 2a2 2 0 002 2a.5.5 0 011 0z')).toEqual( + [ + ['M', 2, 0], + ['A', 2, 2, 0, 0, 0, 0, 2], + ['A', 2, 2, 0, 0, 0, 2, 4], + ['A', 0.5, 0.5, 0, 0, 1, 3, 4], + ['Z'] + ] + ) + + expect(pathParser('M2,0a2 2 0 00-2 2a2 2 0 002 2a.5.5 0 111 0z')).toEqual( + [ + ['M', 2, 0], + ['A', 2, 2, 0, 0, 0, 0, 2], + ['A', 2, 2, 0, 0, 0, 2, 4], + ['A', 0.5, 0.5, 0, 1, 1, 3, 4], + ['Z'] + ] + ) expect(pathParser('m10 10 h 80 v 80 h -80 l 300 400 z')).toEqual([ - [ 'M', 10, 10 ], - [ 'H', 90 ], - [ 'V', 90 ], - [ 'H', 10 ], - [ 'L', 310, 490 ], - [ 'Z' ] - ]) - - expect(pathParser('m10 80 c 40 10 65 10 95 80 s 150 150 180 80 t 300 300 q 52 10 95 80 z')).toEqual([ - [ 'M', 10, 80 ], - [ 'C', 50, 90, 75, 90, 105, 160 ], - [ 'S', 255, 310, 285, 240 ], - [ 'T', 585, 540 ], - [ 'Q', 637, 550, 680, 620 ], - [ 'Z' ] - ]) - - expect(pathParser('m80 80 A 45 45, 0, 0, 0, 125 125 L 125 80 z')).toEqual([ - [ 'M', 80, 80 ], - [ 'A', 45, 45, 0, 0, 0, 125, 125 ], - [ 'L', 125, 80 ], - [ 'Z' ] - ]) - - expect(pathParser('M215.458,245.23c0,0,77.403,0,94.274,0S405,216.451,405,138.054S329.581,15,287.9,15c-41.68,0-139.924,0-170.688,0C86.45,15,15,60.65,15,134.084c0,73.434,96.259,112.137,114.122,112.137C146.984,246.221,215.458,245.23,215.458,245.23z')).toEqual([ - [ 'M', 215.458, 245.23 ], - [ 'C', 215.458, 245.23, 292.861, 245.23, 309.73199999999997, 245.23 ], - [ 'S', 405, 216.451, 405, 138.054 ], - [ 'S', 329.581, 15, 287.9, 15 ], - [ 'C', 246.21999999999997, 15, 147.97599999999997, 15, 117.21199999999999, 15 ], - [ 'C', 86.45, 15, 15, 60.65, 15, 134.084 ], - [ 'C', 15, 207.518, 111.259, 246.221, 129.122, 246.221 ], - [ 'C', 146.984, 246.221, 215.458, 245.23, 215.458, 245.23 ], - [ 'Z' ] - ]) - - expect(pathParser('M10 10-45-30.5.5 .89L2e-2.5.5-.5C.5.5.5.5.5.5L-3-4z')).toEqual([ - [ 'M', 10, 10 ], - [ 'L', -45, -30.5 ], - [ 'L', 0.5, 0.89 ], - [ 'L', 0.02, 0.5 ], - [ 'L', 0.5, -0.5 ], - [ 'C', 0.5, 0.5, 0.5, 0.5, 0.5, 0.5 ], - [ 'L', -3, -4 ], - [ 'Z' ] - ]) - - expect(pathParser('m 0,0 0,3189 2209,0 0,-3189 -2209,0 z m 154,154 1901,0 0,2881 -1901,0 0,-2881 z')).toEqual([ - [ 'M', 0, 0 ], - [ 'L', 0, 3189 ], - [ 'L', 2209, 3189 ], - [ 'L', 2209, 0 ], - [ 'L', 0, 0 ], - [ 'Z' ], - [ 'M', 154, 154 ], - [ 'L', 2055, 154 ], - [ 'L', 2055, 3035 ], - [ 'L', 154, 3035 ], - [ 'L', 154, 154 ], - [ 'Z' ] + ['M', 10, 10], + ['H', 90], + ['V', 90], + ['H', 10], + ['L', 310, 490], + ['Z'] + ]) + + expect( + pathParser( + 'm10 80 c 40 10 65 10 95 80 s 150 150 180 80 t 300 300 q 52 10 95 80 z' + ) + ).toEqual([ + ['M', 10, 80], + ['C', 50, 90, 75, 90, 105, 160], + ['S', 255, 310, 285, 240], + ['T', 585, 540], + ['Q', 637, 550, 680, 620], + ['Z'] + ]) + + expect(pathParser('m80 80 A 45 45, 0, 0, 0, 125 125 L 125 80 z')).toEqual( + [['M', 80, 80], ['A', 45, 45, 0, 0, 0, 125, 125], ['L', 125, 80], ['Z']] + ) + + expect( + pathParser( + 'M215.458,245.23c0,0,77.403,0,94.274,0S405,216.451,405,138.054S329.581,15,287.9,15c-41.68,0-139.924,0-170.688,0C86.45,15,15,60.65,15,134.084c0,73.434,96.259,112.137,114.122,112.137C146.984,246.221,215.458,245.23,215.458,245.23z' + ) + ).toEqual([ + ['M', 215.458, 245.23], + ['C', 215.458, 245.23, 292.861, 245.23, 309.73199999999997, 245.23], + ['S', 405, 216.451, 405, 138.054], + ['S', 329.581, 15, 287.9, 15], + [ + 'C', + 246.21999999999997, + 15, + 147.97599999999997, + 15, + 117.21199999999999, + 15 + ], + ['C', 86.45, 15, 15, 60.65, 15, 134.084], + ['C', 15, 207.518, 111.259, 246.221, 129.122, 246.221], + ['C', 146.984, 246.221, 215.458, 245.23, 215.458, 245.23], + ['Z'] + ]) + + expect( + pathParser('M10 10-45-30.5.5 .89L2e-2.5.5-.5C.5.5.5.5.5.5L-3-4z') + ).toEqual([ + ['M', 10, 10], + ['L', -45, -30.5], + ['L', 0.5, 0.89], + ['L', 0.02, 0.5], + ['L', 0.5, -0.5], + ['C', 0.5, 0.5, 0.5, 0.5, 0.5, 0.5], + ['L', -3, -4], + ['Z'] + ]) + + expect( + pathParser( + 'm 0,0 0,3189 2209,0 0,-3189 -2209,0 z m 154,154 1901,0 0,2881 -1901,0 0,-2881 z' + ) + ).toEqual([ + ['M', 0, 0], + ['L', 0, 3189], + ['L', 2209, 3189], + ['L', 2209, 0], + ['L', 0, 0], + ['Z'], + ['M', 154, 154], + ['L', 2055, 154], + ['L', 2055, 3035], + ['L', 154, 3035], + ['L', 154, 154], + ['Z'] ]) expect(pathParser('m 0,0 a 45 45, 0, 0, 0, 125 125')).toEqual([ - [ 'M', 0, 0 ], - [ 'A', 45, 45, 0, 0, 0, 125, 125 ] + ['M', 0, 0], + ['A', 45, 45, 0, 0, 0, 125, 125] ]) expect(pathParser('M10 10 80 80 30 30 Z')).toEqual([ - [ 'M', 10, 10 ], - [ 'L', 80, 80 ], - [ 'L', 30, 30 ], - [ 'Z' ] + ['M', 10, 10], + ['L', 80, 80], + ['L', 30, 30], + ['Z'] ]) expect(pathParser('M10 10L.5.5.3.3Z')).toEqual([ - [ 'M', 10, 10 ], - [ 'L', 0.5, 0.5 ], - [ 'L', 0.3, 0.3 ], - [ 'Z' ] + ['M', 10, 10], + ['L', 0.5, 0.5], + ['L', 0.3, 0.3], + ['Z'] ]) // "a" commands without optional whitespace around the flag params and ending coordinate pair expect(pathParser('a32 32 0 00.03-45.22', false)).toEqual([ - [ 'a', 32.0, 32.0, 0.0, 0.0, 0.0, 0.03, -45.22 ], + ['a', 32.0, 32.0, 0.0, 0.0, 0.0, 0.03, -45.22] ]) expect(pathParser('a48 48 0 1148-48', false)).toEqual([ - [ 'a', 48.0, 48.0, 0.0, 1.0, 1.0, 48.0, -48.0], + ['a', 48.0, 48.0, 0.0, 1.0, 1.0, 48.0, -48.0] ]) expect(pathParser('a82.6 82.6 0 0033.48-20.25', false)).toEqual([ - [ 'a', 82.6, 82.6, 0.0, 0.0, 0.0, 33.48, -20.25 ], + ['a', 82.6, 82.6, 0.0, 0.0, 0.0, 33.48, -20.25] ]) expect(pathParser('a82.45 82.45 0 00-20.24 33.47', false)).toEqual([ - [ 'a', 82.45, 82.45, 0.0, 0.0, 0.0, -20.24, 33.47 ], + ['a', 82.45, 82.45, 0.0, 0.0, 0.0, -20.24, 33.47] ]) expect(pathParser('a2.51 2.51 0 01.25.32', false)).toEqual([ - [ 'a', 2.51, 2.51, 0, 0, 1, 0.25, 0.32 ], + ['a', 2.51, 2.51, 0, 0, 1, 0.25, 0.32] ]) expect(pathParser('a2.51 2.51 0 00.25.32', false)).toEqual([ - [ 'a', 2.51, 2.51, 0, 0, 0, 0.25, 0.32 ], + ['a', 2.51, 2.51, 0, 0, 0, 0.25, 0.32] ]) expect(pathParser('a2.51 2.51 0 000.25.32', false)).toEqual([ - [ 'a', 2.51, 2.51, 0, 0, 0, 0.25, 0.32 ], + ['a', 2.51, 2.51, 0, 0, 0, 0.25, 0.32] ]) expect(pathParser('a48 48 0 1148-48 48 48 0 01-48 48', false)).toEqual([ - [ 'a', 48.0, 48.0, 0.0, 1.0, 1.0, 48.0, -48.0 ], - [ 'a', 48.0, 48.0, 0.0, 0.0, 1.0, -48.0, 48.0 ] + ['a', 48.0, 48.0, 0.0, 1.0, 1.0, 48.0, -48.0], + ['a', 48.0, 48.0, 0.0, 0.0, 1.0, -48.0, 48.0] ]) }) }) diff --git a/spec/spec/utils/utils.js b/spec/spec/utils/utils.js index 5a2ae97..0b3015e 100644 --- a/spec/spec/utils/utils.js +++ b/spec/spec/utils/utils.js @@ -20,7 +20,7 @@ describe('utils.js', function () { var arr2 beforeEach(function () { - arr1 = [ 1, 2, 3, 4 ] + arr1 = [1, 2, 3, 4] arr2 = map(arr1, function (el) { return el * 2 }) @@ -32,7 +32,7 @@ describe('utils.js', function () { }) it('executes a function on every element and returns the result in a new array', function () { - expect(arr2).toEqual([ 2, 4, 6, 8 ]) + expect(arr2).toEqual([2, 4, 6, 8]) }) }) @@ -41,7 +41,7 @@ describe('utils.js', function () { var arr2 beforeEach(function () { - arr1 = [ 1, 2, 3, 4 ] + arr1 = [1, 2, 3, 4] arr2 = filter(arr1, function (el) { return el % 2 === 0 }) @@ -53,7 +53,7 @@ describe('utils.js', function () { }) it('filters elements by function', function () { - expect(arr2).toEqual([ 2, 4 ]) + expect(arr2).toEqual([2, 4]) }) }) @@ -130,16 +130,28 @@ describe('utils.js', function () { var el = { bbox: () => ({ width: 200, height: 100 }) } it('calculates height proportionally', function () { - expect(proportionalSize(el, 400, null)).toEqual({ width: 400, height: 200 }) + expect(proportionalSize(el, 400, null)).toEqual({ + width: 400, + height: 200 + }) }) it('calculates width proportionally', function () { - expect(proportionalSize(el, null, 200)).toEqual({ width: 400, height: 200 }) + expect(proportionalSize(el, null, 200)).toEqual({ + width: 400, + height: 200 + }) }) it('prefers passed box over element', function () { - expect(proportionalSize(el, 300, null, box)).toEqual({ width: 300, height: 200 }) - expect(proportionalSize(el, null, 200, box)).toEqual({ width: 300, height: 200 }) + expect(proportionalSize(el, 300, null, box)).toEqual({ + width: 300, + height: 200 + }) + expect(proportionalSize(el, null, 200, box)).toEqual({ + width: 300, + height: 200 + }) }) }) @@ -147,48 +159,48 @@ describe('utils.js', function () { var el = { bbox: () => ({ width: 200, height: 100, x: 300, y: 400 }) } it('gets the origin from [ox, oy]', function () { - var origin = { origin: [ 10, 20 ] } - expect(getOrigin(origin, el)).toEqual([ 10, 20 ]) + var origin = { origin: [10, 20] } + expect(getOrigin(origin, el)).toEqual([10, 20]) }) it('gets the origin from [ox, oy] as strings', function () { - var origin = { origin: [ 'center', 'top' ] } - expect(getOrigin(origin, el)).toEqual([ 400, 400 ]) + var origin = { origin: ['center', 'top'] } + expect(getOrigin(origin, el)).toEqual([400, 400]) }) it('gets the origin from {x, y}', function () { var origin = { origin: { x: 10, y: 20 } } - expect(getOrigin(origin, el)).toEqual([ 10, 20 ]) + expect(getOrigin(origin, el)).toEqual([10, 20]) }) it('gets the origin from {ox, oy}', function () { var origin = { ox: 10, oy: 20 } - expect(getOrigin(origin, el)).toEqual([ 10, 20 ]) + expect(getOrigin(origin, el)).toEqual([10, 20]) }) it('gets the origin from {ox, oy} as strings', function () { var origin = { ox: 'center', oy: 'top' } - expect(getOrigin(origin, el)).toEqual([ 400, 400 ]) + expect(getOrigin(origin, el)).toEqual([400, 400]) }) it('gets the origin from {originX, originY}', function () { var origin = { originX: 10, originY: 20 } - expect(getOrigin(origin, el)).toEqual([ 10, 20 ]) + expect(getOrigin(origin, el)).toEqual([10, 20]) }) it('gets the origin from {originX, originY} as strings', function () { var origin = { originX: 'center', originY: 'top' } - expect(getOrigin(origin, el)).toEqual([ 400, 400 ]) + expect(getOrigin(origin, el)).toEqual([400, 400]) }) it('gets the origin from string', function () { var origin = { origin: 'center top' } - expect(getOrigin(origin, el)).toEqual([ 400, 400 ]) + expect(getOrigin(origin, el)).toEqual([400, 400]) }) it('gets the origin from number', function () { var origin = { origin: 5 } - expect(getOrigin(origin, el)).toEqual([ 5, 5 ]) + expect(getOrigin(origin, el)).toEqual([5, 5]) }) }) }) diff --git a/spec/spec/utils/window.js b/spec/spec/utils/window.js index 65fbcab..e681491 100644 --- a/spec/spec/utils/window.js +++ b/spec/spec/utils/window.js @@ -1,6 +1,13 @@ /* globals describe, expect, it */ -import { registerWindow, globals, withWindow, getWindow, saveWindow, restoreWindow } from '../../../src/utils/window.js' +import { + registerWindow, + globals, + withWindow, + getWindow, + saveWindow, + restoreWindow +} from '../../../src/utils/window.js' describe('window.js', () => { describe('registerWindow()', () => { |