Clean up SVGImport tests.

This commit is contained in:
Jürg Lehni 2015-07-27 10:29:50 +02:00
parent 5f42020869
commit 5604dd7a30
3 changed files with 96 additions and 365 deletions

View file

@ -273,8 +273,16 @@ function asyncTest(testName, expected) {
// SVG // SVG
function createSVG(xml) { function createSVG(str, attrs) {
return new DOMParser().parseFromString( if (attrs) {
'<svg xmlns="http://www.w3.org/2000/svg">' + xml + '</svg>', // Similar to SVGExport's createElement / setAttributes.
'text/xml'); var node = document.createElementNS('http://www.w3.org/2000/svg', str);
for (var key in attrs)
node.setAttribute(key, attrs[key]);
return node;
} else {
return new DOMParser().parseFromString(
'<svg xmlns="http://www.w3.org/2000/svg">' + str + '</svg>',
'text/xml');
}
} }

View file

@ -26,7 +26,6 @@ test('Circles', function() {
var rectangle = new Rectangle(topLeft, size); var rectangle = new Rectangle(topLeft, size);
var path = new Path.Ellipse(rectangle); var path = new Path.Ellipse(rectangle);
path.fillColor = 'black'; path.fillColor = 'black';
console.log('JSON', path.exportJSON());
var topLeft = new Point(5, 400); var topLeft = new Point(5, 400);
var size = new Size(100, 50); var size = new Size(100, 50);

View file

@ -18,380 +18,104 @@ test('Import complex CompoundPath and clone', function() {
equals(item, item.clone(), null, { cloned: true }); equals(item, item.clone(), null, { cloned: true });
}); });
test('make an svg line', function() { test('Import SVG line', function() {
var svgns = 'http://www.w3.org/2000/svg'; var attrs = {
var shape = document.createElementNS(svgns, 'line'); x1: 5,
var x1 = 5, x2: 45,
x2 = 45, y1: 5,
y1 = 5, y2: 45
y2 = 45; };
shape.setAttribute('x1', x1); var imported = paper.project.importSVG(createSVG('line', attrs));
shape.setAttribute('y1', y1); var path = new Path.Line([attrs.x1, attrs.y1], [attrs.x2, attrs.y2]);
shape.setAttribute('x2', x2); equals(imported, path);
shape.setAttribute('y2', y2);
var importedLine = paper.project.importSVG(shape);
var line = new Path.Line([x1, y1], [x2, y2]);
equals(importedLine, line);
}); });
test('make an svg line with invalid values', function() { test('Import SVG rect', function() {
var svgns = 'http://www.w3.org/2000/svg'; var attrs = {
var shape = document.createElementNS(svgns, 'line'); x: 25,
shape.setAttribute('x1', null); y: 25,
shape.setAttribute('y1', null); width: 100,
shape.setAttribute('x2', null); height: 100
shape.setAttribute('y2', null); };
var imported = paper.project.importSVG(createSVG('rect', attrs),
var importedLine = paper.project.importSVG(shape); { expandShapes: true });
var path = new Path.Rectangle(attrs);
var line = new Path.Line([0, 0], [0, 0]); equals(imported, path);
equals(importedLine, line);
}); });
test('compare rectangle values', function() { test('Import SVG round rect', function() {
var svgns = 'http://www.w3.org/2000/svg'; var attrs = {
var shape = document.createElementNS(svgns, 'rect'); x: 25,
var x = 25, y: 25,
y = 25, rx: 50,
width = 100, ry: 50,
height = 100; width: 100,
shape.setAttribute('x', x); height: 100
shape.setAttribute('y', y); };
shape.setAttribute('width', width); var imported = paper.project.importSVG(createSVG('rect', attrs),
shape.setAttribute('height', height); { expandShapes: true });
var path = new Path.Rectangle(new Rectangle(attrs),
var importedRectangle = paper.project.importSVG(shape); new Size(attrs.rx, attrs.ry));
equals(imported, path);
var topLeft = new Point(x, y);
var size = new Size(width, height);
var rectangle = new Rectangle(topLeft, size);
var realRectangle = new Shape.Rectangle(rectangle);
equals(importedRectangle, realRectangle);
}); });
test('Import SVG ellipse', function() {
test('compare negative rectangle values', function() { var attrs = {
var svgns = 'http://www.w3.org/2000/svg'; cx: 300,
var shape = document.createElementNS(svgns, 'rect'); cy: 80,
var x = -925, rx: 100,
y = -111, ry: 50
width = -100, }
height = -18; var imported = paper.project.importSVG(createSVG('ellipse', attrs),
shape.setAttribute('x', x); { expandShapes: true });
shape.setAttribute('y', y); var path = new Path.Ellipse({
shape.setAttribute('width', width); center: new Point(attrs.cx, attrs.cy),
shape.setAttribute('height', height); radius: new Point(attrs.rx, attrs.ry)
var importedRectangle = paper.project.importSVG(shape);
var topLeft = new Point(x, y);
var size = new Size(width, height);
var rectangle = new Rectangle(topLeft, size);
var realRectangle = new Shape.Rectangle(rectangle);
equals(importedRectangle, realRectangle);
});
test('compare invalid rectangle values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'rect');
shape.setAttribute('x', null);
shape.setAttribute('y', null);
shape.setAttribute('width', null);
shape.setAttribute('height', null);
var importedRectangle = paper.project.importSVG(shape);
var topLeft = new Point(0, 0);
var size = new Size(0, 0);
var rectangle = new Rectangle(topLeft, size);
var realRectangle = new Shape.Rectangle(rectangle);
equals(importedRectangle, realRectangle);
});
test('compare round rectangle values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'rect');
var x = 25,
y = 25,
rx = 50,
ry = 50,
width = 100,
height = 100;
shape.setAttribute('x', x);
shape.setAttribute('y', y);
shape.setAttribute('rx', rx);
shape.setAttribute('ry', ry);
shape.setAttribute('width', width);
shape.setAttribute('height', height);
var importedRectangle = paper.project.importSVG(shape);
var topLeft = new Point(x, y);
var size = new Size(width, height);
var cornerSize = new Size(rx, ry);
var rectangle = new Rectangle(topLeft, size);
var roundRect = new Shape.Rectangle(rectangle, cornerSize);
equals(importedRectangle, roundRect);
});
test('compare negative round rectangle values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'rect');
var x = -25,
y = -25,
rx = -50,
ry = -50,
width = -100,
height = -100;
shape.setAttribute('x', x);
shape.setAttribute('y', y);
shape.setAttribute('rx', rx);
shape.setAttribute('ry', ry);
shape.setAttribute('width', width);
shape.setAttribute('height', height);
var importedRectangle = paper.project.importSVG(shape);
var topLeft = new Point(x, y);
var size = new Size(width, height);
var cornerSize = new Size(rx, ry);
var rectangle = new Rectangle(topLeft, size);
var roundRect = new Shape.Rectangle(rectangle, cornerSize);
equals(importedRectangle, roundRect);
});
test('compare invalid round rectangle values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'rect');
var x = null,
y = null,
rx = null,
ry = null,
width = null,
height = null;
shape.setAttribute('x', x);
shape.setAttribute('y', y);
shape.setAttribute('rx', rx);
shape.setAttribute('ry', ry);
shape.setAttribute('width', width);
shape.setAttribute('height', height);
var importedRectangle = paper.project.importSVG(shape);
var topLeft = new Point(x, y);
var size = new Size(width, height);
var cornerSize = new Size(rx, ry);
var rectangle = new Rectangle(topLeft, size);
var roundRect = new Shape.Rectangle(rectangle, cornerSize);
equals(importedRectangle, roundRect);
});
test('compare ellipse values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'ellipse');
var cx = 300,
cy = 80,
rx = 100,
ry = 50;
shape.setAttribute('cx', cx);
shape.setAttribute('cy', cy);
shape.setAttribute('rx', rx);
shape.setAttribute('ry', ry);
var importedEllipse = paper.project.importSVG(shape);
var ellipse = new Shape.Ellipse({
center: new Point(cx, cy),
radius: new Point(rx, ry)
}); });
equals(imported, path);
equals(importedEllipse, ellipse);
}); });
test('compare negative ellipse values', function() { test('Import SVG circle', function() {
var svgns = 'http://www.w3.org/2000/svg'; var attrs = {
var shape = document.createElementNS(svgns, 'ellipse'); cx: 100,
var cx = -111, cy: 80,
cy = -2, r: 50
rx = -292, }
ry = -1; var imported = paper.project.importSVG(createSVG('circle', attrs),
shape.setAttribute('cx', cx); { expandShapes: true });
shape.setAttribute('cy', cy); var path = new Path.Circle({
shape.setAttribute('rx', rx); center: new Point(attrs.cx, attrs.cy),
shape.setAttribute('ry', ry); radius: attrs.r
var importedEllipse = paper.project.importSVG(shape);
var ellipse = new Shape.Ellipse({
center: new Point(cx, cy),
radius: new Point(rx, ry)
}); });
equals(imported, path);
equals(importedEllipse, ellipse);
}); });
test('compare invalid ellipse values', function() { function createPolyPath(str) {
var svgns = 'http://www.w3.org/2000/svg'; var points = str.split(' ').map(function(point) {
var shape = document.createElementNS(svgns, 'ellipse'); return point.split(',').map(parseFloat);
shape.setAttribute('cx', null);
shape.setAttribute('cy', null);
shape.setAttribute('rx', null);
shape.setAttribute('ry', null);
var importedEllipse = paper.project.importSVG(shape);
var ellipse = new Shape.Ellipse({
center: new Point(0, 0),
radius: new Point(0, 0)
}); });
var path = new Path();
path.moveTo(points[0]);
for (var i = 1; i < points.length; i++)
path.lineTo(points[i]);
return path;
}
equals(importedEllipse, ellipse); test('Import SVG polygon', function() {
var points = '100,10 40,180 190,60 10,60 160,180';
var imported = paper.project.importSVG(createSVG('polygon', {
points: points
}));
var path = createPolyPath(points);
path.closePath();
equals(imported, path);
}); });
test('compare circle values', function() { test('Import SVG polyline', function() {
var svgns = 'http://www.w3.org/2000/svg'; var points = "5,5 45,45 5,45 45,5";
var shape = document.createElementNS(svgns, 'circle'); var imported = paper.project.importSVG(createSVG('polyline', {
var cx = 100, points: points
cy = 80, }));
r = 50; var path = createPolyPath(points);
shape.setAttribute('cx', cx); equals(imported, path);
shape.setAttribute('cy', cy);
shape.setAttribute('r', r);
var importedCircle = paper.project.importSVG(shape);
var center = new Point(cx, cy);
var circle = new Shape.Circle(center, r);
equals(importedCircle, circle);
});
test('compare negative circle values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'circle');
var cx = -234,
cy = -77,
r = -1110;
shape.setAttribute('cx', cx);
shape.setAttribute('cy', cy);
shape.setAttribute('r', r);
var importedCircle = paper.project.importSVG(shape);
var center = new Point(cx, cy);
var circle = new Shape.Circle(center, r);
equals(importedCircle, circle);
});
test('compare invalid circle values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'circle');
shape.setAttribute('cx', null);
shape.setAttribute('cy', null);
shape.setAttribute('r', null);
var importedCircle = paper.project.importSVG(shape);
var center = new Point(0, 0);
var circle = new Shape.Circle(center, 0);
equals(importedCircle, circle);
});
test('compare polygon values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'polygon');
var svgpoints = "100,10 40,180 190,60 10,60 160,180";
shape.setAttribute('points', svgpoints);
var importedPolygon = paper.project.importSVG(shape);
var poly = new Path();
var points = shape.points;
poly.moveTo(points.getItem(0));
for (var i = 1; i < points.numberOfItems; i++) {
poly.lineTo(points.getItem(i));
}
if (shape.nodeName.toLowerCase() == 'polygon') {
poly.closePath();
}
equals(importedPolygon, poly);
});
test('compare negative polygon values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'polygon');
var svgpoints = "-100,-10 -40,-180 -190,-60 -10,-60 -160,-180";
shape.setAttribute('points', svgpoints);
var importedPolygon = paper.project.importSVG(shape);
var poly = new Path();
var points = shape.points;
poly.moveTo(points.getItem(0));
for (var i = 1; i < points.numberOfItems; i++) {
poly.lineTo(points.getItem(i));
}
if (shape.nodeName.toLowerCase() == 'polygon') {
poly.closePath();
}
equals(importedPolygon, poly);
});
test('compare polyline values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'polyline');
var svgpoints = "5,5 45,45 5,45 45,5";
shape.setAttribute('points', svgpoints);
var importedPolyline = paper.project.importSVG(shape);
var poly = new Path();
var points = shape.points;
poly.moveTo(points.getItem(0));
for (var i = 1; i < points.numberOfItems; i++) {
poly.lineTo(points.getItem(i));
}
if (shape.nodeName.toLowerCase() == 'polygon') {
poly.closePath();
}
equals(importedPolyline, poly);
});
test('compare negative polyline values', function() {
var svgns = 'http://www.w3.org/2000/svg';
var shape = document.createElementNS(svgns, 'polyline');
var svgpoints = "-5,-5 -45,-45 -5,-45 -45,-5";
shape.setAttribute('points', svgpoints);
var importedPolyline = paper.project.importSVG(shape);
var poly = new Path();
var points = shape.points;
poly.moveTo(points.getItem(0));
for (var i = 1; i < points.numberOfItems; i++) {
poly.lineTo(points.getItem(i));
}
if (shape.nodeName.toLowerCase() == 'polygon') {
poly.closePath();
}
equals(importedPolyline, poly);
}); });