js/src/jit-test/tests/basic/testReplaceMap.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.

     2 // String.replace on functions returning hashmap elements.
     4 function first() {
     5   var arr = {a: "hello", b: "there"};
     6   var s = 'a|b';
     7   return s.replace(/[a-z]/g, function(a) { return arr[a]; }, 'g');
     8 }
     9 assertEq(first(), "hello|there");
    11 function second() {
    12   var arr = {a: "hello", c: "there"};
    13   var s = 'a|b|c';
    14   return s.replace(/[a-z]/g, function(a) { return arr[a]; }, 'g');
    15 }
    16 assertEq(second(), "hello|undefined|there");
    18 Object.defineProperty(Object.prototype, "b", {get: function() { return "what"; }});
    20 assertEq(second(), "hello|what|there");
    22 function third() {
    23   var arr = {a: "hello", b: {toString: function() { arr = {}; return "three"; }}, c: "there"};
    24   var s = 'a|b|c';
    25   return s.replace(/[a-z]/g, function(a) { return arr[a]; }, 'g');
    26 }
    27 assertEq(third(), "hello|three|undefined");

mercurial