2 * Some misc JavaScript compatibility tests,
3 * just to make sure the environments we run in are consistent.
6 QUnit
.module( 'mediawiki.jscompat', QUnit
.newMwEnvironment() );
8 QUnit
.test( 'Variable with Unicode letter in name', 3, function ( assert
) {
14 assert
.deepEqual( ŝablono
, orig
, 'ŝablono' );
15 assert
.deepEqual( \u015dablono, orig
, '\\u015dablono' );
16 assert
.deepEqual( \u015Dablono, orig
, '\\u015Dablono' );
20 // Not that we need this. ;)
21 // This fails on IE 6-8
22 // Works on IE 9, Firefox 6, Chrome 14
23 QUnit.test( 'Keyword workaround: "if" as variable name using Unicode escapes', function ( assert ) {
24 var orig = "another token";
26 assert.deepEqual( \u0069\u0066, orig, '\\u0069\\u0066' );
31 // Not that we need this. ;)
32 // This fails on IE 6-9
33 // Works on Firefox 6, Chrome 14
34 QUnit.test( 'Keyword workaround: "if" as member variable name using Unicode escapes', function ( assert ) {
35 var orig = "another token";
37 foo.\u0069\u0066 = orig;
38 assert.deepEqual( foo.\u0069\u0066, orig, 'foo.\\u0069\\u0066' );
42 QUnit
.test( 'Stripping of single initial newline from textarea\'s literal contents (bug 12130)', function ( assert
) {
47 QUnit
.expect( maxn
* 2 );
49 function repeat( str
, n
) {
56 return out
.join( str
);
60 for ( n
= 0; n
< maxn
; n
++ ) {
61 expected
= repeat( '\n', n
) + 'some text';
63 $textarea
= $( '<textarea>\n' + expected
+ '</textarea>' );
64 assert
.equal( $textarea
.val(), expected
, 'Expecting ' + n
+ ' newlines (HTML contained ' + (n
+ 1) + ')' );
66 $textarea
= $( '<textarea>' ).val( expected
);
67 assert
.equal( $textarea
.val(), expected
, 'Expecting ' + n
+ ' newlines (from DOM set with ' + n
+ ')' );