2011-12-11 13:13:43 -03:00
|
|
|
mindplot.nlayout.TestSuite = new Class({
|
|
|
|
Extends: mindplot.nlayout.ChildrenSorterStrategy,
|
|
|
|
initialize:function() {
|
2011-12-11 23:47:01 -03:00
|
|
|
this.testAligned();
|
2011-12-30 17:48:11 -03:00
|
|
|
this.testSymmetry();
|
2012-01-02 17:10:14 -03:00
|
|
|
this.testGrid();
|
2011-12-11 13:13:43 -03:00
|
|
|
this.testEvents();
|
2011-12-11 23:47:01 -03:00
|
|
|
this.testEventsComplex();
|
|
|
|
this.testDisconnect();
|
2012-01-04 14:37:58 -03:00
|
|
|
this.testReconnect();
|
2011-12-11 23:47:01 -03:00
|
|
|
this.testRemoveNode();
|
2011-12-11 13:13:43 -03:00
|
|
|
},
|
|
|
|
|
|
|
|
testAligned: function() {
|
|
|
|
|
2011-12-30 17:48:11 -03:00
|
|
|
var size = {width:25,height:25};
|
2011-12-11 13:13:43 -03:00
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
manager.addNode(1, size, position);
|
2012-01-02 17:10:14 -03:00
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
2011-12-11 13:13:43 -03:00
|
|
|
manager.connectNode(0, 1, 0);
|
2012-01-02 17:10:14 -03:00
|
|
|
manager.connectNode(1, 2, 0);
|
|
|
|
manager.connectNode(2, 3, 0);
|
|
|
|
manager.connectNode(3, 4, 0);
|
2011-12-11 13:13:43 -03:00
|
|
|
|
|
|
|
manager.layout();
|
|
|
|
manager.dump();
|
2012-01-02 17:10:14 -03:00
|
|
|
manager.plot("testAligned", {w:300,h:200});
|
2011-12-30 15:28:03 -03:00
|
|
|
|
2012-01-04 14:37:58 -03:00
|
|
|
// All nodes should be vertically aligned
|
2012-01-02 17:10:14 -03:00
|
|
|
$assert(manager.find(0).getPosition().y == manager.find(1).getPosition().y, "Nodes are not aligned");
|
|
|
|
$assert(manager.find(0).getPosition().y == manager.find(2).getPosition().y, "Nodes are not aligned");
|
|
|
|
$assert(manager.find(0).getPosition().y == manager.find(3).getPosition().y, "Nodes are not aligned");
|
|
|
|
$assert(manager.find(0).getPosition().y == manager.find(4).getPosition().y, "Nodes are not aligned");
|
2011-12-30 17:48:11 -03:00
|
|
|
},
|
|
|
|
|
|
|
|
testSymmetry: function() {
|
|
|
|
var size = {width:25,height:25};
|
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
manager.addNode(5, size, position);
|
|
|
|
manager.addNode(6, size, position);
|
|
|
|
manager.addNode(7, size, position);
|
|
|
|
manager.addNode(8, size, position);
|
|
|
|
manager.addNode(9, size, position);
|
|
|
|
manager.addNode(10, size, position);
|
2012-01-02 17:10:14 -03:00
|
|
|
manager.addNode(11, size, position);
|
|
|
|
manager.addNode(12, size, position);
|
2012-01-04 14:37:58 -03:00
|
|
|
manager.addNode(13, size, position);
|
|
|
|
manager.addNode(14, size, position);
|
|
|
|
manager.connectNode(0, 14, 0);
|
|
|
|
manager.connectNode(14, 13, 0);
|
|
|
|
manager.connectNode(13, 1, 0);
|
|
|
|
manager.connectNode(13, 2, 1);
|
|
|
|
manager.connectNode(13, 3, 2);
|
|
|
|
manager.connectNode(13, 4, 3);
|
|
|
|
manager.connectNode(13, 5, 4);
|
2012-01-02 17:10:14 -03:00
|
|
|
manager.connectNode(1, 6, 0);
|
|
|
|
manager.connectNode(1, 7, 1);
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.connectNode(7, 8, 0);
|
|
|
|
manager.connectNode(8, 9, 0);
|
2012-01-02 17:10:14 -03:00
|
|
|
manager.connectNode(5, 10, 0);
|
|
|
|
manager.connectNode(6, 11, 0);
|
|
|
|
manager.connectNode(6, 12, 1);
|
2011-12-30 17:48:11 -03:00
|
|
|
|
|
|
|
manager.layout();
|
2012-01-04 14:37:58 -03:00
|
|
|
manager.dump();
|
|
|
|
manager.plot("testSymmetry",{w:500, h:300});
|
2012-01-02 17:10:14 -03:00
|
|
|
|
|
|
|
//TODO(gb): make asserts
|
|
|
|
},
|
|
|
|
|
|
|
|
testGrid: function() {
|
|
|
|
var size = {width:25,height:25};
|
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.connectNode(0, 1, 0);
|
|
|
|
manager.layout();
|
|
|
|
manager.plot("testGrid1");
|
|
|
|
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.connectNode(0, 2, 1);
|
|
|
|
manager.layout();
|
|
|
|
manager.plot("testGrid2");
|
|
|
|
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.connectNode(0, 3, 2);
|
|
|
|
manager.layout();
|
|
|
|
manager.plot("testGrid3");
|
|
|
|
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
manager.connectNode(0, 4, 3);
|
|
|
|
manager.layout();
|
|
|
|
manager.plot("testGrid4");
|
|
|
|
|
|
|
|
manager.addNode(5, size, position);
|
|
|
|
manager.addNode(6, size, position);
|
|
|
|
manager.addNode(7, size, position);
|
|
|
|
manager.connectNode(2, 5, 0);
|
|
|
|
manager.connectNode(2, 6, 1);
|
|
|
|
manager.connectNode(6, 7, 0);
|
|
|
|
manager.layout();
|
|
|
|
manager.plot("testGrid5", {w:300, h:300});
|
|
|
|
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.dump();
|
|
|
|
|
2012-01-02 17:10:14 -03:00
|
|
|
//TODO(gb): make asserts
|
2011-12-11 13:13:43 -03:00
|
|
|
},
|
|
|
|
|
|
|
|
testEvents: function() {
|
2011-12-30 17:48:11 -03:00
|
|
|
var size = {width:25,height:25};
|
2011-12-11 13:13:43 -03:00
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
// Add 3 nodes...
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
|
|
|
|
// Now connect one with two....
|
|
|
|
manager.connectNode(0, 1, 0);
|
|
|
|
manager.connectNode(0, 2, 0);
|
|
|
|
manager.connectNode(1, 3, 0);
|
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
// Basic layout repositioning ...
|
|
|
|
console.log("-- Updated tree ---");
|
|
|
|
var events = [];
|
|
|
|
manager.addEvent('change', function(event) {
|
|
|
|
console.log("Updated nodes: {id:" + event.getId() + ", order: " + event.getOrder() + ",position: {" + event.getPosition().x + "," + event.getPosition().y + "}");
|
|
|
|
events.push(event);
|
|
|
|
});
|
|
|
|
manager.layout(true);
|
2011-12-11 13:13:43 -03:00
|
|
|
manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testEvents1");
|
2011-12-11 13:13:43 -03:00
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
// Ok, if a new node is added, this an event should be fired ...
|
|
|
|
console.log("---- Layout without changes should not affect the tree ---");
|
|
|
|
events.empty();
|
|
|
|
manager.layout(true);
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testEvents2");
|
2011-12-11 23:47:01 -03:00
|
|
|
|
|
|
|
$assert(events.length == 0, "Unnecessary tree updated.");
|
|
|
|
},
|
|
|
|
|
|
|
|
testEventsComplex: function() {
|
2011-12-30 17:48:11 -03:00
|
|
|
var size = {width:25,height:25};
|
2011-12-11 23:47:01 -03:00
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
// Add 3 nodes...
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
|
|
|
|
// Now connect one with two....
|
|
|
|
manager.connectNode(0, 1, 0);
|
|
|
|
manager.connectNode(1, 2, 0);
|
|
|
|
manager.connectNode(1, 3, 1);
|
|
|
|
|
2011-12-11 13:13:43 -03:00
|
|
|
var events = [];
|
|
|
|
manager.addEvent('change', function(event) {
|
|
|
|
console.log("Updated nodes: {id:" + event.getId() + ", order: " + event.getOrder() + ",position: {" + event.getPosition().x + "," + event.getPosition().y + "}");
|
|
|
|
events.push(event);
|
|
|
|
});
|
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
// Reposition ...
|
|
|
|
manager.layout(true);
|
|
|
|
manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testEventsComplex1");
|
2011-12-11 23:47:01 -03:00
|
|
|
|
|
|
|
// Add a new node and connect. Only children nodes should be affected.
|
|
|
|
console.log("---- Connect a new node ---");
|
2011-12-11 13:13:43 -03:00
|
|
|
|
|
|
|
events.empty();
|
2011-12-11 23:47:01 -03:00
|
|
|
manager.connectNode(1, 4, 2);
|
|
|
|
manager.layout(true);
|
|
|
|
manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testEventsComplex2");
|
2011-12-11 13:13:43 -03:00
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
// @todo: This seems no to be ok...
|
|
|
|
$assert(events.length == 4, "Only 3 nodes should be repositioned.");
|
|
|
|
},
|
|
|
|
|
|
|
|
testDisconnect: function() {
|
2011-12-30 17:48:11 -03:00
|
|
|
var size = {width:25,height:25};
|
2011-12-11 23:47:01 -03:00
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
// Prepare a sample graph ...
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
|
|
|
|
manager.connectNode(0, 1, 0);
|
|
|
|
manager.connectNode(1, 2, 0);
|
|
|
|
manager.connectNode(1, 3, 1);
|
|
|
|
manager.connectNode(3, 4, 0);
|
|
|
|
|
|
|
|
var events = [];
|
|
|
|
manager.addEvent('change', function(event) {
|
2012-01-04 14:37:58 -03:00
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
var pos = event.getPosition();
|
2012-01-04 14:37:58 -03:00
|
|
|
var posStr = pos ? ",position: {" + pos.x + "," + pos.y : "";
|
|
|
|
var node = manager.find(event.getId());
|
2011-12-11 23:47:01 -03:00
|
|
|
console.log("Updated nodes: {id:" + event.getId() + ", order: " + event.getOrder() + posStr + "}");
|
|
|
|
events.push(event);
|
|
|
|
});
|
|
|
|
manager.layout(true);
|
2012-01-04 14:37:58 -03:00
|
|
|
// manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testDisconnect1", {w:300, h:200});
|
2011-12-11 23:47:01 -03:00
|
|
|
|
|
|
|
// Now, disconnect one node ...
|
|
|
|
console.log("--- Disconnect a single node ---");
|
2011-12-11 13:13:43 -03:00
|
|
|
events.empty();
|
2011-12-11 23:47:01 -03:00
|
|
|
manager.disconnectNode(2);
|
2011-12-11 13:13:43 -03:00
|
|
|
manager.layout(true);
|
2012-01-04 14:37:58 -03:00
|
|
|
// manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testDisconnect2", {w:300, h:200});
|
2011-12-11 13:13:43 -03:00
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
$assert(events.some(
|
|
|
|
function(event) {
|
|
|
|
return event.getId() == 2;
|
|
|
|
}), "Event for disconnected node seems not to be propagated");
|
|
|
|
|
|
|
|
// Great, let's disconnect a not with children.
|
|
|
|
console.log("--- Disconnect a node with children ---");
|
|
|
|
manager.disconnectNode(3);
|
|
|
|
manager.layout(true);
|
2012-01-04 14:37:58 -03:00
|
|
|
// manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testDisconnect3", {w:300, h:200});
|
2011-12-11 23:47:01 -03:00
|
|
|
|
|
|
|
$assert(events.some(
|
|
|
|
function(event) {
|
|
|
|
return event.getId() == 2;
|
|
|
|
}), "Event for disconnected node seems not to be propagated");
|
|
|
|
},
|
|
|
|
|
2012-01-04 14:37:58 -03:00
|
|
|
testReconnect: function() {
|
|
|
|
var size = {width:25,height:25};
|
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
manager.addNode(5, size, position);
|
|
|
|
manager.addNode(6, size, position);
|
|
|
|
manager.addNode(7, size, position);
|
|
|
|
manager.addNode(8, size, position);
|
|
|
|
manager.addNode(9, size, position);
|
|
|
|
manager.addNode(10, size, position);
|
|
|
|
manager.addNode(11, size, position);
|
|
|
|
manager.addNode(12, size, position);
|
|
|
|
manager.connectNode(0, 1, 0);
|
|
|
|
manager.connectNode(0, 2, 1);
|
|
|
|
manager.connectNode(0, 3, 2);
|
|
|
|
manager.connectNode(0, 4, 3);
|
|
|
|
manager.connectNode(0, 5, 4);
|
|
|
|
manager.connectNode(1, 6, 0);
|
|
|
|
manager.connectNode(1, 7, 1);
|
|
|
|
manager.connectNode(7, 8, 0);
|
|
|
|
manager.connectNode(8, 9, 0);
|
|
|
|
manager.connectNode(5, 10, 0);
|
|
|
|
manager.connectNode(6, 11, 0);
|
|
|
|
manager.connectNode(6, 12, 1);
|
|
|
|
|
|
|
|
manager.layout();
|
|
|
|
manager.dump();
|
|
|
|
manager.plot("testReconnect1",{w:400, h:300});
|
|
|
|
|
|
|
|
// Reconnect node 6 to node 4
|
|
|
|
manager.disconnectNode(6);
|
|
|
|
manager.connectNode(4,6,0);
|
|
|
|
manager.layout();
|
|
|
|
manager.dump();
|
|
|
|
manager.plot("testReconnect2",{w:400, h:300});
|
|
|
|
|
|
|
|
//TODO(gb): make asserts
|
|
|
|
},
|
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
testRemoveNode: function() {
|
2011-12-30 17:48:11 -03:00
|
|
|
var size = {width:25,height:25};
|
2011-12-11 23:47:01 -03:00
|
|
|
var position = {x:0,y:0};
|
|
|
|
var manager = new mindplot.nlayout.LayoutManager(0, size);
|
|
|
|
|
|
|
|
// Prepare a sample graph ...
|
|
|
|
manager.addNode(1, size, position);
|
|
|
|
manager.addNode(2, size, position);
|
|
|
|
manager.addNode(3, size, position);
|
|
|
|
manager.addNode(4, size, position);
|
|
|
|
|
|
|
|
manager.connectNode(0, 1, 0);
|
|
|
|
manager.connectNode(1, 2, 0);
|
|
|
|
manager.connectNode(1, 3, 1);
|
|
|
|
manager.connectNode(3, 4, 0);
|
|
|
|
|
|
|
|
var events = [];
|
|
|
|
manager.addEvent('change', function(event) {
|
|
|
|
var pos = event.getPosition();
|
|
|
|
var posStr = pos ? ",position: {" + pos.x + "," + event.getPosition().y : "";
|
|
|
|
console.log("Updated nodes: {id:" + event.getId() + ", order: " + event.getOrder() + posStr + "}");
|
|
|
|
events.push(event);
|
|
|
|
});
|
|
|
|
manager.layout(true);
|
|
|
|
manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testRemoveNode1", {w:300, h:200});
|
2011-12-11 23:47:01 -03:00
|
|
|
|
|
|
|
// Test removal of a connected node ...
|
|
|
|
console.log("--- Remove node 3 ---");
|
|
|
|
manager.removeNode(3);
|
|
|
|
manager.layout(true);
|
|
|
|
manager.dump();
|
2011-12-30 17:48:11 -03:00
|
|
|
manager.plot("testRemoveNode2");
|
2011-12-11 13:13:43 -03:00
|
|
|
}
|
|
|
|
|
2011-12-11 23:47:01 -03:00
|
|
|
|
2011-12-11 13:13:43 -03:00
|
|
|
});
|
|
|
|
|