mediawiki-extensions-Cite/modules/ve-cite/tests/ve.dm.Transaction.test.js
Adam Wight 9535126304 [lint] Satisfy max-len rule
These changes mostly improve the code, and align the lint rules with
the MediaWiki base.

Change-Id: Ib4b0595fd9a9298039b8b44a0f1d4a9e90731527
2024-01-30 12:18:52 +01:00

106 lines
3.1 KiB
JavaScript

'use strict';
/*!
* VisualEditor DataModel Cite-specific Transaction tests.
*
* @copyright 2011-2018 VisualEditor Team's Cite sub-team and others; see AUTHORS.txt
* @license MIT
*/
QUnit.module( 've.dm.Transaction (Cite)', ve.test.utils.newMwEnvironment() );
// FIXME: Duplicates test runner; should be using a data provider
QUnit.test( 'newFromDocumentInsertion with references', function ( assert ) {
const complexDoc = ve.dm.citeExample.createExampleDocument( 'complexInternalData' ),
withReference = [
{ type: 'paragraph' },
'B', 'a', 'r',
{ type: 'mwReference', attributes: {
mw: {},
about: '#mwt4',
listIndex: 0,
listGroup: 'mwReference/',
listKey: 'auto/0',
refGroup: '',
contentsUsed: true
} },
{ type: '/mwReference' },
{ type: '/paragraph' },
{ type: 'internalList' },
{ type: 'internalItem' },
{ type: 'paragraph', internal: { generated: 'wrapper' } },
'B',
'a',
'z',
{ type: '/paragraph' },
{ type: '/internalItem' },
{ type: '/internalList' }
],
cases = [
{
msg: 'inserting a brand new document; internal lists are merged and items renumbered',
doc: 'complexInternalData',
offset: 7,
newDocData: withReference,
removalOps: [],
expectedOps: [
{ type: 'retain', length: 7 },
{
type: 'replace',
remove: [],
insert: withReference.slice( 0, 4 )
// Renumber listIndex from 0 to 2
// Renumber listKey from auto/0 to auto/1
.concat( [
ve.extendObject( true, {}, withReference[ 4 ],
{ attributes: { listIndex: 2, listKey: 'auto/1' } }
)
] )
.concat( withReference.slice( 5, 7 ) )
},
{ type: 'retain', length: 1 },
{
type: 'replace',
remove: complexDoc.getData( new ve.Range( 8, 32 ) ),
insert: complexDoc.getData( new ve.Range( 8, 32 ) )
.concat( withReference.slice( 8, 15 ) )
},
{ type: 'retain', length: 1 }
]
}
];
cases.forEach( function ( caseItem ) {
const doc = ve.dm.citeExample.createExampleDocument( caseItem.doc );
let doc2, removalOps;
if ( caseItem.newDocData ) {
doc2 = new ve.dm.Document( caseItem.newDocData );
removalOps = [];
} else if ( caseItem.range ) {
doc2 = doc.cloneFromRange( caseItem.range );
caseItem.modify( doc2 );
const removalTx = ve.dm.TransactionBuilder.static
.newFromRemoval( doc, caseItem.range, true );
doc.commit( removalTx );
removalOps = removalTx.getOperations();
}
assert.deepEqualWithDomElements(
removalOps, caseItem.removalOps, caseItem.msg + ': removal'
);
const tx = ve.dm.TransactionBuilder.static.newFromDocumentInsertion(
doc, caseItem.offset, doc2
);
assert.deepEqualWithDomElements(
tx.getOperations(), caseItem.expectedOps, caseItem.msg + ': transaction'
);
const expectedStoreItems = caseItem.expectedStoreItems || [];
const actualStoreItems = expectedStoreItems.map( function ( item ) {
return doc.store.value( OO.getHash( item ) );
} );
assert.deepEqual( actualStoreItems, expectedStoreItems, caseItem.msg + ': store items' );
} );
} );