js/src/jit-test/tests/basic/string-repeat.js

Sat, 03 Jan 2015 20:18:00 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Sat, 03 Jan 2015 20:18:00 +0100
branch
TOR_BUG_3246
changeset 7
129ffea94266
permissions
-rw-r--r--

Conditionally enable double key logic according to:
private browsing mode or privacy.thirdparty.isolate preference and
implement in GetCookieStringCommon and FindCookie where it counts...
With some reservations of how to convince FindCookie users to test
condition and pass a nullptr when disabling double key logic.

     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), "");

mercurial