/*! * VisualEditor ContentEditable tests. * * @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt * @license The MIT License (MIT); see LICENSE.txt */ QUnit.module( 've.ce' ); /* Tests */ QUnit.test( 'whitespacePattern', 4, function ( assert ) { assert.equal( 'a b'.match( ve.ce.whitespacePattern ), ' ', 'matches spaces' ); assert.equal( 'a\u00A0b'.match( ve.ce.whitespacePattern ), '\u00A0', 'matches non-breaking spaces' ); assert.equal( 'a\tb'.match( ve.ce.whitespacePattern ), null, 'does not match tab' ); assert.equal( 'ab'.match( ve.ce.whitespacePattern ), null, 'does not match non-whitespace' ); } ); QUnit.test( 'getDomText', 1, function ( assert ) { assert.equal( ve.ce.getDomText( $( 'abcd' )[0] ), 'abcd' ); } ); QUnit.test( 'getDomHash', 1, function ( assert ) { assert.equal( ve.ce.getDomHash( $( 'abcd' )[0] ), '####' ); } ); QUnit.test( 'getOffsetFrom(Element|Text)Node', function ( assert ) { var i, dom, target, surface, documentModel, documentView, expected = 0, testCases = [ { 'msg': 'Annotated alien', 'html': '

FooBarBaz

', // CE html summary; //

FooBarBaz

'expected': [ 0, 1, 1, 2, 3, 4, 4, 4, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 7, 8, 9, 9, 10 ] } ]; for( i = 0; i < testCases.length; i++ ) { expected += testCases[i].expected.length; } QUnit.expect( expected ); function testOffsets( parent, testCase, expectedIndex ) { var i; switch ( parent.nodeType ) { case Node.ELEMENT_NODE: for ( i = 0; i <= parent.childNodes.length; i++ ) { expectedIndex++; assert.equal( ve.ce.getOffsetFromElementNode( parent, i ), testCase.expected[expectedIndex], testCase.msg + ': offset ' + i + ' in <' + parent.nodeName.toLowerCase() + '>' ); if ( parent.childNodes[i] ) { expectedIndex = testOffsets( parent.childNodes[i], testCase, expectedIndex ); } } break; case Node.TEXT_NODE: for ( i = 0; i <= parent.data.length; i++ ) { expectedIndex++; assert.equal( ve.ce.getOffsetFromTextNode( parent, i ), testCase.expected[expectedIndex], testCase.msg + ': offset ' + i + ' in "' + parent.data + '"' ); } break; } return expectedIndex; } for( i = 0; i < testCases.length; i++ ) { dom = ve.createDocumentFromHtml( testCases[i].html ); target = new ve.init.sa.Target( $( '#qunit-fixture' ), dom ); surface = target.surface; documentModel = surface.getModel().getDocument(); documentView = surface.getView().getDocument(); testOffsets( documentView.documentNode.$[0], testCases[i], -1 ); } } );