Thu, 15 Jan 2015 21:03:48 +0100
Integrate friendly tips from Tor colleagues to make (or not) 4.5 alpha 3;
This includes removal of overloaded (but unused) methods, and addition of
a overlooked call to DataStruct::SetData(nsISupports, uint32_t, bool.)
1 /* Test String.prototype.repeat */
3 load(libdir + 'asserts.js');
5 assertEq("abc".repeat(1), "abc");
6 assertEq("abc".repeat(2), "abcabc");
7 assertEq("abc".repeat(3), "abcabcabc");
8 assertEq("a".repeat(10), "aaaaaaaaaa");
9 assertEq("abc".repeat(0), "");
10 assertEq("abc".repeat(2.9), "abcabc");
12 var myobj = {toString : (function () "abc"), repeat : String.prototype.repeat};
13 assertEq(myobj.repeat(1), "abc");
14 assertEq(myobj.repeat(2), "abcabc");
16 assertThrowsInstanceOf(function() {
17 "abc".repeat(-1);
18 }, RangeError,
19 "String.prototype.repeat should raise RangeError on negative arguments");
20 assertThrowsInstanceOf(function() {
21 "abc".repeat(Number.POSITIVE_INFINITY);
22 }, RangeError,
23 "String.prototype.repeat should raise RangeError on excedding maximum string length");
24 assertThrowsInstanceOf(function() {
25 "abc".repeat(1 << 29);
26 }, RangeError,
27 "String.prototype.repeat should raise RangeError on excedding maximum string length");
29 assertEq("".repeat(5), "");
30 assertEq("".repeat(1 << 29), "");