js/src/tests/js1_5/extensions/regress-455380.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 /*
michael@0 3 * Any copyright is dedicated to the Public Domain.
michael@0 4 * http://creativecommons.org/licenses/publicdomain/
michael@0 5 * Contributor: Robert Sayre
michael@0 6 */
michael@0 7
michael@0 8 //-----------------------------------------------------------------------------
michael@0 9 var BUGNUMBER = 455380;
michael@0 10 var summary = 'Do not assert with JIT: !lhs->isQuad() && !rhs->isQuad()';
michael@0 11 var actual = 'No Crash';
michael@0 12 var expect = 'No Crash';
michael@0 13
michael@0 14 printBugNumber(BUGNUMBER);
michael@0 15 printStatus (summary);
michael@0 16
michael@0 17 jit(true);
michael@0 18
michael@0 19 const IS_TOKEN_ARRAY =
michael@0 20 [0, 0, 0, 0, 0, 0, 0, 0, // 0
michael@0 21 0, 0, 0, 0, 0, 0, 0, 0, // 8
michael@0 22 0, 0, 0, 0, 0, 0, 0, 0, // 16
michael@0 23 0, 0, 0, 0, 0, 0, 0, 0, // 24
michael@0 24
michael@0 25 0, 1, 0, 1, 1, 1, 1, 1, // 32
michael@0 26 0, 0, 1, 1, 0, 1, 1, 0, // 40
michael@0 27 1, 1, 1, 1, 1, 1, 1, 1, // 48
michael@0 28 1, 1, 0, 0, 0, 0, 0, 0, // 56
michael@0 29
michael@0 30 0, 1, 1, 1, 1, 1, 1, 1, // 64
michael@0 31 1, 1, 1, 1, 1, 1, 1, 1, // 72
michael@0 32 1, 1, 1, 1, 1, 1, 1, 1, // 80
michael@0 33 1, 1, 1, 0, 0, 0, 1, 1, // 88
michael@0 34
michael@0 35 1, 1, 1, 1, 1, 1, 1, 1, // 96
michael@0 36 1, 1, 1, 1, 1, 1, 1, 1, // 104
michael@0 37 1, 1, 1, 1, 1, 1, 1, 1, // 112
michael@0 38 1, 1, 1, 0, 1, 0, 1]; // 120
michael@0 39
michael@0 40 const headerUtils = {
michael@0 41 normalizeFieldName: function(fieldName)
michael@0 42 {
michael@0 43 if (fieldName == "")
michael@0 44 throw "error: empty string";
michael@0 45
michael@0 46 for (var i = 0, sz = fieldName.length; i < sz; i++)
michael@0 47 {
michael@0 48 if (!IS_TOKEN_ARRAY[fieldName.charCodeAt(i)])
michael@0 49 {
michael@0 50 throw (fieldName + " is not a valid header field name!");
michael@0 51 }
michael@0 52 }
michael@0 53
michael@0 54 return fieldName.toLowerCase();
michael@0 55 }
michael@0 56 };
michael@0 57
michael@0 58 headerUtils.normalizeFieldName("Host");
michael@0 59
michael@0 60 jit(false);
michael@0 61
michael@0 62 reportCompare(expect, actual, summary);

mercurial