mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-03 18:36:20 +00:00
ef0e4b4973
Also updated tests to use the new assert as an argument style Change-Id: I3c82b4b068134bba755ae4a5c26f5bb98d400c43
285 lines
8.2 KiB
JavaScript
285 lines
8.2 KiB
JavaScript
/**
|
|
* VisualEditor content editable TextNode tests.
|
|
*
|
|
* @copyright 2011-2012 VisualEditor Team and others; see AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
module( 've.ce.TextNode' );
|
|
|
|
/* Tests */
|
|
|
|
test( 'getHtml', 22, function( assert ) {
|
|
var cases = [
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
'a',
|
|
'b',
|
|
'c',
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': 'abc'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
['a', { '{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' } }],
|
|
['b', { '{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' } }],
|
|
['c', { '{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' } }],
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': '<b>abc</b>'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
['a', { '{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' } }],
|
|
'b',
|
|
['c', { '{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' } }],
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': '<b>a</b>b<i>c</i>'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
['a', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['b', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['c', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': '<b><i><u>abc</u></i></b>'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
['a', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['b', {
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' }
|
|
}],
|
|
['c', {
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' }
|
|
}],
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': '<b><i><u>abc</u></i></b>'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
['a', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
'b',
|
|
['c', {
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' }
|
|
}],
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': '<b><i><u>a</u></i></b>b<u><b><i>c</i></b></u>'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
'a',
|
|
'b',
|
|
'c',
|
|
['d', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['e', {
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' }
|
|
}],
|
|
['f', {
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' }
|
|
}],
|
|
'g',
|
|
'h',
|
|
'i',
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': 'abc<b><i><u>def</u></i></b>ghi'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
'a',
|
|
'b',
|
|
'c',
|
|
['d', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['e', {
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['f', {
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' }
|
|
}],
|
|
'g',
|
|
'h',
|
|
'i',
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': 'abc<b><i><u>d</u></i></b><i><u>e<b>f</b></u></i>ghi'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
'a',
|
|
'b',
|
|
'c',
|
|
['d', {
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' }
|
|
}],
|
|
['e', {
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['f', {
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' }
|
|
}],
|
|
'g',
|
|
'h',
|
|
'i',
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': 'abc<i><u><b>d</b>e<b>f</b></u></i>ghi'
|
|
},
|
|
{
|
|
'data': [
|
|
{ 'type': 'paragraph' },
|
|
'a',
|
|
'b',
|
|
'c',
|
|
['d', {
|
|
'{"type":"textStyle/italic"}': { 'type': 'textStyle/italic' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' }
|
|
}],
|
|
['e', {
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' },
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' }
|
|
}],
|
|
['f', {
|
|
'{"type":"textStyle/underline"}': { 'type': 'textStyle/underline' },
|
|
'{"type":"textStyle/bold"}': { 'type': 'textStyle/bold' }
|
|
}],
|
|
'g',
|
|
'h',
|
|
'i',
|
|
{ 'type': '/paragraph' }
|
|
],
|
|
'html': 'abc<i><u><b>d</b></u></i><u><b>ef</b></u>ghi'
|
|
},
|
|
{
|
|
// [ ]
|
|
'data': [{ 'type': 'paragraph' },{ 'type': '/paragraph' }],
|
|
'html': ''
|
|
},
|
|
{
|
|
// [ ]
|
|
'data': [{ 'type': 'paragraph' },' ',{ 'type': '/paragraph' }],
|
|
'html': ' '
|
|
},
|
|
{
|
|
// [ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' '
|
|
},
|
|
{
|
|
// [ ][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' '
|
|
},
|
|
{
|
|
// [ ][ ][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' '
|
|
},
|
|
{
|
|
// [ ][ ][ ][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' '
|
|
},
|
|
{
|
|
// [ ][ ][ ][ ][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ', ' ', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' '
|
|
},
|
|
{
|
|
// [ ][A][ ][ ][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', 'A', ' ', ' ', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' A '
|
|
},
|
|
{
|
|
// [ ][ ][A][ ][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', 'A', ' ', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' A '
|
|
},
|
|
{
|
|
// [ ][ ][ ][A][ ][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ', 'A', ' ', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' A '
|
|
},
|
|
{
|
|
// [ ][ ][ ][ ][A][ ]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ', ' ', 'A', ' ',{ 'type': '/paragraph' }],
|
|
'html': ' A '
|
|
},
|
|
{
|
|
// [ ][ ][ ][ ][ ][A]
|
|
'data': [{ 'type': 'paragraph' },' ', ' ', ' ', ' ', ' ', 'A',{ 'type': '/paragraph' }],
|
|
'html': ' A'
|
|
}
|
|
];
|
|
for ( var i = 0; i < cases.length; i++ ) {
|
|
assert.equal(
|
|
( new ve.ce.TextNode(
|
|
( new ve.dm.Document( cases[i].data ) )
|
|
.documentNode.getChildren()[0].getChildren()[0] )
|
|
).getHtml(),
|
|
cases[i].html
|
|
);
|
|
}
|
|
} );
|