mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-29 08:34:54 +00:00
edcaaf9edc
Add a static.name property to ce nodes and make sure both ce and dm nodes always use the static.name property in constructors and registration calls. The result of this is that any given node type should now only appear once in the code as a string. Bug: 45701 Change-Id: Ibf31de16ab28ad58209c1443cd74f93dda278998
93 lines
2.6 KiB
JavaScript
93 lines
2.6 KiB
JavaScript
/*!
|
|
* VisualEditor ContentEditable BranchNode tests.
|
|
*
|
|
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
QUnit.module( 've.ce.BranchNode' );
|
|
|
|
/* Stubs */
|
|
|
|
ve.ce.BranchNodeStub = function VeCeBranchNodeStub( model, $element ) {
|
|
// Parent constructor
|
|
ve.ce.BranchNode.call( this, model, $element );
|
|
};
|
|
|
|
ve.inheritClass( ve.ce.BranchNodeStub, ve.ce.BranchNode );
|
|
|
|
ve.ce.BranchNodeStub.static.name = 'branch-stub';
|
|
|
|
ve.ce.BranchNodeStub.static.canBeSplit = true;
|
|
|
|
ve.ce.BranchNodeStub.domWrapperElementTypes = {
|
|
'a': 'a',
|
|
'b': 'b'
|
|
};
|
|
|
|
ve.ce.nodeFactory.register( ve.ce.BranchNodeStub );
|
|
|
|
/* Tests */
|
|
|
|
QUnit.test( 'canBeSplit', 1, function ( assert ) {
|
|
var node = new ve.ce.BranchNodeStub( new ve.dm.BranchNodeStub() );
|
|
|
|
assert.equal( node.canBeSplit(), true );
|
|
} );
|
|
|
|
QUnit.test( 'canHaveChildren', 1, function ( assert ) {
|
|
var node = new ve.ce.BranchNodeStub( new ve.dm.BranchNodeStub() );
|
|
|
|
assert.equal( node.canHaveChildren(), true );
|
|
} );
|
|
|
|
QUnit.test( 'canHaveGrandchildren', 1, function ( assert ) {
|
|
var node = new ve.ce.BranchNodeStub( new ve.dm.BranchNodeStub() );
|
|
|
|
assert.equal( node.canHaveGrandchildren(), true );
|
|
} );
|
|
|
|
QUnit.test( 'updateDomWrapper', 3, function ( assert ) {
|
|
var attributes = { 'style': 'a' },
|
|
node = new ve.ce.BranchNodeStub( new ve.dm.BranchNodeStub( [], {
|
|
'type': 'branch-stub', 'attributes': attributes
|
|
} ) );
|
|
|
|
// Add classes and content to the node
|
|
node.$.addClass( 'test' ).text( 'hello' );
|
|
|
|
// Modify attribute
|
|
attributes.style = 'b';
|
|
node.updateDomWrapper( 'style' );
|
|
|
|
assert.equal( node.$.get( 0 ).nodeName.toLowerCase(), 'b', 'DOM element type gets converted' );
|
|
assert.equal( node.$.hasClass( 'test' ), true, 'old classes are added to new wrapper' );
|
|
assert.equal( node.$.text(), 'hello', 'contents are added to new wrapper' );
|
|
} );
|
|
|
|
QUnit.test( 'onSplice', 7, function ( assert ) {
|
|
var modelA = new ve.dm.BranchNodeStub(),
|
|
modelB = new ve.dm.BranchNodeStub(),
|
|
modelC = new ve.dm.BranchNodeStub(),
|
|
viewA = new ve.ce.BranchNodeStub( modelA );
|
|
|
|
// Insertion tests
|
|
modelA.splice( 0, 0, modelB, modelC );
|
|
|
|
assert.equal( viewA.getChildren().length, 2 );
|
|
assert.deepEqual( viewA.getChildren()[0].getModel(), modelB );
|
|
assert.deepEqual( viewA.getChildren()[1].getModel(), modelC );
|
|
|
|
// Removal tests
|
|
modelA.splice( 0, 1 );
|
|
|
|
assert.equal( viewA.getChildren().length, 1 );
|
|
assert.deepEqual( viewA.getChildren()[0].getModel(), modelC );
|
|
|
|
// Removal and insertion tests
|
|
modelA.splice( 0, 1, modelB );
|
|
|
|
assert.equal( viewA.getChildren().length, 1 );
|
|
assert.deepEqual( viewA.getChildren()[0].getModel(), modelB );
|
|
} );
|