dom/bindings/test/test_lenientThis.html

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 <!doctype html>
     2 <meta charset=utf-8>
     3 <title>[LenientThis]</title>
     4 <script src=/resources/testharness.js></script>
     5 <script src=/resources/testharnessreport.js></script>
     6 <div id=log></div>
     7 <script>
     8 function noop1() { }
     9 function noop2() { }
    11 test(function() {
    12   var desc = Object.getOwnPropertyDescriptor(Document.prototype, "onreadystatechange");
    14   document.onreadystatechange = noop1;
    15   assert_equals(document.onreadystatechange, noop1, "document.onreadystatechange == noop1");
    16   assert_equals(desc.get.call({ }), undefined, "document.onreadystatechange getter.call({}) == undefined");
    17 }, "invoking Document.onreadystatechange's getter with an invalid this object returns undefined");
    19 test(function() {
    20   var desc = Object.getOwnPropertyDescriptor(Document.prototype, "onreadystatechange");
    22   document.onreadystatechange = noop1;
    23   assert_equals(document.onreadystatechange, noop1, "document.onreadystatechange == noop1");
    24   assert_equals(desc.set.call({ }, noop2), undefined, "document.onreadystatechange setter.call({}) == undefined");
    25   assert_equals(document.onreadystatechange, noop1, "document.onreadystatechange == noop1 (still)");
    26 }, "invoking Document.onreadystatechange's setter with an invalid this object does nothing and returns undefined");
    27 </script>

mercurial