js/src/tests/ecma_3/Object/8.6.1-01.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.

michael@0 1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
michael@0 2 /* This Source Code Form is subject to the terms of the Mozilla Public
michael@0 3 * License, v. 2.0. If a copy of the MPL was not distributed with this
michael@0 4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
michael@0 5
michael@0 6 //-----------------------------------------------------------------------------
michael@0 7
michael@0 8 var BUGNUMBER = 315436;
michael@0 9 var summary = 'In strict mode, setting a read-only property should generate a warning';
michael@0 10
michael@0 11 printBugNumber(BUGNUMBER);
michael@0 12 printStatus (summary);
michael@0 13
michael@0 14 enterFunc (String (BUGNUMBER));
michael@0 15
michael@0 16 // should throw an error in strict mode
michael@0 17 var actual = '';
michael@0 18 var expect = '"length" is read-only';
michael@0 19 var status = summary + ': Throw if STRICT and WERROR is enabled';
michael@0 20
michael@0 21 if (!options().match(/strict/))
michael@0 22 {
michael@0 23 options('strict');
michael@0 24 }
michael@0 25 if (!options().match(/werror/))
michael@0 26 {
michael@0 27 options('werror');
michael@0 28 }
michael@0 29
michael@0 30 try
michael@0 31 {
michael@0 32 var s = new String ('abc');
michael@0 33 s.length = 0;
michael@0 34 }
michael@0 35 catch (e)
michael@0 36 {
michael@0 37 actual = e.message;
michael@0 38 }
michael@0 39
michael@0 40 reportCompare(expect, actual, status);
michael@0 41
michael@0 42 // should not throw an error if in strict mode and WERROR is false
michael@0 43
michael@0 44 actual = 'did not throw';
michael@0 45 expect = 'did not throw';
michael@0 46 var status = summary + ': Do not throw if STRICT is enabled and WERROR is disabled';
michael@0 47
michael@0 48 // toggle werror off
michael@0 49 options('werror');
michael@0 50
michael@0 51 try
michael@0 52 {
michael@0 53 s.length = 0;
michael@0 54 }
michael@0 55 catch (e)
michael@0 56 {
michael@0 57 actual = e.message;
michael@0 58 }
michael@0 59
michael@0 60 reportCompare(expect, actual, status);
michael@0 61
michael@0 62 // should not throw an error if not in strict mode
michael@0 63
michael@0 64 actual = 'did not throw';
michael@0 65 expect = 'did not throw';
michael@0 66 var status = summary + ': Do not throw if not in strict mode';
michael@0 67
michael@0 68 // toggle strict off
michael@0 69 options('strict');
michael@0 70
michael@0 71 try
michael@0 72 {
michael@0 73 s.length = 0;
michael@0 74 }
michael@0 75 catch (e)
michael@0 76 {
michael@0 77 actual = e.message;
michael@0 78 }
michael@0 79
michael@0 80 reportCompare(expect, actual, status);

mercurial