diff options
author | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2020-04-10 15:15:29 +1000 |
---|---|---|
committer | Ulrich-Matthias Schäfer <ulima.ums@googlemail.com> | 2020-04-10 15:15:29 +1000 |
commit | e6fda9da8f777786a98c9351f33823241ce864fd (patch) | |
tree | fa68aff91188cd079b4dda2057e02ed9f8744b26 /spec | |
parent | 373b78a10b3255104e221c64494e3139d11d058b (diff) | |
download | svg.js-e6fda9da8f777786a98c9351f33823241ce864fd.tar.gz svg.js-e6fda9da8f777786a98c9351f33823241ce864fd.zip |
added tests for Mask
Diffstat (limited to 'spec')
-rw-r--r-- | spec/spec/elements/ClipPath.js | 2 | ||||
-rw-r--r-- | spec/spec/elements/Mask.js | 95 |
2 files changed, 96 insertions, 1 deletions
diff --git a/spec/spec/elements/ClipPath.js b/spec/spec/elements/ClipPath.js index a476884..d1d799b 100644 --- a/spec/spec/elements/ClipPath.js +++ b/spec/spec/elements/ClipPath.js @@ -42,7 +42,7 @@ describe('ClipPath.js', () => { }) describe('Container', () => { - describe('circle()', () => { + describe('clip()', () => { it('creates a clipPath in the defs', () => { const canvas = SVG() const clip = canvas.clip() diff --git a/spec/spec/elements/Mask.js b/spec/spec/elements/Mask.js new file mode 100644 index 0000000..b9c97f3 --- /dev/null +++ b/spec/spec/elements/Mask.js @@ -0,0 +1,95 @@ +/* globals describe, expect, it, spyOn, jasmine, container */ + +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)) + }) + + it('sets passed attributes on the element', () => { + expect(new Mask({ id: 'foo' }).id()).toBe('foo') + }) + }) + + describe('remove()', () => { + it('unmasks all targets', () => { + const canvas = SVG().addTo(container) + const mask = canvas.mask() + const rect = canvas.rect(100, 100).maskWith(mask) + expect(mask.remove()).toBe(mask) + expect(rect.masker()).toBe(null) + }) + + it('calls remove on parent class', () => { + const mask = new Mask() + const spy = spyOn(Container.prototype, 'remove') + mask.remove() + expect(spy).toHaveBeenCalled() + }) + }) + + describe('targets()', () => { + it('gets all targets of this maskPath', () => { + const canvas = SVG().addTo(container) + const mask = canvas.mask() + const rect = canvas.rect(100, 100).maskWith(mask) + expect(mask.targets()).toEqual([ rect ]) + }) + }) + + describe('Container', () => { + describe('mask()', () => { + it('creates a maskPath in the defs', () => { + const canvas = SVG() + const mask = canvas.mask() + expect(mask).toEqual(any(Mask)) + expect(canvas.defs().children()).toEqual([ mask ]) + }) + }) + }) + + describe('Element', () => { + describe('masker()', () => { + it('returns the instance of Mask the current element is maskped with', () => { + const canvas = SVG().addTo(container) + const mask = canvas.mask() + const rect = canvas.rect(100, 100).maskWith(mask) + expect(rect.masker()).toEqual(mask) + }) + + it('returns null if no maskPath was found', () => { + expect(new Rect().masker()).toBe(null) + }) + }) + + describe('maskWith()', () => { + it('sets the mask attribute on the element to the id of the maskPath', () => { + const mask = new Mask().id('foo') + const rect = new Rect().maskWith(mask) + expect(rect.attr('mask')).toBe('url("#foo")') + }) + + it('creates a maskPath and appends the passed element to it to mask current element', () => { + const canvas = SVG().addTo(container) + const circle = canvas.circle(40) + const rect = canvas.rect(100, 100).maskWith(circle) + expect(circle.parent()).toEqual(any(Mask)) + expect(rect.attr('mask')).toBe(`url("#${circle.parent().id()}")`) + }) + }) + + describe('unmask()', () => { + it('sets the mask-target attribute to null and returns itself', () => { + const mask = new Mask().id('foo') + const rect = new Rect().maskWith(mask) + expect(rect.unmask()).toBe(rect) + expect(rect.attr('mask')).toBe(undefined) + }) + }) + }) +}) |