summaryrefslogtreecommitdiffstats
path: root/spec
diff options
context:
space:
mode:
Diffstat (limited to 'spec')
-rwxr-xr-xspec/spec/array.js20
-rwxr-xr-xspec/spec/element.js9
-rwxr-xr-xspec/spec/text.js28
3 files changed, 32 insertions, 25 deletions
diff --git a/spec/spec/array.js b/spec/spec/array.js
index c051976..05ea837 100755
--- a/spec/spec/array.js
+++ b/spec/spec/array.js
@@ -1,36 +1,42 @@
describe('Array', function () {
+ var array
it('parses a matrix array correctly to string', function() {
- var array = new SVG.Array([ .343, .669, .119, 0, 0
+ array = new SVG.Array([ .343, .669, .119, 0, 0
, .249, -.626, .130, 0, 0
, .172, .334, .111, 0, 0
, .000, .000, .000, 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')
})
-
+ describe('reverse()', function() {
+ it('reverses the array', function() {
+ array = new SVG.Array([1 ,2 ,3, 4, 5]).reverse()
+ expect(array.value).toEqual([5, 4, 3, 2, 1])
+ })
+ it('returns itself', function() {
+ array = new SVG.Array()
+ expect(array.reverse()).toBe(array)
+ })
+ })
})
describe('PointArray', function () {
-
it('parses a string to a point array', function() {
var array = new SVG.PointArray('0,1 -.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', function() {
var array = new SVG.PointArray([[0,.15], [-100,-3.141592654], [50,100]])
expect(array + '').toBe('0,0.15 -100,-3.141592654 50,100')
})
-
})
-/* toUpperCase() for Firefox */
describe('PathArray', function () {
- var p1, p2
+ var p1, p2, p3
beforeEach(function() {
p1 = new SVG.PathArray('m10 10 h 80 v 80 h -80 l 300 400 z')
diff --git a/spec/spec/element.js b/spec/spec/element.js
index 22b09bf..919df93 100755
--- a/spec/spec/element.js
+++ b/spec/spec/element.js
@@ -57,15 +57,16 @@ describe('Element', function() {
})
it('gets the "style" attribute as a string', function() {
rect.style('cursor', 'pointer')
- expect(stripped(rect.attr('style'))).toBe('cursor:pointer;')
+ expect(rect.node.style.cursor).toBe('pointer')
})
it('redirects to the style() method when setting a style string', function() {
rect.attr('style', 'cursor:move;')
- expect(stripped(rect.node.getAttribute('style'))).toBe('cursor:move;')
+ expect(rect.node.style.cursor).toBe('move')
})
it('should remove style attribute on node if the style is empty', function() {
- rect.style('style', '')
- expect(rect.node.getAttribute('style')).toBe(null)
+ rect.style('cursor', 'move')
+ rect.style('cursor', '')
+ expect(rect.style.cursor).toBe(undefined)
})
it('should act as a global getter when no arguments are given', function() {
rect.fill('#ff0066')
diff --git a/spec/spec/text.js b/spec/spec/text.js
index f9019a2..6c4d9c6 100755
--- a/spec/spec/text.js
+++ b/spec/spec/text.js
@@ -1,6 +1,6 @@
// IMPORTANT!!!
-// The native getBBox() on text elements is not accurate to the pixel.
-// Therefore some values are treated with the approximately() function.
+// The native getBBox() on text elements isn't always accurate in the decimals.
+// Therefore sometimes some rounding is used to make test work as expected.
describe('Text', function() {
var text
@@ -15,50 +15,50 @@ describe('Text', function() {
describe('x()', function() {
it('returns the value of x without an argument', function() {
- expect(approximately(text.x())).toBe(approximately(0))
+ expect(text.x()).toBe(0)
})
it('sets the value of x with the first argument', function() {
text.x(123)
var box = text.bbox()
- expect(approximately(box.x, 5)).toBe(approximately(123, 5))
+ expect(box.x).toBe(123)
})
it('sets the value of x based on the anchor with the first argument', function() {
text.x(123, true)
var box = text.bbox()
- expect(approximately(box.x, 5)).toBe(approximately(123, 5))
+ expect(box.x).toBe(123)
})
})
describe('y()', function() {
it('returns the value of y without an argument', function() {
- expect(text.y()).toBe(0)
+ expect(text.y(0).y()).toBe(0)
})
it('sets the value of y with the first argument', function() {
text.y(345)
var box = text.bbox()
- expect(approximately(box.y, 5)).toBe(approximately(345, 5))
+ expect(box.y).toBe(345)
})
it('sets the value of y based on the anchor with the first argument', function() {
text.y(345, true)
var box = text.bbox()
- expect(approximately(box.y, 5)).toBe(approximately(345, 5))
+ expect(box.y).toBe(345)
})
})
describe('cx()', function() {
it('returns the value of cx without an argument', function() {
var box = text.bbox()
- expect(approximately(text.cx())).toBe(approximately(box.width / 2))
+ expect(text.cx()).toBe(box.width / 2)
})
it('sets the value of cx with the first argument', function() {
text.cx(123)
var box = text.bbox()
- expect(approximately(box.cx, 5)).toBe(approximately(123, 5))
+ expect(box.cx).toBe(123)
})
it('sets the value of cx based on the anchor with the first argument', function() {
text.cx(123, true)
var box = text.bbox()
- expect(approximately(box.cx, 5)).toBe(approximately(123, 5))
+ expect(box.cx).toBe(123)
})
})
@@ -70,7 +70,7 @@ describe('Text', function() {
it('sets the value of cy with the first argument', function() {
text.cy(345)
var box = text.bbox()
- expect(approximately(box.cy, 5)).toBe(approximately(345, 5))
+ expect(Math.round(box.cy * 10) / 10).toBe(345)
})
})
@@ -87,8 +87,8 @@ describe('Text', function() {
it('sets the cx and cy position', function() {
text.center(321,567)
var box = text.bbox()
- expect(approximately(box.cx, 5)).toBe(approximately(321, 5))
- expect(approximately(box.cy, 6)).toBe(approximately(567, 6))
+ expect(box.cx).toBe(321)
+ expect(Math.round(box.cy * 10) / 10).toBe(567)
})
})