paper.js/test/tests/Path.js

202 lines
4.9 KiB
JavaScript
Raw Normal View History

module('Path');
test('path.join(path)', function() {
var path = new Path();
path.add(0, 0);
path.add(10, 0);
var path2 = new Path();
path2.add(10, 0);
path2.add(20, 10);
path.join(path2);
equals(path.segments.toString(), '{ point: { x: 0, y: 0 } },{ point: { x: 10, y: 0 } },{ point: { x: 20, y: 10 } }');
equals(function() {
return paper.project.activeLayer.children.length;
}, 1);
var path = new Path();
path.add(0, 0);
path.add(10, 0);
var path2 = new Path();
path2.add(20, 10);
path2.add(10, 0);
path.join(path2);
equals(path.segments.toString(), '{ point: { x: 0, y: 0 } },{ point: { x: 10, y: 0 } },{ point: { x: 20, y: 10 } }');
var path = new Path();
path.add(0, 0);
path.add(10, 0);
var path2 = new Path();
path2.add(30, 10);
path2.add(40, 0);
path.join(path2);
equals(path.segments.toString(), '{ point: { x: 0, y: 0 } },{ point: { x: 10, y: 0 } },{ point: { x: 30, y: 10 } },{ point: { x: 40, y: 0 } }');
var path = new Path();
path.add(0, 0);
path.add(10, 0);
path.add(20, 10);
var path2 = new Path();
path2.add(0, 0);
path2.add(10, 5);
path2.add(20, 10);
path.join(path2);
equals(path.segments.toString(), '{ point: { x: 0, y: 0 } },{ point: { x: 10, y: 0 } },{ point: { x: 20, y: 10 } },{ point: { x: 10, y: 5 } }');
equals(function() {
return path.closed;
}, true);
});
test('path.remove()', function() {
var path = new Path();
path.add(0, 0);
path.add(10, 0);
path.add(20, 0);
path.add(30, 0);
path.removeSegment(0);
equals(function() {
return path.segments.length;
}, 3);
path.removeSegment(0);
equals(function() {
return path.segments.length;
}, 2);
path.removeSegments(0, 1);
equals(function() {
return path.segments.length;
}, 1);
path.remove();
equals(function() {
return paper.project.activeLayer.children.length;
}, 0);
});
test('path.removeSegments()', function() {
var path = new Path();
path.add(0, 0);
path.add(10, 0);
path.add(20, 0);
path.add(30, 0);
path.removeSegments();
equals(function() {
return path.segments.length;
}, 0);
});
2011-04-22 05:40:54 -04:00
test('Is the path deselected after setting a new list of segments?', function() {
var path = new Path([0, 0]);
path.selected = true;
equals(function() {
return path.selected;
}, true);
equals(function() {
return paper.project.selectedItems.length;
}, 1);
2011-04-22 05:52:24 -04:00
path.segments = [[0, 10]];
equals(function() {
return path.selected;
}, false);
equals(function() {
return paper.project.selectedItems.length;
}, 0);
2011-04-27 06:13:28 -04:00
});
2011-06-14 10:37:46 -04:00
test('After setting Path#fullySelected=true on an empty path, subsequent segments should be selected', function() {
2011-06-14 06:19:54 -04:00
var path = new Path();
2011-06-14 10:37:46 -04:00
path.fullySelected = true;
2011-06-14 06:19:54 -04:00
equals(function() {
2011-06-14 10:37:46 -04:00
return path.fullySelected;
2011-06-14 06:19:54 -04:00
}, true);
path.add([10, 10]);
equals(function() {
2011-06-14 10:37:46 -04:00
return path.fullySelected;
2011-06-14 06:19:54 -04:00
}, true);
equals(function() {
return path.firstSegment.selected;
}, true);
});
test('After simplifying a path using #pointToCurves(), the path should stay fullySelected', function() {
var path = new Path();
for (var i = 0; i < 30; i++) {
path.add(i * 10, 10);
};
path.fullySelected = true;
path.pointsToCurves();
equals(function() {
return path.fullySelected;
}, true);
});
test('After simplifying a path using #pointToCurves(), the path should stay selected', function() {
var path = new Path();
for (var i = 0; i < 30; i++) {
path.add(i * 10, (i % 2 ? 20 : 40));
};
path.selected = true;
path.pointsToCurves();
equals(function() {
return path.selected;
}, true);
});
test('After smoothing a path using #smooth(), the path should stay fullySelected', function() {
var path = new Path();
for (var i = 0; i < 30; i++) {
path.add(i * 10, (i % 2 ? 20 : 40));
};
path.fullySelected = true;
path.smooth();
equals(function() {
return path.fullySelected;
}, true);
});
test('After smoothing a path using #smooth(), the path should stay selected', function() {
var path = new Path();
for (var i = 0; i < 30; i++) {
path.add(i * 10, (i % 2 ? 20 : 40));
};
path.selected = true;
path.smooth();
equals(function() {
2011-06-20 10:59:51 -04:00
return path.selected;
}, true);
});
test('After selecting a segment, Path#selected should return true', function() {
var path = new Path();
path.add([10, 10]);
path.firstSegment.selected = true;
equals(function() {
return path.selected;
}, true);
});
2011-04-27 06:13:28 -04:00
test('Path#reverse', function() {
var path = new Path.Circle([100, 100], 30);
path.reverse();
equals(path.segments.toString(), '{ point: { x: 100, y: 130 }, handleIn: { x: -16.56854, y: 0 }, handleOut: { x: 16.56854, y: 0 } },{ point: { x: 130, y: 100 }, handleIn: { x: 0, y: 16.56854 }, handleOut: { x: 0, y: -16.56854 } },{ point: { x: 100, y: 70 }, handleIn: { x: 16.56854, y: 0 }, handleOut: { x: -16.56854, y: 0 } },{ point: { x: 70, y: 100 }, handleIn: { x: 0, y: -16.56854 }, handleOut: { x: 0, y: 16.56854 } }');
2011-04-27 06:13:28 -04:00
});
test('Path#fullySelected', function() {
var path = new Path.Circle([100, 100], 10);
2011-06-14 10:37:46 -04:00
path.fullySelected = true;
path.segments[1].selected = false;
equals(function() {
return path.fullySelected;
}, false);
});