mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-10 04:04:50 +00:00
7cf10ea474
The "Add parameter" page always starts collapsed. Even if a template doesn't contain anything but this. But most of the content isn't visible, unless the user presses the button. It's not only a lot of content, it's also rather expensive, including .parseDom(), LinkCache.styleElement(), and ve.targetLinksToNewWindow(). This adds up in large multi-part transclusions. In an example with 200 parts the total blocking time goes down from 2.9s to 2.4s. Which means this is not a major bottleneck, but still worth it. Bug: T296335 Change-Id: Ieab9fd35d145142b04d2267d8e5a2e10a4c02784
100 lines
4.2 KiB
JavaScript
100 lines
4.2 KiB
JavaScript
QUnit.module( 've.ui.MWAddParameterPage', ve.test.utils.mwEnvironment );
|
|
|
|
QUnit.test( 'Input event handlers', ( assert ) => {
|
|
const transclusion = new ve.dm.MWTransclusionModel(),
|
|
template = new ve.dm.MWTemplateModel( transclusion, {} ),
|
|
parameter = new ve.dm.MWParameterModel( template ),
|
|
page = new ve.ui.MWAddParameterPage( parameter );
|
|
|
|
page.togglePlaceholder( true );
|
|
|
|
page.paramInputField.setValue( ' ' );
|
|
assert.strictEqual( page.saveButton.isDisabled(), true, 'cannot click' );
|
|
page.onParameterNameSubmitted();
|
|
assert.deepEqual( template.getParameters(), {}, 'empty input is ignored' );
|
|
assert.strictEqual( page.paramInputField.getValue(), ' ', 'bad input is not cleared' );
|
|
|
|
page.paramInputField.setValue( ' p1 ' );
|
|
assert.strictEqual( page.saveButton.isDisabled(), false, 'can click' );
|
|
page.onParameterNameSubmitted();
|
|
assert.true( template.hasParameter( 'p1' ), 'input is trimmed and parameter added' );
|
|
assert.strictEqual( page.paramInputField.getValue(), '', 'accepted input is cleared' );
|
|
|
|
template.getParameter( 'p1' ).setValue( 'not empty' );
|
|
page.paramInputField.setValue( 'p1' );
|
|
assert.strictEqual( page.saveButton.isDisabled(), true, 'cannot click' );
|
|
page.onParameterNameSubmitted();
|
|
assert.strictEqual( template.getParameter( 'p1' ).getValue(), 'not empty',
|
|
'existing parameter is not replaced' );
|
|
|
|
template.getSpec().setTemplateData( { params: { documented: {} } } );
|
|
page.paramInputField.setValue( 'documented' );
|
|
page.onParameterNameSubmitted();
|
|
assert.false( template.hasParameter( 'documented' ), 'documented parameter is not added' );
|
|
assert.strictEqual( page.paramInputField.getValue(), 'documented', 'bad input is not cleared' );
|
|
} );
|
|
|
|
QUnit.test( 'Outline item initialization', ( assert ) => {
|
|
const transclusion = new ve.dm.MWTransclusionModel(),
|
|
template = new ve.dm.MWTemplateModel( transclusion, {} ),
|
|
parameter = new ve.dm.MWParameterModel( template ),
|
|
page = new ve.ui.MWAddParameterPage( parameter );
|
|
|
|
page.setOutlineItem( new OO.ui.OutlineOptionWidget() );
|
|
const outlineItem = page.getOutlineItem();
|
|
|
|
assert.strictEqual( outlineItem.$element.children().length, 0,
|
|
'Outline item should be empty' );
|
|
// eslint-disable-next-line no-jquery/no-class-state
|
|
assert.false( outlineItem.$element.hasClass( 'oo-ui-outlineOptionWidget' ),
|
|
'Outline item should not be styled' );
|
|
} );
|
|
|
|
[
|
|
[ '', 0 ],
|
|
[ 'a', 0 ],
|
|
[ 'a=b', '(visualeditor-dialog-transclusion-add-param-error-forbidden-char: =)' ],
|
|
[ 'x|a=b', '(visualeditor-dialog-transclusion-add-param-error-forbidden-char: |)' ],
|
|
[ 'used', '(visualeditor-dialog-transclusion-add-param-error-exists-selected: used, used)' ],
|
|
[ 'unused', '(visualeditor-dialog-transclusion-add-param-error-exists-unselected: unused, unused)' ],
|
|
[ 'usedAlias', '(visualeditor-dialog-transclusion-add-param-error-alias: usedAlias, xLabel)' ],
|
|
[ 'unusedAlias', '(visualeditor-dialog-transclusion-add-param-error-alias: unusedAlias, y)' ],
|
|
[ 'usedAliasNoLabel', '(visualeditor-dialog-transclusion-add-param-error-alias: usedAliasNoLabel, usedAliasNoLabel)' ],
|
|
[ 'usedDeprecated', '(visualeditor-dialog-transclusion-add-param-error-exists-selected: usedDeprecated, usedDeprecated)' ],
|
|
[ 'unusedDeprecated', '(visualeditor-dialog-transclusion-add-param-error-deprecated: unusedDeprecated, unusedDeprecated)' ]
|
|
].forEach( ( [ input, expected ] ) =>
|
|
QUnit.test( 'getValidationErrors: ' + input, ( assert ) => {
|
|
const data = {
|
|
target: {},
|
|
params: {
|
|
used: {},
|
|
usedAlias: {},
|
|
usedAliasNoLabel: {},
|
|
usedDeprecated: {}
|
|
}
|
|
};
|
|
|
|
const transclusion = new ve.dm.MWTransclusionModel(),
|
|
template = ve.dm.MWTemplateModel.newFromData( transclusion, data ),
|
|
parameter = new ve.dm.MWParameterModel( template ),
|
|
page = new ve.ui.MWAddParameterPage( parameter );
|
|
|
|
template.getSpec().setTemplateData( { params: {
|
|
used: {},
|
|
unused: {},
|
|
x: { aliases: [ 'usedAlias' ], label: 'xLabel' },
|
|
y: { aliases: [ 'unusedAlias' ] },
|
|
z: { aliases: [ 'usedAliasNoLabel' ] },
|
|
usedDeprecated: { deprecated: true },
|
|
unusedDeprecated: { deprecated: true }
|
|
} } );
|
|
template.addParameter( parameter );
|
|
|
|
const errors = page.getValidationErrors( input );
|
|
assert.strictEqual( errors.length, expected ? 1 : 0 );
|
|
if ( expected ) {
|
|
assert.strictEqual( errors[ 0 ].text(), expected );
|
|
}
|
|
} )
|
|
);
|