X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=tests%2Fqunit%2Fsuites%2Fresources%2Fmediawiki%2Fmediawiki.test.js;h=83e695fcd9d6d7428455a14ed0bd7bb8ffcad711;hb=75cc8d3e0003318cf8a8fb33cb98523f63abcfb9;hp=75dc66511e122c7401bcd2943529a2ebd87ba21e;hpb=b4054da0f9c2a1c23f4af93871329e39c0ab6a8f;p=lhc%2Fweb%2Fwiklou.git diff --git a/tests/qunit/suites/resources/mediawiki/mediawiki.test.js b/tests/qunit/suites/resources/mediawiki/mediawiki.test.js index 75dc66511e..83e695fcd9 100644 --- a/tests/qunit/suites/resources/mediawiki/mediawiki.test.js +++ b/tests/qunit/suites/resources/mediawiki/mediawiki.test.js @@ -52,12 +52,12 @@ } ); QUnit.test( 'mw.format', function ( assert ) { - assert.equal( + assert.strictEqual( mw.format( 'Format $1 $2', 'foo', 'bar' ), 'Format foo bar', 'Simple parameters' ); - assert.equal( + assert.strictEqual( mw.format( 'Format $1 $2' ), 'Format $1 $2', 'Missing parameters' @@ -65,8 +65,8 @@ } ); QUnit.test( 'mw.now', function ( assert ) { - assert.equal( typeof mw.now(), 'number', 'Return a number' ); - assert.equal( + assert.strictEqual( typeof mw.now(), 'number', 'Return a number' ); + assert.strictEqual( String( Math.round( mw.now() ) ).length, String( +new Date() ).length, 'Match size of current timestamp' @@ -86,7 +86,7 @@ // Single get and set assert.strictEqual( conf.set( 'foo', 'Bar' ), true, 'Map.set returns boolean true if a value was set for a valid key string' ); - assert.equal( conf.get( 'foo' ), 'Bar', 'Map.get returns a single value value correctly' ); + assert.strictEqual( conf.get( 'foo' ), 'Bar', 'Map.get returns a single value value correctly' ); assert.strictEqual( conf.get( 'example' ), null, 'Map.get returns null if selection was a string and the key was not found' ); assert.strictEqual( conf.get( 'example', arry ), arry, 'Map.get returns fallback by reference if the key was not found' ); @@ -108,7 +108,7 @@ assert.strictEqual( conf.set( 'undef' ), false, 'Map.set requires explicit value (no undefined default)' ); assert.strictEqual( conf.set( 'undef', undefined ), true, 'Map.set allows setting value to `undefined`' ); - assert.equal( conf.get( 'undef', 'fallback' ), undefined, 'Map.get supports retreiving value of `undefined`' ); + assert.strictEqual( conf.get( 'undef', 'fallback' ), undefined, 'Map.get supports retreiving value of `undefined`' ); assert.strictEqual( conf.set( funky, 'Funky' ), false, 'Map.set returns boolean false if key was invalid (Function)' ); assert.strictEqual( conf.set( arry, 'Arry' ), false, 'Map.set returns boolean false if key was invalid (Array)' ); @@ -155,31 +155,31 @@ // Interacting with globals conf.set( 'globalMapChecker', 'Hi' ); - assert.ok( ( 'globalMapChecker' in window ) === false, 'Map does not its store values in the window object by default' ); + assert.strictEqual( 'globalMapChecker' in window, false, 'Map does not its store values in the window object by default' ); globalConf = new mw.Map( true ); globalConf.set( 'anotherGlobalMapChecker', 'Hello' ); assert.ok( 'anotherGlobalMapChecker' in window, 'global Map stores its values in the window object' ); - assert.equal( globalConf.get( 'anotherGlobalMapChecker' ), 'Hello', 'get value from global Map via get()' ); + assert.strictEqual( globalConf.get( 'anotherGlobalMapChecker' ), 'Hello', 'get value from global Map via get()' ); this.suppressWarnings(); - assert.equal( window.anotherGlobalMapChecker, 'Hello', 'get value from global Map via window object' ); + assert.strictEqual( window.anotherGlobalMapChecker, 'Hello', 'get value from global Map via window object' ); this.restoreWarnings(); // Change value via global Map globalConf.set( 'anotherGlobalMapChecker', 'Again' ); - assert.equal( globalConf.get( 'anotherGlobalMapChecker' ), 'Again', 'Change in global Map reflected via get()' ); + assert.strictEqual( globalConf.get( 'anotherGlobalMapChecker' ), 'Again', 'Change in global Map reflected via get()' ); this.suppressWarnings(); - assert.equal( window.anotherGlobalMapChecker, 'Again', 'Change in global Map reflected window object' ); + assert.strictEqual( window.anotherGlobalMapChecker, 'Again', 'Change in global Map reflected window object' ); this.restoreWarnings(); // Change value via window object this.suppressWarnings(); window.anotherGlobalMapChecker = 'World'; - assert.equal( window.anotherGlobalMapChecker, 'World', 'Change in window object works' ); + assert.strictEqual( window.anotherGlobalMapChecker, 'World', 'Change in window object works' ); this.restoreWarnings(); - assert.equal( globalConf.get( 'anotherGlobalMapChecker' ), 'Again', 'Change in window object not reflected in global Map' ); + assert.strictEqual( globalConf.get( 'anotherGlobalMapChecker' ), 'Again', 'Change in window object not reflected in global Map' ); // Whitelist this global variable for QUnit's 'noglobal' mode if ( QUnit.config.noglobals ) { @@ -197,7 +197,7 @@ for ( i = 0; i < len; i++ ) { format = formats[ i ]; - assert.equal( mw.message.apply( null, messageArguments )[ format ](), expectedResult, assertMessage + ' when format is ' + format ); + assert.strictEqual( mw.message.apply( null, messageArguments )[ format ](), expectedResult, assertMessage + ' when format is ' + format ); } } @@ -207,29 +207,29 @@ hello = mw.message( 'hello' ); // https://phabricator.wikimedia.org/T46459 - assert.equal( hello.format, 'text', 'Message property "format" defaults to "text"' ); + assert.strictEqual( hello.format, 'text', 'Message property "format" defaults to "text"' ); assert.strictEqual( hello.map, mw.messages, 'Message property "map" defaults to the global instance in mw.messages' ); - assert.equal( hello.key, 'hello', 'Message property "key" (currect key)' ); + assert.strictEqual( hello.key, 'hello', 'Message property "key" (currect key)' ); assert.deepEqual( hello.parameters, [], 'Message property "parameters" defaults to an empty array' ); // TODO assert.ok( hello.params, 'Message prototype "params"' ); hello.format = 'plain'; - assert.equal( hello.toString(), 'Hello awesome world', 'Message.toString returns the message as a string with the current "format"' ); + assert.strictEqual( hello.toString(), 'Hello awesome world', 'Message.toString returns the message as a string with the current "format"' ); - assert.equal( hello.escaped(), 'Hello <b>awesome</b> world', 'Message.escaped returns the escaped message' ); - assert.equal( hello.format, 'escaped', 'Message.escaped correctly updated the "format" property' ); + assert.strictEqual( hello.escaped(), 'Hello <b>awesome</b> world', 'Message.escaped returns the escaped message' ); + assert.strictEqual( hello.format, 'escaped', 'Message.escaped correctly updated the "format" property' ); assert.ok( mw.messages.set( 'multiple-curly-brace', '"{{SITENAME}}" is the home of {{int:other-message}}' ), 'mw.messages.set: Register' ); assertMultipleFormats( [ 'multiple-curly-brace' ], [ 'text', 'parse' ], '"' + siteName + '" is the home of Other Message', 'Curly brace format works correctly' ); - assert.equal( mw.message( 'multiple-curly-brace' ).plain(), mw.messages.get( 'multiple-curly-brace' ), 'Plain format works correctly for curly brace message' ); - assert.equal( mw.message( 'multiple-curly-brace' ).escaped(), mw.html.escape( '"' + siteName + '" is the home of Other Message' ), 'Escaped format works correctly for curly brace message' ); + assert.strictEqual( mw.message( 'multiple-curly-brace' ).plain(), mw.messages.get( 'multiple-curly-brace' ), 'Plain format works correctly for curly brace message' ); + assert.strictEqual( mw.message( 'multiple-curly-brace' ).escaped(), mw.html.escape( '"' + siteName + '" is the home of Other Message' ), 'Escaped format works correctly for curly brace message' ); assert.ok( mw.messages.set( 'multiple-square-brackets-and-ampersand', 'Visit the [[Project:Community portal|community portal]] & [[Project:Help desk|help desk]]' ), 'mw.messages.set: Register' ); assertMultipleFormats( [ 'multiple-square-brackets-and-ampersand' ], [ 'plain', 'text' ], mw.messages.get( 'multiple-square-brackets-and-ampersand' ), 'Square bracket message is not processed' ); - assert.equal( mw.message( 'multiple-square-brackets-and-ampersand' ).escaped(), 'Visit the [[Project:Community portal|community portal]] & [[Project:Help desk|help desk]]', 'Escaped format works correctly for square bracket message' ); + assert.strictEqual( mw.message( 'multiple-square-brackets-and-ampersand' ).escaped(), 'Visit the [[Project:Community portal|community portal]] & [[Project:Help desk|help desk]]', 'Escaped format works correctly for square bracket message' ); assert.htmlEqual( mw.message( 'multiple-square-brackets-and-ampersand' ).parse(), 'Visit the ' + 'community portal' + ' & help desk', 'Internal links work with parse' ); @@ -238,17 +238,17 @@ assert.htmlEqual( mw.message( 'mediawiki-test-version-entrypoints-index-php' ).parse(), 'index.php', 'External link works correctly in parse mode' ); assertMultipleFormats( [ 'external-link-replace', 'http://example.org/?x=y&z' ], [ 'plain', 'text' ], 'Foo [http://example.org/?x=y&z bar]', 'Parameters are substituted but external link is not processed' ); - assert.equal( mw.message( 'external-link-replace', 'http://example.org/?x=y&z' ).escaped(), 'Foo [http://example.org/?x=y&z bar]', 'In escaped mode, parameters are substituted and ampersand is escaped, but external link is not processed' ); + assert.strictEqual( mw.message( 'external-link-replace', 'http://example.org/?x=y&z' ).escaped(), 'Foo [http://example.org/?x=y&z bar]', 'In escaped mode, parameters are substituted and ampersand is escaped, but external link is not processed' ); assert.htmlEqual( mw.message( 'external-link-replace', 'http://example.org/?x=y&z' ).parse(), 'Foo bar', 'External link with replacement works in parse mode without double-escaping' ); hello.parse(); - assert.equal( hello.format, 'parse', 'Message.parse correctly updated the "format" property' ); + assert.strictEqual( hello.format, 'parse', 'Message.parse correctly updated the "format" property' ); hello.plain(); - assert.equal( hello.format, 'plain', 'Message.plain correctly updated the "format" property' ); + assert.strictEqual( hello.format, 'plain', 'Message.plain correctly updated the "format" property' ); hello.text(); - assert.equal( hello.format, 'text', 'Message.text correctly updated the "format" property' ); + assert.strictEqual( hello.format, 'text', 'Message.text correctly updated the "format" property' ); assert.strictEqual( hello.exists(), true, 'Message.exists returns true for existing messages' ); @@ -259,7 +259,7 @@ assert.ok( mw.messages.set( 'plural-test-msg', 'There {{PLURAL:$1|is|are}} $1 {{PLURAL:$1|result|results}}' ), 'mw.messages.set: Register' ); assertMultipleFormats( [ 'plural-test-msg', 6 ], [ 'text', 'parse', 'escaped' ], 'There are 6 results', 'plural get resolved' ); - assert.equal( mw.message( 'plural-test-msg', 6 ).plain(), 'There {{PLURAL:6|is|are}} 6 {{PLURAL:6|result|results}}', 'Parameter is substituted but plural is not resolved in plain' ); + assert.strictEqual( mw.message( 'plural-test-msg', 6 ).plain(), 'There {{PLURAL:6|is|are}} 6 {{PLURAL:6|result|results}}', 'Parameter is substituted but plural is not resolved in plain' ); assert.ok( mw.messages.set( 'plural-test-msg-explicit', 'There {{plural:$1|is one car|are $1 cars|0=are no cars|12=are a dozen cars}}' ), 'mw.messages.set: Register message with explicit plural forms' ); assertMultipleFormats( [ 'plural-test-msg-explicit', 12 ], [ 'text', 'parse', 'escaped' ], 'There are a dozen cars', 'explicit plural get resolved' ); @@ -274,26 +274,26 @@ assertMultipleFormats( [ 'mediawiki-test-pagetriage-del-talk-page-notify-summary', specialCharactersPageName ], [ 'plain', 'text' ], 'Notifying author of deletion nomination for [[' + specialCharactersPageName + ']]', 'Double square brackets with one parameter' ); - assert.equal( mw.message( 'mediawiki-test-pagetriage-del-talk-page-notify-summary', specialCharactersPageName ).escaped(), 'Notifying author of deletion nomination for [[' + mw.html.escape( specialCharactersPageName ) + ']]', 'Double square brackets with one parameter, when escaped' ); + assert.strictEqual( mw.message( 'mediawiki-test-pagetriage-del-talk-page-notify-summary', specialCharactersPageName ).escaped(), 'Notifying author of deletion nomination for [[' + mw.html.escape( specialCharactersPageName ) + ']]', 'Double square brackets with one parameter, when escaped' ); assert.ok( mw.messages.set( 'mediawiki-test-categorytree-collapse-bullet', '[−]' ), 'mw.messages.set: Register' ); - assert.equal( mw.message( 'mediawiki-test-categorytree-collapse-bullet' ).plain(), mw.messages.get( 'mediawiki-test-categorytree-collapse-bullet' ), 'Single square brackets unchanged in plain mode' ); + assert.strictEqual( mw.message( 'mediawiki-test-categorytree-collapse-bullet' ).plain(), mw.messages.get( 'mediawiki-test-categorytree-collapse-bullet' ), 'Single square brackets unchanged in plain mode' ); assert.ok( mw.messages.set( 'mediawiki-test-wikieditor-toolbar-help-content-signature-result', 'Username (talk)' ), 'mw.messages.set: Register' ); - assert.equal( mw.message( 'mediawiki-test-wikieditor-toolbar-help-content-signature-result' ).plain(), mw.messages.get( 'mediawiki-test-wikieditor-toolbar-help-content-signature-result' ), 'HTML message with curly braces is not changed in plain mode' ); + assert.strictEqual( mw.message( 'mediawiki-test-wikieditor-toolbar-help-content-signature-result' ).plain(), mw.messages.get( 'mediawiki-test-wikieditor-toolbar-help-content-signature-result' ), 'HTML message with curly braces is not changed in plain mode' ); assertMultipleFormats( [ 'gender-plural-msg', 'male', 1 ], [ 'text', 'parse', 'escaped' ], 'he is awesome', 'Gender and plural are resolved' ); - assert.equal( mw.message( 'gender-plural-msg', 'male', 1 ).plain(), '{{GENDER:male|he|she|they}} {{PLURAL:1|is|are}} awesome', 'Parameters are substituted, but gender and plural are not resolved in plain mode' ); + assert.strictEqual( mw.message( 'gender-plural-msg', 'male', 1 ).plain(), '{{GENDER:male|he|she|they}} {{PLURAL:1|is|are}} awesome', 'Parameters are substituted, but gender and plural are not resolved in plain mode' ); - assert.equal( mw.message( 'grammar-msg' ).plain(), mw.messages.get( 'grammar-msg' ), 'Grammar is not resolved in plain mode' ); + assert.strictEqual( mw.message( 'grammar-msg' ).plain(), mw.messages.get( 'grammar-msg' ), 'Grammar is not resolved in plain mode' ); assertMultipleFormats( [ 'grammar-msg' ], [ 'text', 'parse' ], 'Przeszukaj ' + siteName, 'Grammar is resolved' ); - assert.equal( mw.message( 'grammar-msg' ).escaped(), 'Przeszukaj ' + siteName, 'Grammar is resolved in escaped mode' ); + assert.strictEqual( mw.message( 'grammar-msg' ).escaped(), 'Przeszukaj ' + siteName, 'Grammar is resolved in escaped mode' ); assertMultipleFormats( [ 'formatnum-msg', '987654321.654321' ], [ 'text', 'parse', 'escaped' ], '987,654,321.654', 'formatnum is resolved' ); - assert.equal( mw.message( 'formatnum-msg' ).plain(), mw.messages.get( 'formatnum-msg' ), 'formatnum is not resolved in plain mode' ); + assert.strictEqual( mw.message( 'formatnum-msg' ).plain(), mw.messages.get( 'formatnum-msg' ), 'formatnum is not resolved in plain mode' ); assertMultipleFormats( [ 'int-msg' ], [ 'text', 'parse', 'escaped' ], 'Some Other Message', 'int is resolved' ); - assert.equal( mw.message( 'int-msg' ).plain(), mw.messages.get( 'int-msg' ), 'int is not resolved in plain mode' ); + assert.strictEqual( mw.message( 'int-msg' ).plain(), mw.messages.get( 'int-msg' ), 'int is not resolved in plain mode' ); assert.ok( mw.messages.set( 'mediawiki-italics-msg', 'Very important' ), 'mw.messages.set: Register' ); assertMultipleFormats( [ 'mediawiki-italics-msg' ], [ 'plain', 'text', 'parse' ], mw.messages.get( 'mediawiki-italics-msg' ), 'Simple italics unchanged' ); @@ -333,117 +333,24 @@ QUnit.test( 'mw.msg', function ( assert ) { assert.ok( mw.messages.set( 'hello', 'Hello awesome world' ), 'mw.messages.set: Register' ); - assert.equal( mw.msg( 'hello' ), 'Hello awesome world', 'Gets message with default options (existing message)' ); - assert.equal( mw.msg( 'goodbye' ), '⧼goodbye⧽', 'Gets message with default options (nonexistent message)' ); + assert.strictEqual( mw.msg( 'hello' ), 'Hello awesome world', 'Gets message with default options (existing message)' ); + assert.strictEqual( mw.msg( 'goodbye' ), '⧼goodbye⧽', 'Gets message with default options (nonexistent message)' ); assert.ok( mw.messages.set( 'plural-item', 'Found $1 {{PLURAL:$1|item|items}}' ), 'mw.messages.set: Register' ); - assert.equal( mw.msg( 'plural-item', 5 ), 'Found 5 items', 'Apply plural for count 5' ); - assert.equal( mw.msg( 'plural-item', 0 ), 'Found 0 items', 'Apply plural for count 0' ); - assert.equal( mw.msg( 'plural-item', 1 ), 'Found 1 item', 'Apply plural for count 1' ); + assert.strictEqual( mw.msg( 'plural-item', 5 ), 'Found 5 items', 'Apply plural for count 5' ); + assert.strictEqual( mw.msg( 'plural-item', 0 ), 'Found 0 items', 'Apply plural for count 0' ); + assert.strictEqual( mw.msg( 'plural-item', 1 ), 'Found 1 item', 'Apply plural for count 1' ); - assert.equal( mw.msg( 'mediawiki-test-pagetriage-del-talk-page-notify-summary', specialCharactersPageName ), 'Notifying author of deletion nomination for [[' + specialCharactersPageName + ']]', 'Double square brackets in mw.msg one parameter' ); + assert.strictEqual( mw.msg( 'mediawiki-test-pagetriage-del-talk-page-notify-summary', specialCharactersPageName ), 'Notifying author of deletion nomination for [[' + specialCharactersPageName + ']]', 'Double square brackets in mw.msg one parameter' ); - assert.equal( mw.msg( 'gender-plural-msg', 'male', 1 ), 'he is awesome', 'Gender test for male, plural count 1' ); - assert.equal( mw.msg( 'gender-plural-msg', 'female', '1' ), 'she is awesome', 'Gender test for female, plural count 1' ); - assert.equal( mw.msg( 'gender-plural-msg', 'unknown', 10 ), 'they are awesome', 'Gender test for neutral, plural count 10' ); + assert.strictEqual( mw.msg( 'gender-plural-msg', 'male', 1 ), 'he is awesome', 'Gender test for male, plural count 1' ); + assert.strictEqual( mw.msg( 'gender-plural-msg', 'female', '1' ), 'she is awesome', 'Gender test for female, plural count 1' ); + assert.strictEqual( mw.msg( 'gender-plural-msg', 'unknown', 10 ), 'they are awesome', 'Gender test for neutral, plural count 10' ); - assert.equal( mw.msg( 'grammar-msg' ), 'Przeszukaj ' + siteName, 'Grammar is resolved' ); + assert.strictEqual( mw.msg( 'grammar-msg' ), 'Przeszukaj ' + siteName, 'Grammar is resolved' ); - assert.equal( mw.msg( 'formatnum-msg', '987654321.654321' ), '987,654,321.654', 'formatnum is resolved' ); + assert.strictEqual( mw.msg( 'formatnum-msg', '987654321.654321' ), '987,654,321.654', 'formatnum is resolved' ); - assert.equal( mw.msg( 'int-msg' ), 'Some Other Message', 'int is resolved' ); + assert.strictEqual( mw.msg( 'int-msg' ), 'Some Other Message', 'int is resolved' ); } ); - - QUnit.test( 'mw.hook', function ( assert ) { - var hook, add, fire, chars, callback; - - mw.hook( 'test.hook.unfired' ).add( function () { - assert.ok( false, 'Unfired hook' ); - } ); - - mw.hook( 'test.hook.basic' ).add( function () { - assert.ok( true, 'Basic callback' ); - } ); - mw.hook( 'test.hook.basic' ).fire(); - - mw.hook( 'hasOwnProperty' ).add( function () { - assert.ok( true, 'hook with name of predefined method' ); - } ); - mw.hook( 'hasOwnProperty' ).fire(); - - mw.hook( 'test.hook.data' ).add( function ( data1, data2 ) { - assert.equal( data1, 'example', 'Fire with data (string param)' ); - assert.deepEqual( data2, [ 'two' ], 'Fire with data (array param)' ); - } ); - mw.hook( 'test.hook.data' ).fire( 'example', [ 'two' ] ); - - hook = mw.hook( 'test.hook.chainable' ); - assert.strictEqual( hook.add(), hook, 'hook.add is chainable' ); - assert.strictEqual( hook.remove(), hook, 'hook.remove is chainable' ); - assert.strictEqual( hook.fire(), hook, 'hook.fire is chainable' ); - - hook = mw.hook( 'test.hook.detach' ); - add = hook.add; - fire = hook.fire; - add( function ( x, y ) { - assert.deepEqual( [ x, y ], [ 'x', 'y' ], 'Detached (contextless) with data' ); - } ); - fire( 'x', 'y' ); - - mw.hook( 'test.hook.fireBefore' ).fire().add( function () { - assert.ok( true, 'Invoke handler right away if it was fired before' ); - } ); - - mw.hook( 'test.hook.fireTwiceBefore' ).fire().fire().add( function () { - assert.ok( true, 'Invoke handler right away if it was fired before (only last one)' ); - } ); - - chars = []; - - mw.hook( 'test.hook.many' ) - .add( function ( chr ) { - chars.push( chr ); - } ) - .fire( 'x' ).fire( 'y' ).fire( 'z' ) - .add( function ( chr ) { - assert.equal( chr, 'z', 'Adding callback later invokes right away with last data' ); - } ); - - assert.deepEqual( chars, [ 'x', 'y', 'z' ], 'Multiple callbacks with multiple fires' ); - - chars = []; - callback = function ( chr ) { - chars.push( chr ); - }; - - mw.hook( 'test.hook.variadic' ) - .add( - callback, - callback, - function ( chr ) { - chars.push( chr ); - }, - callback - ) - .fire( 'x' ) - .remove( - function () { - 'not-added'; - }, - callback - ) - .fire( 'y' ) - .remove( callback ) - .fire( 'z' ); - - assert.deepEqual( - chars, - [ 'x', 'x', 'x', 'x', 'y', 'z' ], - '"add" and "remove" support variadic arguments. ' + - '"add" does not filter unique. ' + - '"remove" removes all equal by reference. ' + - '"remove" is silent if the function is not found' - ); - } ); - }( mediaWiki ) );