mediawiki-extensions-Visual.../modules/ve/test/ce/ve.ce.Document.test.js
Roan Kattouw 904abe74c8 Create CE nodes and annotations with the correct $$
Most of CE wasn't passing through $$ at all. Also fix CE tests that
weren't passing the required surface parameter to the ce.Document
constructor.

Change-Id: Ia234f174050f4b2666ec20e8acc24c6aa4305202
2013-10-28 15:48:51 +00:00

177 lines
3.8 KiB
JavaScript

/*!
* VisualEditor ContentEditable Document tests.
*
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
QUnit.module( 've.ce.Document' );
/* Tests */
QUnit.test( 'getRelativeOffset', function ( assert ) {
var documentModel = ve.dm.example.createExampleDocument( 'alienData' ),
surface = ve.test.utils.createSurfaceFromDocument( documentModel ),
documentView = surface.getView().getDocument(),
tests = [
{
direction: 1,
unit: 'character',
cases: [
{ input: 0, output: 3 },
{ input: 3, output: 4 },
{ input: 4, output: 6 },
{ input: 6, output: 7 },
{ input: 7, output: 10 }
]
},
{
direction: 1,
unit: 'word',
cases: [
{ input: 0, output: 3 },
{ input: 3, output: 4 },
{ input: 4, output: 6 },
{ input: 6, output: 7 },
{ input: 7, output: 10 }
]
},
{
direction: -1,
unit: 'character',
cases: [
{ input: 10, output: 7 },
{ input: 7, output: 6 },
{ input: 6, output: 4 },
{ input: 4, output: 3 },
{ input: 3, output: 0 }
]
},
{
direction: -1,
unit: 'word',
cases: [
{ input: 10, output: 7 },
{ input: 7, output: 6 },
{ input: 6, output: 4 },
{ input: 4, output: 3 },
{ input: 3, output: 0 }
]
}
], i, j, expectCount = 0;
for ( i = 0; i < tests.length; i++ ) {
for ( j = 0; j < tests[i].cases.length; j++ ) {
assert.equal(
documentView.getRelativeOffset(
tests[i].cases[j].input,
tests[i].direction,
tests[i].unit
),
tests[i].cases[j].output
);
}
expectCount += tests[i].cases.length;
}
QUnit.expect( expectCount );
surface.destroy();
} );
QUnit.test( 'getRelativeRange', function ( assert ) {
var documentModel, surface, documentView, i, j, expectCount = 0,
tests = [
{
data: [
/* 0 */ { type: 'paragraph' },
/* 1 */ 'a',
/* 2 */ { type: 'image' },
/* 3 */ { type: '/image' },
/* 4 */ 'b',
/* 5 */ { type: '/paragraph' }
],
cases: [
{
direction: 1,
expand: false,
given: new ve.Range( 1 ),
expected: new ve.Range( 2 )
},
{
direction: 1,
expand: false,
given: new ve.Range( 2 ),
expected: new ve.Range( 2, 4 )
},
{
direction: 1,
expand: false,
given: new ve.Range( 2, 4 ),
expected: new ve.Range( 4 )
},
{
direction: 1,
expand: true,
given: new ve.Range( 1 ),
expected: new ve.Range( 1, 2 )
},
{
direction: 1,
expand: true,
given: new ve.Range( 1, 2 ),
expected: new ve.Range( 1, 4 )
},
{
direction: 1,
expand: true,
given: new ve.Range( 1, 4 ),
expected: new ve.Range( 1, 5 )
}
]
},
{
data: [
/* 0 */ { type: 'paragraph' },
/* 1 */ { type: 'image' },
/* 2 */ { type: '/image' },
/* 3 */ { type: 'image' },
/* 4 */ { type: '/image' },
/* 5 */ { type: '/paragraph' }
],
cases: [
{
direction: 1,
expand: false,
given: new ve.Range( 3 ),
expected: new ve.Range( 3, 5 )
},
{
direction: 1,
expand: true,
given: new ve.Range( 1, 3 ),
expected: new ve.Range( 1, 5 )
}
]
}
];
for ( i = 0; i < tests.length; i++ ) {
documentModel = new ve.dm.Document( tests[i].data );
surface = ve.test.utils.createSurfaceFromDocument( documentModel );
documentView = surface.getView().getDocument();
for ( j = 0; j < tests[i].cases.length; j++ ) {
expectCount++;
assert.equalRange(
documentView.getRelativeRange(
tests[i].cases[j].given,
tests[i].cases[j].direction,
'character',
tests[i].cases[j].expand
),
tests[i].cases[j].expected,
'i: ' + i + ', j: ' + j
);
}
surface.destroy();
}
QUnit.expect( expectCount );
} );