mediawiki-extensions-Visual.../modules/ve-mw/tests/ui/widgets/ve.ui.MWTemplateTitleInputWidget.test.js
WMDE-Fisch c4f59132ae Only add asterisk after word characters in improved template search
This will avoid that the search breaks in edge cases where symbols
are used.

Including a fallback for ES5 browsers. The fallback should cover
almost all cases. Worst case would be not adding the asterisk even
though it might be valid.

Bug: T284554
Change-Id: Ie4aee0b77492b7a73bc251a8723a206dbd641600
2021-06-21 21:07:28 +02:00

184 lines
4 KiB
JavaScript

( function () {
function enableCirrusSearchLookup( enabled ) {
const config = mw.config.get( 'wgVisualEditorConfig' );
config.cirrusSearchLookup = enabled !== false;
mw.config.set( 'wgVisualEditorConfig', config );
}
QUnit.module( 've.ui.MWTemplateTitleInputWidget', QUnit.newMwEnvironment( {
beforeEach: function () {
enableCirrusSearchLookup( false );
},
afterEach() {
enableCirrusSearchLookup( false );
}
} ) );
QUnit.test( 'default prefixsearch', ( assert ) => {
const widget = new ve.ui.MWTemplateTitleInputWidget(),
query = 'a',
apiParams = widget.getApiParams( query );
assert.deepEqual( apiParams, {
action: 'query',
generator: 'prefixsearch',
gpslimit: 10,
gpsnamespace: 10,
gpssearch: 'a',
ppprop: 'disambiguation',
prop: [ 'info', 'pageprops' ],
redirects: true
} );
} );
QUnit.test( 'CirrusSearch: all API parameters', ( assert ) => {
enableCirrusSearchLookup();
const widget = new ve.ui.MWTemplateTitleInputWidget(),
query = 'a',
apiParams = widget.getApiParams( query );
assert.deepEqual( apiParams, {
action: 'query',
generator: 'search',
gsrlimit: 10,
gsrnamespace: 10,
gsrprop: 'redirecttitle',
gsrsearch: 'a*',
ppprop: 'disambiguation',
prop: [ 'info', 'pageprops' ],
redirects: true
} );
} );
QUnit.test( 'CirrusSearch: showRedirectTargets disabled', ( assert ) => {
enableCirrusSearchLookup();
const widget = new ve.ui.MWTemplateTitleInputWidget( { showRedirectTargets: false } ),
apiParams = widget.getApiParams();
assert.notOk( 'gsrprop' in apiParams );
} );
QUnit.test( 'CirrusSearch: prefixsearch behavior', ( assert ) => {
enableCirrusSearchLookup();
const widget = new ve.ui.MWTemplateTitleInputWidget();
[
{
query: 'a',
expected: 'a*'
},
{
query: 'a ',
expected: 'a '
},
{
query: 'ü',
expected: 'ü*'
},
{
query: '3',
expected: '3*'
},
{
query: '!!',
expected: '!!'
},
{
query: 'Foo:',
expected: 'Foo:'
},
{
query: 'Foo:Bar',
expected: 'Foo:Bar*'
},
{
query: 'foo_',
expected: 'foo_'
},
{
query: 'foo-',
expected: 'foo-'
},
{
query: 'foo+',
expected: 'foo+'
},
{
query: 'foo/',
expected: 'foo/'
},
{
query: 'foo~',
expected: 'foo~'
},
{
query: 'foo*',
expected: 'foo*'
},
{
query: '(foo)',
expected: '(foo)'
},
{
query: '[foo]',
expected: '[foo]'
},
{
query: '{foo}',
expected: '{foo}'
},
{
query: '"foo"',
expected: '"foo"'
},
{
query: 'foß',
expected: 'foß*'
},
{
query: '中文字',
expected: '中文字*'
},
{
query: 'zhōngwénzì',
expected: 'zhōngwénzì*'
}
].forEach( ( data ) => {
const apiParams = widget.getApiParams( data.query );
assert.strictEqual(
apiParams.gsrsearch,
data.expected,
'Searching for ' + data.query
);
} );
} );
QUnit.test( 'CirrusSearch: redirect is forwarded to the TitleOptionWidget', ( assert ) => {
enableCirrusSearchLookup();
const widget = new ve.ui.MWTemplateTitleInputWidget(),
originalData = { redirecttitle: 'Template:From' },
data = widget.getOptionWidgetData( 'Template:To', { originalData } );
assert.strictEqual( data.redirecttitle, 'Template:From' );
} );
QUnit.test( 'CirrusSearch: redirect appears in the description', ( assert ) => {
enableCirrusSearchLookup();
const widget = new ve.ui.MWTemplateTitleInputWidget();
let option = widget.createOptionWidget( { redirecttitle: 'Template:From' } );
assert.strictEqual(
option.$element.find( '.ve-ui-mwTemplateTitleInputWidget-redirectedfrom' ).text(),
'(redirectedfrom: From)'
);
widget.relative = false;
option = widget.createOptionWidget( { redirecttitle: 'Template:From' } );
assert.strictEqual(
option.$element.find( '.ve-ui-mwTemplateTitleInputWidget-redirectedfrom' ).text(),
'(redirectedfrom: Template:From)'
);
} );
}() );