Go to the documentation of this file.
3 use Wikimedia\TestingAccessWrapper;
12 "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",
13 $this->
getLang()->normalizeForSearch(
14 "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
16 'convertDoubleWidth() with the full alphabet and digits'
25 $this->assertEquals( $expected, $this->
getLang()->formatTimePeriod( $seconds, $format ), $desc );
34 'formatTimePeriod() rounding (<10s)'
38 [
'noabbrevs' =>
true ],
40 'formatTimePeriod() rounding (<10s)'
46 'formatTimePeriod() rounding (<10s)'
50 [
'noabbrevs' =>
true ],
52 'formatTimePeriod() rounding (<10s)'
58 'formatTimePeriod() rounding (<60s)'
62 [
'noabbrevs' =>
true ],
64 'formatTimePeriod() rounding (<60s)'
70 'formatTimePeriod() rounding (<1h)'
74 [
'noabbrevs' =>
true ],
75 '2 minutes 0 seconds',
76 'formatTimePeriod() rounding (<1h)'
82 'formatTimePeriod() rounding (<1h)'
86 [
'noabbrevs' =>
true ],
87 '1 hour 0 minutes 0 seconds',
88 'formatTimePeriod() rounding (<1h)'
94 'formatTimePeriod() rounding (>=1h)'
98 [
'noabbrevs' =>
true ],
99 '2 hours 0 minutes 0 seconds',
100 'formatTimePeriod() rounding (>=1h)'
106 'formatTimePeriod() rounding (>=1h), avoidseconds'
110 [
'avoid' =>
'avoidseconds',
'noabbrevs' =>
true ],
112 'formatTimePeriod() rounding (>=1h), avoidseconds'
118 'formatTimePeriod() rounding (>=1h), avoidminutes'
122 [
'avoid' =>
'avoidminutes',
'noabbrevs' =>
true ],
124 'formatTimePeriod() rounding (>=1h), avoidminutes'
130 'formatTimePeriod() rounding (=48h), avoidseconds'
134 [
'avoid' =>
'avoidseconds',
'noabbrevs' =>
true ],
135 '48 hours 0 minutes',
136 'formatTimePeriod() rounding (=48h), avoidseconds'
142 'formatTimePeriod() rounding (>48h), avoidminutes'
146 [
'avoid' =>
'avoidminutes',
'noabbrevs' =>
true ],
148 'formatTimePeriod() rounding (>48h), avoidminutes'
154 'formatTimePeriod() rounding (>48h), avoidseconds'
158 [
'avoid' =>
'avoidseconds',
'noabbrevs' =>
true ],
159 '2 days 1 hour 0 minutes',
160 'formatTimePeriod() rounding (>48h), avoidseconds'
166 'formatTimePeriod() rounding (>48h), avoidminutes'
170 [
'avoid' =>
'avoidminutes',
'noabbrevs' =>
true ],
172 'formatTimePeriod() rounding (>48h), avoidminutes'
178 'formatTimePeriod() rounding (>48h), avoidseconds'
182 [
'avoid' =>
'avoidseconds',
'noabbrevs' =>
true ],
183 '3 days 0 hours 0 minutes',
184 'formatTimePeriod() rounding (>48h), avoidseconds'
190 'formatTimePeriod() rounding, (>48h), avoidseconds'
194 [
'avoid' =>
'avoidseconds',
'noabbrevs' =>
true ],
195 '2 days 0 hours 0 minutes',
196 'formatTimePeriod() rounding, (>48h), avoidseconds'
202 'formatTimePeriod() rounding, recursion, (>48h)'
206 [
'noabbrevs' =>
true ],
207 '2 days 1 hour 1 minute 1 second',
208 'formatTimePeriod() rounding, recursion, (>48h)'
220 $this->
getLang()->truncateForDatabase(
"1234567890", 0,
'XXX' ),
221 'truncate prefix, len 0, small ellipsis'
226 $this->
getLang()->truncateForDatabase(
"1234567890", 8,
'XXX' ),
227 'truncate prefix, small ellipsis'
232 $this->
getLang()->truncateForDatabase(
"123456789", 5,
'XXXXXXXXXXXXXXX' ),
233 'truncate prefix, large ellipsis'
238 $this->
getLang()->truncateForDatabase(
"1234567890", -8,
'XXX' ),
239 'truncate suffix, small ellipsis'
244 $this->
getLang()->truncateForDatabase(
"123456789", -5,
'XXXXXXXXXXXXXXX' ),
245 'truncate suffix, large ellipsis'
249 $this->
getLang()->truncateForDatabase(
"123 ", 9,
'XXX' ),
250 'truncate prefix, with spaces'
254 $this->
getLang()->truncateForDatabase(
"12345 8", 11,
'XXX' ),
255 'truncate prefix, with spaces and non-space ending'
259 $this->
getLang()->truncateForDatabase(
"1 234", -8,
'XXX' ),
260 'truncate suffix, with spaces'
264 $this->
getLang()->truncateForDatabase(
"1234567890", 5,
'XXX',
false ),
265 'truncate without adjustment'
269 $this->
getLang()->truncateForDatabase(
"泰乐菌素123456789", 11,
'...',
false ),
270 'truncate does not chop Unicode characters in half'
274 $this->
getLang()->truncateForDatabase(
"\n泰乐菌素123456789", 12,
'...',
false ),
275 'truncate does not chop Unicode characters in half if there is a preceding newline'
285 $expected, $string, $length, $ellipsis =
'...', $adjustLength =
true
289 $this->
getLang()->truncateForVisual( $string, $length, $ellipsis, $adjustLength )
298 [
"XXX",
"тестирам да ли ради", 0,
"XXX" ],
299 [
"testnXXX",
"testni scenarij", 8,
"XXX" ],
300 [
"حالة اختبار",
"حالة اختبار", 5,
"XXXXXXXXXXXXXXX" ],
301 [
"XXXедент",
"прецедент", -8,
"XXX" ],
302 [
"XXപിൾ",
"ആപ്പിൾ", -5,
"XX" ],
303 [
"神秘XXX",
"神秘 ", 9,
"XXX" ],
304 [
"ΔημιουργXXX",
"Δημιουργία Σύμπαντος", 11,
"XXX" ],
305 [
"XXXの家です",
"地球は私たちの唯 の家です", -8,
"XXX" ],
306 [
"زندگیXXX",
"زندگی زیباست", 6,
"XXX",
false ],
307 [
"ცხოვრება...",
"ცხოვრება არის საოცარი", 8,
"...",
false ],
308 [
"\nທ່ານ...",
"\nທ່ານບໍ່ຮູ້ຫນັງສື", 5,
"...",
false ],
329 [ 0,
'XXX',
"1234567890",
"XXX" ],
330 [ 8,
'XXX',
"1234567890",
"12345XXX" ],
331 [ 5,
'XXXXXXXXXXXXXXX',
'1234567890',
"1234567890" ],
333 '<p><span style="font-weight:bold;"></span></p>',
334 '<p><span style="font-weight:bold;"></span></p>',
337 '<p><span style="font-weight:bold;">123456789</span></p>',
338 '<p><span style="font-weight:bold;">***</span></p>',
341 '<p><span style="font-weight:bold;"> 23456789</span></p>',
342 '<p><span style="font-weight:bold;">***</span></p>',
345 '<p><span style="font-weight:bold;">123456789</span></p>',
346 '<p><span style="font-weight:bold;">***</span></p>',
349 '<p><span style="font-weight:bold;">123456789</span></p>',
350 '<p><span style="font-weight:bold;">1***</span></p>',
353 '<tt><span style="font-weight:bold;">123456789</span></tt>',
354 '<tt><span style="font-weight:bold;">12***</span></tt>',
357 '<p><a href="www.mediawiki.org">123456789</a></p>',
358 '<p><a href="www.mediawiki.org">123***</a></p>',
361 '<p><a href="www.mediawiki.org">12 456789</a></p>',
362 '<p><a href="www.mediawiki.org">12 ***</a></p>',
365 '<small><span style="font-weight:bold;">123<p id="#moo">456</p>789</span></small>',
366 '<small><span style="font-weight:bold;">123<p id="#moo">4***</p></span></small>',
369 '<div><span style="font-weight:bold;">123<span>4</span>56789</span></div>',
370 '<div><span style="font-weight:bold;">123<span>4</span>5***</span></div>',
373 '<p><table style="font-weight:bold;"><tr><td>123456789</td></tr></table></p>',
374 '<p><table style="font-weight:bold;"><tr><td>123456789</td></tr></table></p>',
377 '<p><font style="font-weight:bold;">123456789</font></p>',
378 '<p><font style="font-weight:bold;">123456789</font></p>',
391 "validating code $code $message"
403 [
'fr',
'two-letter code' ],
404 [
'fr-latn',
'two-letter code with lower case script code' ],
405 [
'fr-Latn-FR',
'two-letter code with title case script code and uppercase country code' ],
406 [
'fr-Latn-419',
'two-letter code with title case script code and region number' ],
407 [
'fr-FR',
'two-letter code with uppercase' ],
408 [
'ax-TZ',
'Not in the registry, but well-formed' ],
409 [
'fr-shadok',
'two-letter code with variant' ],
410 [
'fr-y-myext-myext2',
'non-x singleton' ],
411 [
'fra-Latn',
'ISO 639 can be 3-letters' ],
412 [
'fra',
'three-letter language code' ],
413 [
'fra-FX',
'three-letter language code with country code' ],
414 [
'i-klingon',
'grandfathered with singleton' ],
415 [
'I-kLINgon',
'tags are case-insensitive...' ],
416 [
'no-bok',
'grandfathered without singleton' ],
417 [
'i-enochian',
'Grandfathered' ],
418 [
'x-fr-CH',
'private use' ],
419 [
'es-419',
'two-letter code with region number' ],
420 [
'en-Latn-GB-boont-r-extended-sequence-x-private',
'weird, but well-formed' ],
421 [
'ab-x-abc-x-abc',
'anything goes after x' ],
422 [
'ab-x-abc-a-a',
'anything goes after x, including several non-x singletons' ],
423 [
'i-default',
'grandfathered' ],
424 [
'abcd-Latn',
'Language of 4 chars reserved for future use' ],
425 [
'AaBbCcDd-x-y-any-x',
'Language of 5-8 chars, registered' ],
426 [
'de-CH-1901',
'with country and year' ],
427 [
'en-US-x-twain',
'with country and singleton' ],
428 [
'zh-cmn',
'three-letter variant' ],
429 [
'zh-cmn-Hant',
'three-letter variant and script' ],
430 [
'zh-cmn-Hant-HK',
'three-letter variant, script and country' ],
431 [
'xr-p-lze',
'Extension' ],
443 "validating that code $code is a malformed language tag - $message"
455 [
'f',
'language too short' ],
456 [
'f-Latn',
'language too short with script' ],
457 [
'xr-lxs-qut',
'variants too short' ], # extlangS
458 [
'fr-Latn-F',
'region too short' ],
459 [
'a-value',
'language too short with region' ],
460 [
'tlh-a-b-foo',
'valid three-letter with wrong variant' ],
463 'grandfathered but not registered: invalid, even if we only test well-formedness'
465 [
'abcdefghi-012345678',
'numbers too long' ],
466 [
'ab-abc-abc-abc-abc',
'invalid extensions' ],
467 [
'ab-abcd-abc',
'invalid extensions' ],
468 [
'ab-ab-abc',
'invalid extensions' ],
469 [
'ab-123-abc',
'invalid extensions' ],
470 [
'a-Hant-ZH',
'short language with valid extensions' ],
471 [
'a1-Hant-ZH',
'invalid character in language' ],
472 [
'ab-abcde-abc',
'invalid extensions' ],
473 [
'ab-1abc-abc',
'invalid characters in extensions' ],
474 [
'ab-ab-abcd',
'invalid order of extensions' ],
475 [
'ab-123-abcd',
'invalid order of extensions' ],
476 [
'ab-abcde-abcd',
'invalid extensions' ],
477 [
'ab-1abc-abcd',
'invalid characters in extensions' ],
478 [
'ab-a-b',
'extensions too short' ],
479 [
'ab-a-x',
'extensions too short, even with singleton' ],
480 [
'ab--ab',
'two separators' ],
481 [
'ab-abc-',
'separator in the end' ],
482 [
'-ab-abc',
'separator in the beginning' ],
483 [
'abcd-efg',
'language too long' ],
484 [
'aabbccddE',
'tag too long' ],
485 [
'pa_guru',
'A tag with underscore is invalid in strict mode' ],
486 [
'de-f',
'subtag too short' ],
497 'pa_guru is a well-formed language tag in lenient mode'
507 $this->assertEquals( $expected,
509 "validating code $code $message"
515 [
'fr',
true,
'Two letters, minor case' ],
516 [
'EN',
false,
'Two letters, upper case' ],
517 [
'tyv',
true,
'Three letters' ],
518 [
'be-tarask',
true,
'With dash' ],
519 [
'be-x-old',
true,
'With extension (two dashes)' ],
520 [
'be_tarask',
false,
'Reject underscores' ],
532 "validating code $code - $message"
538 [
'fr',
'simple code' ],
539 [
'bat-smg',
'an MW legacy tag' ],
540 [
'sgs',
'an internal standard MW name, for which a legacy tag is used externally' ],
548 if ( !class_exists(
'LanguageNames' ) ) {
549 $this->markTestSkipped(
'The LanguageNames class is not available. '
550 .
'The CLDR extension is probably not installed.' );
555 'validating code "pal" an ancient language, which probably will '
556 .
'not appear in Names.php, but appears in CLDR in English'
568 "checking that code $code is invalid - $message"
574 [
'mw',
'non-existent two-letter code' ],
575 [
'foo"<bar',
'very invalid language code' ],
585 $this->
getLang()->sprintfDate(
'xiY',
'1234567890123' );
594 $this->
getLang()->sprintfDate(
'xiY',
'123456789012345' );
603 $this->
getLang()->sprintfDate(
'xiY',
'-1234567890123' );
614 $this->
getLang()->sprintfDate( $format, $ts,
null, $ttl ),
615 "sprintfDate('$format', '$ts'): $msg"
618 $dt =
new DateTime( $ts );
619 $lastValidTS = $dt->add(
new DateInterval(
'PT' . ( $ttl - 1 ) .
'S' ) )->format(
'YmdHis' );
622 $this->
getLang()->sprintfDate( $format, $lastValidTS,
null ),
623 "sprintfDate('$format', '$ts'): TTL $ttl too high (output was different at $lastValidTS)"
627 $dt =
new DateTime( $ts );
628 $newTS = $dt->add(
new DateInterval(
'P1Y1M8DT13H1M1S' ) )->format(
'YmdHis' );
631 $this->
getLang()->sprintfDate( $format, $newTS,
null ),
632 "sprintfDate('$format', '$ts'): Missing TTL (output was different at $newTS)"
643 $oldTZ = date_default_timezone_get();
644 $res = date_default_timezone_set(
'Asia/Seoul' );
646 $this->markTestSkipped(
"Error setting Timezone" );
651 $this->
getLang()->sprintfDate( $format, $ts ),
652 "sprintfDate('$format', '$ts'): $msg"
655 date_default_timezone_set( $oldTZ );
664 $tz =
new DateTimeZone(
'Asia/Seoul' );
666 $this->markTestSkipped(
"Error getting Timezone" );
671 $this->
getLang()->sprintfDate( $format, $ts, $tz ),
672 "sprintfDate('$format', '$ts', 'Asia/Seoul'): $msg"
689 'If the caller does not set the $ttl variable, do not compute it.'
691 $this->assertInternalType(
'int', $ttl,
'TTL should have been computed.' );
701 'Iranian calendar full year'
708 'Iranian calendar short year'
715 'ISO 8601 (week) year'
766 'Month index, not zero pad'
773 'Month index. Zero pad'
794 'Genitive month name (same in EN)'
801 'Day of month (not zero pad)'
808 'Day of month (zero-pad)'
815 'Day of year (zero-indexed)'
822 'Day of week (abbrev)'
836 'Day of week (Mon=1, Sun=7)'
843 'Day of week (Sun=0, Sat=6)'
885 '12 hour, zero padded'
934 'Days in current month'
939 '2012-01-02T09:07:05+00:00',
940 '2012-01-02T09:07:05+09:00',
946 'Mon, 02 Jan 2012 09:07:05 +0000',
947 'Mon, 02 Jan 2012 09:07:05 +0900',
955 'Timezone identifier'
976 'Timezone offset with colon'
983 'Timezone abbreviation'
990 'Timezone offset in seconds'
1018 'Hebrew number of days in month'
1025 'Hebrew genitive month name (No difference in EN)'
1074 'Raw numerals (doesn\'t mean much in EN)'
1077 '[[Y "(yea"\\r)]] \\"xx\\"',
1079 '[[2012 (year)]] "x"',
1080 '[[2012 (year)]] "x"',
1092 $this->assertEquals(
1094 $this->
getLang()->formatSize( $size ),
1095 "formatSize('$size'): $msg"
1155 $this->assertEquals(
1157 $this->
getLang()->formatBitrate( $bps ),
1158 "formatBitrate('$bps'): $msg"
1172 "999 bits per second"
1177 "1 kilobit per second"
1182 "1 megabit per second"
1187 "1 gigabit per second"
1192 "1 terabit per second"
1197 "1 petabit per second"
1202 "1 exabit per second"
1207 "1 zetabit per second"
1212 "1 yottabit per second"
1217 "1,000 yottabits per second"
1227 $this->assertEquals(
1229 $this->
getLang()->formatDuration( $duration, $intervals ),
1230 "formatDuration('$duration'): $expected"
1274 ( 365 + ( 24 * 3 + 25 ) / 400.0 ) * 86400,
1307 '2 hours, 30 minutes and 1 second'
1311 '1 hour and 1 second'
1314 31556952 + 2 * 86400 + 9000,
1315 '1 year, 2 days, 2 hours and 30 minutes'
1318 42 * 1000 * 31556952 + 42,
1319 '42 millennia and 42 seconds'
1337 31556952 + 2 * 86400 + 9000,
1338 '1 year, 2 days and 150 minutes',
1339 [
'years',
'days',
'minutes' ],
1344 [
'years',
'days' ],
1347 31556952 + 2 * 86400 + 9000,
1348 '1 year, 2 days and 150 minutes',
1349 [
'minutes',
'days',
'years' ],
1354 [
'days',
'years' ],
1364 $this->assertEquals(
1366 $this->
getLang()->checkTitleEncoding(
$s ),
1367 "checkTitleEncoding('$s')"
1375 [
"United States of America" ],
1376 [ rawurldecode(
"S%C3%A9rie%20t%C3%A9l%C3%A9vis%C3%A9e" ) ],
1379 "Acteur%7CAlbert%20Robbins%7CAnglais%7CAnn%20Donahue%7CAnthony%20E.%20Zuiker%7CCarol%20Mendelsohn"
1387 "Acteur%7CAlbert%20Robbins%7CAnglais%7CAnn%20Donahue%7CAnthony%20E.%20Zuiker%7CCarol%20Mendelsohn%7C"
1388 .
"Catherine%20Willows%7CDavid%20Hodges%7CDavid%20Phillips%7CGil%20Grissom%7CGreg%20Sanders%7CHodges%7C"
1389 .
"Internet%20Movie%20Database%7CJim%20Brass%7CLady%20Heather%7C"
1390 .
"Les%20Experts%20(s%C3%A9rie%20t%C3%A9l%C3%A9vis%C3%A9e)%7CLes%20Experts%20:%20Manhattan%7C"
1391 .
"Les%20Experts%20:%20Miami%7CListe%20des%20personnages%20des%20Experts%7C"
1392 .
"Liste%20des%20%C3%A9pisodes%20des%20Experts%7CMod%C3%A8le%20discussion:Palette%20Les%20Experts%7C"
1393 .
"Nick%20Stokes%7CPersonnage%20de%20fiction%7CPersonnage%20fictif%7CPersonnage%20de%20fiction%7C"
1394 .
"Personnages%20r%C3%A9currents%20dans%20Les%20Experts%7CRaymond%20Langston%7CRiley%20Adams%7C"
1395 .
"Saison%201%20des%20Experts%7CSaison%2010%20des%20Experts%7CSaison%2011%20des%20Experts%7C"
1396 .
"Saison%2012%20des%20Experts%7CSaison%202%20des%20Experts%7CSaison%203%20des%20Experts%7C"
1397 .
"Saison%204%20des%20Experts%7CSaison%205%20des%20Experts%7CSaison%206%20des%20Experts%7C"
1398 .
"Saison%207%20des%20Experts%7CSaison%208%20des%20Experts%7CSaison%209%20des%20Experts%7C"
1399 .
"Sara%20Sidle%7CSofia%20Curtis%7CS%C3%A9rie%20t%C3%A9l%C3%A9vis%C3%A9e%7CWallace%20Langham%7C"
1400 .
"Warrick%20Brown%7CWendy%20Simms%7C%C3%89tats-Unis"
1405 "Mod%C3%A8le%3AArrondissements%20homonymes%7CMod%C3%A8le%3ABandeau%20standard%20pour%20page%20d'homonymie%7C"
1406 .
"Mod%C3%A8le%3ABatailles%20homonymes%7CMod%C3%A8le%3ACantons%20homonymes%7C"
1407 .
"Mod%C3%A8le%3ACommunes%20fran%C3%A7aises%20homonymes%7CMod%C3%A8le%3AFilms%20homonymes%7C"
1408 .
"Mod%C3%A8le%3AGouvernements%20homonymes%7CMod%C3%A8le%3AGuerres%20homonymes%7CMod%C3%A8le%3AHomonymie%7C"
1409 .
"Mod%C3%A8le%3AHomonymie%20bateau%7CMod%C3%A8le%3AHomonymie%20d'%C3%A9tablissements%20scolaires%20ou"
1410 .
"%20universitaires%7CMod%C3%A8le%3AHomonymie%20d'%C3%AEles%7CMod%C3%A8le%3AHomonymie%20de%20clubs%20sportifs%7C"
1411 .
"Mod%C3%A8le%3AHomonymie%20de%20comt%C3%A9s%7CMod%C3%A8le%3AHomonymie%20de%20monument%7C"
1412 .
"Mod%C3%A8le%3AHomonymie%20de%20nom%20romain%7CMod%C3%A8le%3AHomonymie%20de%20parti%20politique%7C"
1413 .
"Mod%C3%A8le%3AHomonymie%20de%20route%7CMod%C3%A8le%3AHomonymie%20dynastique%7C"
1414 .
"Mod%C3%A8le%3AHomonymie%20vid%C3%A9oludique%7CMod%C3%A8le%3AHomonymie%20%C3%A9difice%20religieux%7C"
1415 .
"Mod%C3%A8le%3AInternationalisation%7CMod%C3%A8le%3AIsom%C3%A9rie%7CMod%C3%A8le%3AParonymie%7C"
1416 .
"Mod%C3%A8le%3APatronyme%7CMod%C3%A8le%3APatronyme%20basque%7CMod%C3%A8le%3APatronyme%20italien%7C"
1417 .
"Mod%C3%A8le%3APatronymie%7CMod%C3%A8le%3APersonnes%20homonymes%7CMod%C3%A8le%3ASaints%20homonymes%7C"
1418 .
"Mod%C3%A8le%3ATitres%20homonymes%7CMod%C3%A8le%3AToponymie%7CMod%C3%A8le%3AUnit%C3%A9s%20homonymes%7C"
1419 .
"Mod%C3%A8le%3AVilles%20homonymes%7CMod%C3%A8le%3A%C3%89difices%20religieux%20homonymes"
1431 $this->assertEquals(
1434 "romanNumeral('$num')"
1471 [ 1989,
'MCMLXXXIX' ],
1477 [ 7000,
'MMMMMMM' ],
1478 [ 8000,
'MMMMMMMM' ],
1479 [ 9000,
'MMMMMMMMM' ],
1480 [ 9999,
'MMMMMMMMMCMXCIX' ],
1481 [ 10000,
'MMMMMMMMMM' ],
1490 $this->assertEquals(
1493 "hebrewNumeral('$num')"
1540 [ 2000,
"ב' אלפים" ],
1542 [ 3000,
"ג' אלפים" ],
1543 [ 4000,
"ד' אלפים" ],
1544 [ 4904,
"ד'תתק\"ד" ],
1545 [ 5000,
"ה' אלפים" ],
1546 [ 5680,
"ה'תר\"ף" ],
1547 [ 5690,
"ה'תר\"ץ" ],
1548 [ 5708,
"ה'תש\"ח" ],
1549 [ 5720,
"ה'תש\"ך" ],
1550 [ 5740,
"ה'תש\"ם" ],
1551 [ 5750,
"ה'תש\"ן" ],
1552 [ 5775,
"ה'תשע\"ה" ],
1561 $chosen = $this->
getLang()->convertPlural( $number, $forms );
1562 $this->assertEquals( $expected, $chosen );
1569 'singular',
'plural'
1571 [
'explicit zero', 0, [
1572 '0=explicit zero',
'singular',
'plural'
1574 [
'explicit one', 1, [
1575 'singular',
'plural',
'1=explicit one',
1578 'singular',
'plural',
'0=explicit zero',
1581 '0=explicit zero',
'1=explicit one',
'singular',
'plural'
1583 [
'explicit eleven', 11, [
1584 'singular',
'plural',
'11=explicit eleven',
1587 'singular',
'plural',
'11=explicit twelve',
1590 'singular',
'plural',
'=explicit form',
1593 'kissa=kala',
'1=2=3',
'other',
1596 '0=explicit zero',
'1=explicit one',
1609 $this->assertEquals(
1611 $lang->embedBidi(
'123' ),
1612 'embedBidi with neutral argument'
1614 $this->assertEquals(
1615 $lre .
'Ben_(WMF)' . $pdf,
1616 $lang->embedBidi(
'Ben_(WMF)' ),
1617 'embedBidi with LTR argument'
1619 $this->assertEquals(
1620 $rle .
'יהודי (מנוחין)' . $pdf,
1621 $lang->embedBidi(
'יהודי (מנוחין)' ),
1622 'embedBidi with RTL argument'
1632 if ( is_array( $expectedData ) ) {
1633 list( $func, $arg ) = $expectedData;
1634 $expected =
$lang->$func( $arg );
1636 $expected = $expectedData;
1638 $this->assertEquals( $expected,
$lang->translateBlockExpiry( $str,
null, $now ), $desc );
1643 [
'2 hours',
'2 hours', 0,
'simple data from ipboptions' ],
1644 [
'indefinite',
'infinite', 0,
'infinite from ipboptions' ],
1645 [
'indefinite',
'infinity', 0,
'alternative infinite from ipboptions' ],
1646 [
'indefinite',
'indefinite', 0,
'another alternative infinite from ipboptions' ],
1647 [ [
'formatDuration', 1023 * 60 * 60 ],
'1023 hours', 0,
'relative' ],
1648 [ [
'formatDuration', -1023 ],
'-1023 seconds', 0,
'negative relative' ],
1650 [
'formatDuration', 1023 * 60 * 60 ],
1653 'relative with initial timestamp'
1655 [ [
'formatDuration', 0 ],
'now', 0,
'now' ],
1657 [
'timeanddate',
'20120102070000' ],
1658 '2012-1-1 7:00 +1 day',
1660 'mixed, handled as absolute'
1662 [ [
'timeanddate',
'19910203040506' ],
'1991-2-3 4:05:06', 0,
'absolute' ],
1663 [ [
'timeanddate',
'19700101000000' ],
'1970-1-1 0:00:00', 0,
'absolute at epoch' ],
1664 [ [
'timeanddate',
'19691231235959' ],
'1969-12-31 23:59:59', 0,
'time before epoch' ],
1666 [
'timeanddate',
'19910910000000' ],
1671 [
'dummy',
'dummy', 0,
'return garbage as is' ],
1680 $translateNumerals, $langCode, $number, $nocommafy, $expected
1682 $this->
setMwGlobals( [
'wgTranslateNumerals' => $translateNumerals ] );
1684 $formattedNum =
$lang->formatNum( $number, $nocommafy );
1685 $this->
assertType(
'string', $formattedNum );
1686 $this->assertEquals( $expected, $formattedNum );
1691 [
true,
'en', 100,
false,
'100' ],
1692 [
true,
'en', 101,
true,
'101' ],
1693 [
false,
'en', 103,
false,
'103' ],
1694 [
false,
'en', 104,
true,
'104' ],
1695 [
true,
'en',
'105',
false,
'105' ],
1696 [
true,
'en',
'106',
true,
'106' ],
1697 [
false,
'en',
'107',
false,
'107' ],
1698 [
false,
'en',
'108',
true,
'108' ],
1709 $localisedNum =
$lang->formatNum( $number );
1710 $normalisedNum =
$lang->parseFormattedNumber( $localisedNum );
1712 $this->assertEquals( $number, $normalisedNum );
1722 [
'zh-classical', 7432 ]
1731 $this->assertEquals(
1733 $this->
getLang()->commafy( $number ),
1734 "commafy('$number')"
1744 [ 10000,
'10,000' ],
1745 [ 100000,
'100,000' ],
1746 [ 1000000,
'1,000,000' ],
1747 [ -1.0001,
'-1.0001' ],
1748 [ 1.0001,
'1.0001' ],
1749 [ 10.0001,
'10.0001' ],
1750 [ 100.0001,
'100.0001' ],
1751 [ 1000.0001,
'1,000.0001' ],
1752 [ 10000.0001,
'10,000.0001' ],
1753 [ 100000.0001,
'100,000.0001' ],
1754 [ 1000000.0001,
'1,000,000.0001' ],
1755 [
'200000000000000000000',
'200,000,000,000,000,000,000' ],
1756 [
'-200000000000000000000',
'-200,000,000,000,000,000,000' ],
1765 $and =
$lang->getMessageFromDB(
'and' );
1766 $s =
$lang->getMessageFromDB(
'word-separator' );
1767 $c =
$lang->getMessageFromDB(
'comma-separator' );
1769 $this->assertEquals(
'',
$lang->listToText( [] ) );
1770 $this->assertEquals(
'a',
$lang->listToText( [
'a' ] ) );
1771 $this->assertEquals(
"a{$and}{$s}b",
$lang->listToText( [
'a',
'b' ] ) );
1772 $this->assertEquals(
"a{$c}b{$and}{$s}c",
$lang->listToText( [
'a',
'b',
'c' ] ) );
1773 $this->assertEquals(
"a{$c}b{$c}c{$and}{$s}d",
$lang->listToText( [
'a',
'b',
'c',
'd' ] ) );
1780 $languageClass = TestingAccessWrapper::newFromClass(
Language::class );
1785 $this->assertNotCount( 0,
1794 $this->assertNotCount( 0, $languageClass->fallbackLanguageCache );
1797 $lang->getGrammarTransformations();
1798 $this->assertNotNull( $languageClass->grammarTransformations );
1802 $this->assertNotNull( $languageClass->languageNameCache );
1807 $this->assertCount( 0,
1810 $this->assertCount( 0, $languageClass->fallbackLanguageCache );
1811 $this->assertNull( $languageClass->grammarTransformations );
1812 $this->assertNull( $languageClass->languageNameCache );
1825 [
'en',
true,
'is supported language' ],
1826 [
'fi',
true,
'is supported language' ],
1827 [
'bunny',
false,
'is not supported language' ],
1828 [
'FI',
false,
'is not supported language, input should be in lower case' ],
1838 if ( is_null( $expected ) ) {
1839 $this->assertNull(
$lang->getParentLanguage(), $comment );
1841 $this->assertEquals( $expected,
$lang->getParentLanguage()->getCode(), $comment );
1847 [
'zh-cn',
'zh',
'zh is the parent language of zh-cn' ],
1848 [
'zh',
'zh',
'zh is defined as the parent language of zh, '
1849 .
'because zh converter can convert zh-cn to zh' ],
1850 [
'zh-invalid',
null,
'do not be fooled by arbitrarily composed language codes' ],
1851 [
'de-formal',
null,
'de does not have converter' ],
1852 [
'de',
null,
'de does not have converter' ],
1862 $aliases = $language->getNamespaceAliases();
1863 foreach ( $subset
as $alias => $nsId ) {
1864 $this->assertEquals( $nsId, $aliases[$alias] );
1887 $this->assertTrue( $en->hasVariant(
'en' ),
'base is always a variant' );
1888 $this->assertFalse( $en->hasVariant(
'en-bogus' ),
'bogus en variant' );
1891 $this->assertTrue( $bogus->hasVariant(
'bogus' ),
'base is always a variant' );
1901 $this->assertTrue( $en1->equals( $en2 ),
'en1 equals en2' );
1902 $this->assertTrue( $en2->equals( $en3 ),
'en2 equals en3' );
1903 $this->assertTrue( $en3->equals( $en1 ),
'en3 equals en1' );
1906 $this->assertFalse( $en1->equals( $fr ),
'en not equals fr' );
1910 $this->assertTrue( $ar1->equals( $ar2 ),
'ar equals ar' );
testLanguageConvertDoubleWidthToSingleWidth()
Language::convertDoubleWidth Language::normalizeForSearch.
static provideCheckTitleEncodingData()
testMalformedLanguageTag( $code, $message='')
Negative test for Language::isWellFormedLanguageTag() provideMalformedLanguageTags Language::isWellFo...
Helping class to run tests using a clean language instance.
static clearCaches()
Intended for tests that may change configuration in a way that invalidates caches.
processing should stop and the error should be shown to the user * false
testFormatTimePeriod( $seconds, $format, $expected, $desc)
provideFormattableTimes Language::formatTimePeriod
testBuiltInCodeValidation( $code, $expected, $message='')
Test Language::isValidBuiltInCode() provideLanguageCodes Language::isValidBuiltInCode.
static provideWellFormedLanguageTags()
The test cases are based on the tests in the GaBuZoMeu parser written by Stéphane Bortzmeyer bortzmey...
testSprintfDateNoTtlIfNotNeeded()
sprintfDate should only calculate a TTL if the caller is going to use it.
testKnownCldrLanguageTag()
Language::isKnownLanguageTag.
if(!isset( $args[0])) $lang
wfTimestamp( $outputtype=TS_UNIX, $ts=0)
Get a timestamp string in one of various formats.
static provideCommafyData()
testUnknownLanguageTag( $code, $message='')
Negative tests for Language::isKnownLanguageTag() provideUnKnownLanguageTags Language::isKnownLanguag...
testFormatSize( $size, $expected, $msg)
provideFormatSizes Language::formatSize
testGetNamespaceAliases( $languageCode, $subset)
provideGetNamespaceAliases Language::getNamespaceAliases
testTruncateForDatabase()
Language::truncateForDatabase Language::truncateInternal.
testCheckTitleEncoding( $s)
provideCheckTitleEncodingData Language::checkTitleEncoding
static providePluralData()
testSprintfDate( $format, $ts, $expected, $msg)
provideSprintfDateSamples Language::sprintfDate
static provideMalformedLanguageTags()
The test cases are based on the tests in the GaBuZoMeu parser written by Stéphane Bortzmeyer bortzmey...
testFormatBitrate( $bps, $expected, $msg)
provideFormatBitrate Language::formatBitrate
testEquals()
Language::equals.
static provideHTMLTruncateData()
injection txt This is an overview of how MediaWiki makes use of dependency injection The design described here grew from the discussion of RFC T384 The term dependency this means that anything an object needs to operate should be injected from the the object itself should only know narrow no concrete implementation of the logic it relies on The requirement to inject everything typically results in an architecture that based on two main types of and essentially stateless service objects that use other service objects to operate on the value objects As of the beginning MediaWiki is only starting to use the DI approach Much of the code still relies on global state or direct resulting in a highly cyclical dependency which acts as the top level factory for services in MediaWiki which can be used to gain access to default instances of various services MediaWikiServices however also allows new services to be defined and default services to be redefined Services are defined or redefined by providing a callback the instantiator that will return a new instance of the service When it will create an instance of MediaWikiServices and populate it with the services defined in the files listed by thereby bootstrapping the DI framework Per $wgServiceWiringFiles lists includes ServiceWiring php
static isWellFormedLanguageTag( $code, $lenient=false)
Returns true if a language code string is a well-formed language tag according to RFC 5646.
static provideFormatDuration()
testSprintfDateNoZone( $format, $ts, $expected, $ignore, $msg)
sprintfDate should always use UTC when no zone is given.
static isKnownLanguageTag( $tag)
Returns true if a language code is an IETF tag known to MediaWiki.
static provideHebrewNumeralsData()
testSprintfDateTooLongTimestamp()
Test too long timestamp MWException Language::sprintfDate.
static getLocalisationCache()
Get the LocalisationCache instance.
testParseFormattedNumber( $langCode, $number)
Language::parseFormattedNumber parseFormattedNumberProvider.
testKnownLanguageTag( $code, $message='')
Test Language::isKnownLanguageTag() provideKnownLanguageTags Language::isKnownLanguageTag.
testLenientLanguageTag()
Negative test for Language::isWellFormedLanguageTag() Language::isWellFormedLanguageTag.
testHebrewNumeral( $num, $numerals)
provideHebrewNumeralsData Language::hebrewNumeral
if(is_array( $mode)) switch( $mode) $input
testListToText()
Language::listToText.
testRomanNumerals( $num, $numerals)
provideRomanNumeralsData Language::romanNumeral
testHasVariant()
Language::hasVariant.
parseFormattedNumberProvider()
testClearCaches()
Language::clearCaches.
static provideTruncateData()
testFormatNum( $translateNumerals, $langCode, $number, $nocommafy, $expected)
provideFormatNum Language::formatNum
testFormatDuration( $duration, $expected, $intervals=[])
provideFormatDuration Language::formatDuration
as see the revision history and available at free of to any person obtaining a copy of this software and associated documentation to deal in the Software without including without limitation the rights to use
this hook is for auditing only or null if authentication failed before getting that far or null if we can t even determine that probably a stub it is not rendered in wiki pages or galleries in category pages allow injecting custom HTML after the section Any uses of the hook need to handle escaping see BaseTemplate::getToolbox and BaseTemplate::makeListItem for details on the format of individual items inside of this array or by returning and letting standard HTTP rendering take place modifiable or by returning false and taking over the output modifiable & $code
static provideKnownLanguageTags()
static provideTranslateBlockExpiry()
static provideGetNamespaceAliases()
wfTimestampNow()
Convenience function; returns MediaWiki timestamp for the present time.
static provideIsSupportedLanguage()
deferred txt A few of the database updates required by various functions here can be deferred until after the result page is displayed to the user For updating the view updating the linked to tables after a etc PHP does not yet have any way to tell the server to actually return and disconnect while still running these but it might have such a feature in the future We handle these by creating a deferred update object and putting those objects on a global list
static provideSprintfDateSamples()
testGetParentLanguage( $code, $expected, $comment)
provideGetParentLanguage Language::getParentLanguage
static isValidBuiltInCode( $code)
Returns true if a language code is of a valid form for the purposes of internal customisation of Medi...
static hebrewNumeral( $num)
Hebrew Gematria number formatting up to 9999.
testConvertPlural( $expected, $number, $forms)
providePluralData Language::convertPlural
testTranslateBlockExpiry( $expectedData, $str, $now, $desc)
Language::translateBlockExpiry() provideTranslateBlockExpiry.
testCommafy( $number, $numbersWithCommas)
Language::commafy() provideCommafyData.
static provideFormattableTimes()
testTruncateForVisual( $expected, $string, $length, $ellipsis='...', $adjustLength=true)
provideTruncateData Language::truncateForVisual Language::truncateInternal
static provideFormatSizes()
testSprintfDateNotAllDigitTimestamp()
Test too short timestamp MWException Language::sprintfDate.
static provideFormatBitrate()
static getFallbacksIncludingSiteLanguage( $code)
Get the ordered list of fallback languages, ending with the fallback language chain for the site lang...
This document is intended to provide useful advice for parties seeking to redistribute MediaWiki to end users It s targeted particularly at maintainers for Linux since it s been observed that distribution packages of MediaWiki often break We ve consistently had to recommend that users seeking support use official tarballs instead of their distribution s and this often solves whatever problem the user is having It would be nice if this could such as
static provideRomanNumeralsData()
static provideLanguageCodes()
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return true
static romanNumeral( $num)
Roman number formatting up to 10000.
testEmbedBidi()
Language::embedBidi()
static factory( $code)
Get a cached or new language object for a given language code.
testWellFormedLanguageTag( $code, $message='')
Test Language::isWellFormedLanguageTag() provideWellFormedLanguageTags Language::isWellFormedLanguage...
you have access to all of the normal MediaWiki so you can get a DB use the etc For full docs on the Maintenance class
static provideGetParentLanguage()
static isSupportedLanguage( $code)
Checks whether any localisation is available for that language tag in MediaWiki (MessagesXx....
static fetchLanguageNames( $inLanguage=self::AS_AUTONYMS, $include='mw')
Get an array of language names, indexed by code.
static LocalisationCache $dataCache
testSprintfDateTZ( $format, $ts, $ignore, $expected, $msg)
sprintfDate should use passed timezone provideSprintfDateSamples Language::sprintfDate
testSprintfDateTooShortTimestamp()
Test too short timestamp MWException Language::sprintfDate.
testIsSupportedLanguage( $code, $expected, $comment)
provideIsSupportedLanguage Language::isSupportedLanguage
Internationalisation code.
testTruncateHtml( $len, $ellipsis, $input, $expected)
provideHTMLTruncateData Language::truncateHTML
static provideUnknownLanguageTags()