mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-25 14:56:20 +00:00
46 lines
2.2 KiB
JavaScript
46 lines
2.2 KiB
JavaScript
|
module( 've' );
|
||
|
|
||
|
test( 've.Node.getCommonAncestorPaths', 14, function() {
|
||
|
var documentModel = ve.dm.DocumentNode.newFromPlainObject( veTest.obj ), result;
|
||
|
|
||
|
var list = documentModel.children[1].children[0].children[0].children[1];
|
||
|
result = ve.Node.getCommonAncestorPaths( list, list );
|
||
|
// Test 1
|
||
|
ok( result.commonAncestor == list, 'same nodes (commonAncestor)' );
|
||
|
// Test 2
|
||
|
ok( ve.compareArrays( result.node1Path, [] ), 'adjacent list items (node1Path)' );
|
||
|
// Test 3
|
||
|
ok( ve.compareArrays( result.node2Path, [] ), 'adjacent list items (node2Path)' );
|
||
|
|
||
|
result = ve.Node.getCommonAncestorPaths( list.children[0], list.children[1] );
|
||
|
// Test 4
|
||
|
ok( result.commonAncestor == list, 'adjacent list items (commonAncestor)' );
|
||
|
// Test 5
|
||
|
ok( ve.compareArrays( result.node1Path, [ list.children[0] ] ), 'adjacent list items (node1Path)' );
|
||
|
// Test 6
|
||
|
ok( ve.compareArrays( result.node2Path, [ list.children[1] ] ), 'adjacent list items (node2Path)' );
|
||
|
|
||
|
result = ve.Node.getCommonAncestorPaths( list.children[0], list.children[2] );
|
||
|
// Test 7
|
||
|
ok( result.commonAncestor == list, 'non-adjacent sibling list items (commonAncestor)' );
|
||
|
// Test 8
|
||
|
ok( ve.compareArrays( result.node1Path, [ list.children[0] ] ), 'non-adjacent sibling list items (node1Path)' );
|
||
|
// Test 9
|
||
|
ok( ve.compareArrays( result.node2Path, [ list.children[2] ] ), 'non-adjacent sibling list items (node2Path)' );
|
||
|
|
||
|
result = ve.Node.getCommonAncestorPaths( list.children[0].children[0], list.children[2].children[0] );
|
||
|
// Test 10
|
||
|
ok( result.commonAncestor == list, 'paragraphs inside list items (commonAncestor)' );
|
||
|
// Test 11
|
||
|
ok( ve.compareArrays( result.node1Path, [ list.children[0].children[0], list.children[0] ] ), 'paragraphs inside list items (node1Path)' );
|
||
|
// Test 12
|
||
|
ok( ve.compareArrays( result.node2Path, [ list.children[2].children[0], list.children[2] ] ), 'paragraphs inside list items (node2Path)' );
|
||
|
|
||
|
result = ve.Node.getCommonAncestorPaths( list.children[0].children[0], list.children[2] );
|
||
|
// Test 13
|
||
|
equal( result, false, 'nodes of unequal depth' );
|
||
|
|
||
|
result = ve.Node.getCommonAncestorPaths( list, ve.dm.DocumentNode.newFromPlainObject( veTest.obj ).children[1] );
|
||
|
// Test 14
|
||
|
equal( result, false, 'nodes in different trees' );
|
||
|
} );
|