mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-22 02:53:04 +00:00
a0e613d8fc
These tests obviously don't need this extra environment. They run just fine (and faster) without. Bug: T289560 Change-Id: Ib186a07cd556f741e0440ffa54ae6aaaf626adcd
50 lines
1.7 KiB
JavaScript
50 lines
1.7 KiB
JavaScript
/*!
|
|
* VisualEditor MediaWiki-specific ContentEditable ContentBranchNode tests.
|
|
*
|
|
* @copyright 2011-2020 VisualEditor Team and others; see AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
QUnit.module( 've.ce.ContentBranchNode (MW)' );
|
|
|
|
/* Tests */
|
|
|
|
// FIXME runner copypasted from core, use data provider
|
|
QUnit.test( 'getRenderedContents', ( assert ) => {
|
|
const cases = [ {
|
|
msg: 'Annotation spanning text and inline nodes',
|
|
data: [
|
|
{ type: 'paragraph' },
|
|
'a',
|
|
[ 'b', [ { type: 'textStyle/bold' } ] ],
|
|
{
|
|
type: 'mwEntity',
|
|
attributes: { character: 'c' },
|
|
annotations: [ { type: 'textStyle/bold' } ]
|
|
},
|
|
{ type: '/mwEntity' },
|
|
[ 'd', [ { type: 'textStyle/bold' } ] ],
|
|
{
|
|
type: 'alienInline',
|
|
originalDomElements: $( '<span rel="ve:Alien">e</span>' ).toArray(),
|
|
annotations: [ { type: 'textStyle/bold' } ]
|
|
},
|
|
{ type: '/alienInline' },
|
|
{ type: '/paragraph' }
|
|
],
|
|
html:
|
|
'a<b>b' +
|
|
'<span class="ve-ce-leafNode ve-ce-mwEntityNode" contenteditable="false">c</span>' +
|
|
'd<span rel="ve:Alien" class="ve-ce-focusableNode ve-ce-leafNode" contenteditable="false">e</span>' +
|
|
'</b>'
|
|
} ];
|
|
|
|
for ( let i = 0; i < cases.length; i++ ) {
|
|
const doc = new ve.dm.Document( ve.dm.example.preprocessAnnotations( cases[ i ].data ) ),
|
|
$wrapper = $( new ve.ce.ParagraphNode( doc.getDocumentNode().getChildren()[ 0 ] ).getRenderedContents() );
|
|
// HACK strip out all the class="ve-ce-textStyleAnnotation ve-ce-textStyleBoldAnnotation" crap
|
|
$wrapper.find( '.ve-ce-textStyleAnnotation' ).removeAttr( 'class' );
|
|
assert.equalDomElement( $wrapper[ 0 ], $( '<div>' ).html( cases[ i ].html )[ 0 ], cases[ i ].msg );
|
|
}
|
|
} );
|