mediawiki-extensions-Visual.../modules/ve/test/ce/ve.ce.NodeFactory.test.js
Trevor Parscal 8d33a3de0d Major Documentation Cleanup
* Made method descriptions imperative: "Do this" rather than "Does this"
* Changed use of "this object" to "the object" in method documentation
* Added missing documentation
* Fixed incorrect documentation
* Fixed incorrect debug method names (as in those VeDmClassName tags we add to functions so they make sense when dumped into in the console)
* Normalized use of package names throughout
* Normalized class descriptions
* Removed incorrect @abstract tags
* Added missing @method tags
* Lots of other minor cleanup

Change-Id: I4ea66a2dd107613e2ea3a5f56ff54d675d72957e
2013-01-16 15:37:59 -08:00

46 lines
1.1 KiB
JavaScript

/*!
* VisualEditor ContentEditable NodeFactory tests.
*
* @copyright 2011-2012 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
QUnit.module( 've.ce.NodeFactory' );
/* Stubs */
ve.ce.NodeFactoryNodeStub = function VeCeNodeFactoryNodeStub( a, b ) {
this.a = a;
this.b = b;
};
ve.inheritClass( ve.ce.NodeFactoryNodeStub, ve.ce.LeafNode );
ve.ce.NodeFactoryNodeStub.rules = {
'canBeSplit': false
};
/* Tests */
QUnit.test( 'canNodeBeSplit', 2, function ( assert ) {
var factory = new ve.ce.NodeFactory();
assert.throws( function () {
factory.canNodeBeSplit( 'node-factory-node-stub' );
},
Error,
'throws an exception when getting split rules for a node of an unregistered type'
);
factory.register( 'node-factory-node-stub', ve.ce.NodeFactoryNodeStub );
assert.strictEqual(
factory.canNodeBeSplit( 'node-factory-node-stub' ),
false,
'gets split rules for registered nodes'
);
} );
QUnit.test( 'initialization', 1, function ( assert ) {
assert.ok( ve.ce.nodeFactory instanceof ve.ce.NodeFactory, 'factory is initialized at ve.ce.nodeFactory' );
} );