mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Merge mozilla-central to mozilla-inbound
This commit is contained in:
commit
4d946bd718
@ -22,6 +22,7 @@
|
|||||||
"MOZILLA_OFFICIAL": "1",
|
"MOZILLA_OFFICIAL": "1",
|
||||||
"B2GUPDATER": "1"
|
"B2GUPDATER": "1"
|
||||||
},
|
},
|
||||||
|
"gecko_l10n_root": "http://hg.mozilla.org/l10n-central",
|
||||||
"gaia": {
|
"gaia": {
|
||||||
"vcs": "hgtool",
|
"vcs": "hgtool",
|
||||||
"repo": "http://hg.mozilla.org/integration/gaia-nightly",
|
"repo": "http://hg.mozilla.org/integration/gaia-nightly",
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
"{srcdir}/b2g/config/panda/README",
|
"{srcdir}/b2g/config/panda/README",
|
||||||
"{workdir}/sources.xml"
|
"{workdir}/sources.xml"
|
||||||
],
|
],
|
||||||
|
"gecko_l10n_root": "http://hg.mozilla.org/l10n-central",
|
||||||
"gaia": {
|
"gaia": {
|
||||||
"vcs": "hgtool",
|
"vcs": "hgtool",
|
||||||
"repo": "http://hg.mozilla.org/integration/gaia-central",
|
"repo": "http://hg.mozilla.org/integration/gaia-central",
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
"{srcdir}/b2g/config/panda/README",
|
"{srcdir}/b2g/config/panda/README",
|
||||||
"{workdir}/sources.xml"
|
"{workdir}/sources.xml"
|
||||||
],
|
],
|
||||||
|
"gecko_l10n_root": "http://hg.mozilla.org/l10n-central",
|
||||||
"gaia": {
|
"gaia": {
|
||||||
"vcs": "hgtool",
|
"vcs": "hgtool",
|
||||||
"repo": "http://hg.mozilla.org/integration/gaia-nightly",
|
"repo": "http://hg.mozilla.org/integration/gaia-nightly",
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
"MOZILLA_OFFICIAL": "1",
|
"MOZILLA_OFFICIAL": "1",
|
||||||
"B2GUPDATER": "1"
|
"B2GUPDATER": "1"
|
||||||
},
|
},
|
||||||
|
"gecko_l10n_root": "http://hg.mozilla.org/l10n-central",
|
||||||
"gaia": {
|
"gaia": {
|
||||||
"vcs": "hgtool",
|
"vcs": "hgtool",
|
||||||
"repo": "http://hg.mozilla.org/integration/gaia-nightly",
|
"repo": "http://hg.mozilla.org/integration/gaia-nightly",
|
||||||
|
@ -351,7 +351,10 @@ XBLEnumerate(JSContext *cx, JS::Handle<JSObject*> obj)
|
|||||||
return protoBinding->ResolveAllFields(cx, obj);
|
return protoBinding->ResolveAllFields(cx, obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
nsXBLJSClass::nsXBLJSClass(const nsAFlatCString& aClassName)
|
uint64_t nsXBLJSClass::sIdCount = 0;
|
||||||
|
|
||||||
|
nsXBLJSClass::nsXBLJSClass(const nsAFlatCString& aClassName,
|
||||||
|
const nsCString& aKey)
|
||||||
{
|
{
|
||||||
memset(this, 0, sizeof(nsXBLJSClass));
|
memset(this, 0, sizeof(nsXBLJSClass));
|
||||||
next = prev = static_cast<JSCList*>(this);
|
next = prev = static_cast<JSCList*>(this);
|
||||||
@ -367,6 +370,7 @@ nsXBLJSClass::nsXBLJSClass(const nsAFlatCString& aClassName)
|
|||||||
resolve = (JSResolveOp)XBLResolve;
|
resolve = (JSResolveOp)XBLResolve;
|
||||||
convert = ::JS_ConvertStub;
|
convert = ::JS_ConvertStub;
|
||||||
finalize = XBLFinalize;
|
finalize = XBLFinalize;
|
||||||
|
mKey = aKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
nsrefcnt
|
nsrefcnt
|
||||||
@ -376,8 +380,9 @@ nsXBLJSClass::Destroy()
|
|||||||
"referenced nsXBLJSClass is on LRU list already!?");
|
"referenced nsXBLJSClass is on LRU list already!?");
|
||||||
|
|
||||||
if (nsXBLService::gClassTable) {
|
if (nsXBLService::gClassTable) {
|
||||||
nsCStringKey key(name);
|
nsCStringKey key(mKey);
|
||||||
(nsXBLService::gClassTable)->Remove(&key);
|
(nsXBLService::gClassTable)->Remove(&key);
|
||||||
|
mKey.Truncate();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nsXBLService::gClassLRUListLength >= nsXBLService::gClassLRUListQuota) {
|
if (nsXBLService::gClassLRUListLength >= nsXBLService::gClassLRUListQuota) {
|
||||||
@ -1357,11 +1362,12 @@ nsXBLBinding::DoInitJSClass(JSContext *cx, JSObject *global, JSObject *obj,
|
|||||||
{
|
{
|
||||||
// First ensure our JS class is initialized.
|
// First ensure our JS class is initialized.
|
||||||
nsAutoCString className(aClassName);
|
nsAutoCString className(aClassName);
|
||||||
|
nsAutoCString xblKey(aClassName);
|
||||||
JSObject* parent_proto = nullptr; // If we have an "obj" we can set this
|
JSObject* parent_proto = nullptr; // If we have an "obj" we can set this
|
||||||
JSAutoRequest ar(cx);
|
JSAutoRequest ar(cx);
|
||||||
|
|
||||||
JSAutoCompartment ac(cx, global);
|
JSAutoCompartment ac(cx, global);
|
||||||
|
nsXBLJSClass* c = nullptr;
|
||||||
if (obj) {
|
if (obj) {
|
||||||
// Retrieve the current prototype of obj.
|
// Retrieve the current prototype of obj.
|
||||||
if (!JS_GetPrototype(cx, obj, &parent_proto)) {
|
if (!JS_GetPrototype(cx, obj, &parent_proto)) {
|
||||||
@ -1369,7 +1375,7 @@ nsXBLBinding::DoInitJSClass(JSContext *cx, JSObject *global, JSObject *obj,
|
|||||||
}
|
}
|
||||||
if (parent_proto) {
|
if (parent_proto) {
|
||||||
// We need to create a unique classname based on aClassName and
|
// We need to create a unique classname based on aClassName and
|
||||||
// parent_proto. Append a space (an invalid URI character) to ensure that
|
// id. Append a space (an invalid URI character) to ensure that
|
||||||
// we don't have accidental collisions with the case when parent_proto is
|
// we don't have accidental collisions with the case when parent_proto is
|
||||||
// null and aClassName ends in some bizarre numbers (yeah, it's unlikely).
|
// null and aClassName ends in some bizarre numbers (yeah, it's unlikely).
|
||||||
jsid parent_proto_id;
|
jsid parent_proto_id;
|
||||||
@ -1383,10 +1389,25 @@ nsXBLBinding::DoInitJSClass(JSContext *cx, JSObject *global, JSObject *obj,
|
|||||||
// string representation of what we're printing does not fit in the buffer
|
// string representation of what we're printing does not fit in the buffer
|
||||||
// provided).
|
// provided).
|
||||||
char buf[20];
|
char buf[20];
|
||||||
|
if (sizeof(jsid) == 4) {
|
||||||
PR_snprintf(buf, sizeof(buf), " %lx", parent_proto_id);
|
PR_snprintf(buf, sizeof(buf), " %lx", parent_proto_id);
|
||||||
|
} else {
|
||||||
|
MOZ_ASSERT(sizeof(jsid) == 8);
|
||||||
|
PR_snprintf(buf, sizeof(buf), " %llx", parent_proto_id);
|
||||||
|
}
|
||||||
|
xblKey.Append(buf);
|
||||||
|
nsCStringKey key(xblKey);
|
||||||
|
|
||||||
|
c = static_cast<nsXBLJSClass*>(nsXBLService::gClassTable->Get(&key));
|
||||||
|
if (c) {
|
||||||
|
className.Assign(c->name);
|
||||||
|
} else {
|
||||||
|
char buf[20];
|
||||||
|
PR_snprintf(buf, sizeof(buf), " %llx", nsXBLJSClass::NewId());
|
||||||
className.Append(buf);
|
className.Append(buf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
jsval val;
|
jsval val;
|
||||||
JSObject* proto = NULL;
|
JSObject* proto = NULL;
|
||||||
@ -1394,14 +1415,11 @@ nsXBLBinding::DoInitJSClass(JSContext *cx, JSObject *global, JSObject *obj,
|
|||||||
JSVAL_IS_PRIMITIVE(val)) {
|
JSVAL_IS_PRIMITIVE(val)) {
|
||||||
// We need to initialize the class.
|
// We need to initialize the class.
|
||||||
|
|
||||||
nsXBLJSClass* c;
|
nsCStringKey key(xblKey);
|
||||||
void* classObject;
|
if (!c) {
|
||||||
nsCStringKey key(className);
|
c = static_cast<nsXBLJSClass*>(nsXBLService::gClassTable->Get(&key));
|
||||||
classObject = (nsXBLService::gClassTable)->Get(&key);
|
}
|
||||||
|
if (c) {
|
||||||
if (classObject) {
|
|
||||||
c = static_cast<nsXBLJSClass*>(classObject);
|
|
||||||
|
|
||||||
// If c is on the LRU list (i.e., not linked to itself), remove it now!
|
// If c is on the LRU list (i.e., not linked to itself), remove it now!
|
||||||
JSCList* link = static_cast<JSCList*>(c);
|
JSCList* link = static_cast<JSCList*>(c);
|
||||||
if (c->next != link) {
|
if (c->next != link) {
|
||||||
@ -1411,7 +1429,7 @@ nsXBLBinding::DoInitJSClass(JSContext *cx, JSObject *global, JSObject *obj,
|
|||||||
} else {
|
} else {
|
||||||
if (JS_CLIST_IS_EMPTY(&nsXBLService::gClassLRUList)) {
|
if (JS_CLIST_IS_EMPTY(&nsXBLService::gClassLRUList)) {
|
||||||
// We need to create a struct for this class.
|
// We need to create a struct for this class.
|
||||||
c = new nsXBLJSClass(className);
|
c = new nsXBLJSClass(className, xblKey);
|
||||||
|
|
||||||
if (!c)
|
if (!c)
|
||||||
return NS_ERROR_OUT_OF_MEMORY;
|
return NS_ERROR_OUT_OF_MEMORY;
|
||||||
@ -1423,12 +1441,13 @@ nsXBLBinding::DoInitJSClass(JSContext *cx, JSObject *global, JSObject *obj,
|
|||||||
|
|
||||||
// Remove any mapping from the old name to the class struct.
|
// Remove any mapping from the old name to the class struct.
|
||||||
c = static_cast<nsXBLJSClass*>(lru);
|
c = static_cast<nsXBLJSClass*>(lru);
|
||||||
nsCStringKey oldKey(c->name);
|
nsCStringKey oldKey(c->Key());
|
||||||
(nsXBLService::gClassTable)->Remove(&oldKey);
|
(nsXBLService::gClassTable)->Remove(&oldKey);
|
||||||
|
|
||||||
// Change the class name and we're done.
|
// Change the class name and we're done.
|
||||||
nsMemory::Free((void*) c->name);
|
nsMemory::Free((void*) c->name);
|
||||||
c->name = ToNewCString(className);
|
c->name = ToNewCString(className);
|
||||||
|
c->SetKey(xblKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add c to our table.
|
// Add c to our table.
|
||||||
|
@ -134,12 +134,19 @@ class nsXBLJSClass : public JSCList, public JSClass
|
|||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
nsrefcnt mRefCnt;
|
nsrefcnt mRefCnt;
|
||||||
|
nsCString mKey;
|
||||||
|
static uint64_t sIdCount;
|
||||||
nsrefcnt Destroy();
|
nsrefcnt Destroy();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
nsXBLJSClass(const nsAFlatCString& aClassName);
|
nsXBLJSClass(const nsAFlatCString& aClassName, const nsCString& aKey);
|
||||||
~nsXBLJSClass() { nsMemory::Free((void*) name); }
|
~nsXBLJSClass() { nsMemory::Free((void*) name); }
|
||||||
|
|
||||||
|
static uint64_t NewId() { return ++sIdCount; }
|
||||||
|
|
||||||
|
nsCString& Key() { return mKey; }
|
||||||
|
void SetKey(const nsCString& aKey) { mKey = aKey; }
|
||||||
|
|
||||||
nsrefcnt Hold() { return ++mRefCnt; }
|
nsrefcnt Hold() { return ++mRefCnt; }
|
||||||
nsrefcnt Drop() { return --mRefCnt ? mRefCnt : Destroy(); }
|
nsrefcnt Drop() { return --mRefCnt ? mRefCnt : Destroy(); }
|
||||||
};
|
};
|
||||||
|
@ -10,10 +10,8 @@ relativesrcdir = @relativesrcdir@
|
|||||||
|
|
||||||
include $(DEPTH)/config/autoconf.mk
|
include $(DEPTH)/config/autoconf.mk
|
||||||
|
|
||||||
# Bug 814718 and bug 818466 prevent us from running the following tests:
|
# Bug 814718 prevents us from running the following test:
|
||||||
# test_getUserMedia_basicVideo.html
|
# test_getUserMedia_basicVideo.html
|
||||||
# test_getUserMedia_basicAudio.html
|
|
||||||
# test_getUserMedia_basicVideoAudio.html
|
|
||||||
|
|
||||||
MOCHITEST_FILES = \
|
MOCHITEST_FILES = \
|
||||||
test_getUserMedia_exceptions.html \
|
test_getUserMedia_exceptions.html \
|
||||||
@ -24,6 +22,8 @@ MOCHITEST_FILES = \
|
|||||||
# The following tests are leaking and cannot be run by default yet
|
# The following tests are leaking and cannot be run by default yet
|
||||||
ifdef MOZ_WEBRTC_LEAKING_TESTS
|
ifdef MOZ_WEBRTC_LEAKING_TESTS
|
||||||
MOCHITEST_FILES += \
|
MOCHITEST_FILES += \
|
||||||
|
test_getUserMedia_basicAudio.html \
|
||||||
|
test_getUserMedia_basicVideoAudio.html \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -19,9 +19,9 @@ function runTest(aCallback, desktopSupportedOnly) {
|
|||||||
|
|
||||||
// If this is a desktop supported test and we're on android or b2g,
|
// If this is a desktop supported test and we're on android or b2g,
|
||||||
// indicate that the test is not supported and skip the test
|
// indicate that the test is not supported and skip the test
|
||||||
if(desktopSupportedOnly && (navigator.platform === 'Android' ||
|
if(desktopSupportedOnly && (navigator.userAgent.indexOf('Android') > -1 ||
|
||||||
navigator.platform === '')) {
|
navigator.platform === '')) {
|
||||||
ok(true, navigator.platform + ' currently not supported');
|
ok(true, navigator.userAgent + ' currently not supported');
|
||||||
SimpleTest.finish();
|
SimpleTest.finish();
|
||||||
} else {
|
} else {
|
||||||
SpecialPowers.pushPrefEnv({'set': [['media.peerconnection.enabled', true]]},
|
SpecialPowers.pushPrefEnv({'set': [['media.peerconnection.enabled', true]]},
|
||||||
|
@ -69,4 +69,11 @@ MOCHITEST_CHROME_FILES = \
|
|||||||
frame_clear_browser_data.html \
|
frame_clear_browser_data.html \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
|
ifdef MOZ_PER_WINDOW_PRIVATE_BROWSING
|
||||||
|
MOCHITEST_CHROME_FILES += \
|
||||||
|
test_localStorageBasePrivateBrowsing_perwindowpb.html \
|
||||||
|
page_blank.html \
|
||||||
|
$(NULL)
|
||||||
|
endif
|
||||||
|
|
||||||
include $(topsrcdir)/config/rules.mk
|
include $(topsrcdir)/config/rules.mk
|
||||||
|
5
dom/tests/mochitest/localstorage/page_blank.html
Normal file
5
dom/tests/mochitest/localstorage/page_blank.html
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
aaaaaaaaaaaaaaaaaaaa
|
||||||
|
</body>
|
||||||
|
</html>
|
@ -0,0 +1,264 @@
|
|||||||
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||||
|
<head>
|
||||||
|
<title>localStorage basic test, while in sesison only mode</title>
|
||||||
|
|
||||||
|
<script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
|
||||||
|
<link rel="stylesheet" type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css"?>
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
|
||||||
|
const Ci = Components.interfaces;
|
||||||
|
var mainWindow;
|
||||||
|
|
||||||
|
var prefBranch = Components.classes["@mozilla.org/preferences-service;1"]
|
||||||
|
.getService(Components.interfaces.nsIPrefBranch);
|
||||||
|
prefBranch.setIntPref("browser.startup.page", 0);
|
||||||
|
prefBranch.setCharPref("browser.startup.homepage_override.mstone", "ignore");
|
||||||
|
|
||||||
|
function startTest() {
|
||||||
|
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
|
||||||
|
mainWindow = window.QueryInterface(Ci.nsIInterfaceRequestor)
|
||||||
|
.getInterface(Ci.nsIWebNavigation)
|
||||||
|
.QueryInterface(Ci.nsIDocShellTreeItem)
|
||||||
|
.rootTreeItem
|
||||||
|
.QueryInterface(Ci.nsIInterfaceRequestor)
|
||||||
|
.getInterface(Ci.nsIDOMWindow);
|
||||||
|
|
||||||
|
doTest();
|
||||||
|
}
|
||||||
|
|
||||||
|
var contentPage = "http://mochi.test:8888/chrome/dom/tests/mochitest/localstorage/page_blank.html";
|
||||||
|
|
||||||
|
function testOnWindow(aIsPrivate, aCallback) {
|
||||||
|
var win = mainWindow.OpenBrowserWindow({private: aIsPrivate});
|
||||||
|
win.addEventListener("load", function onLoad() {
|
||||||
|
win.removeEventListener("load", onLoad, false);
|
||||||
|
win.addEventListener("DOMContentLoaded", function onInnerLoad() {
|
||||||
|
// I am at my wits' end figuring out how to stop this load from occurring. I give up.
|
||||||
|
if (win.content.location.href == "about:privatebrowsing") {
|
||||||
|
win.gBrowser.loadURI(contentPage);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
win.removeEventListener("DOMConten/tLoaded", onInnerLoad, true);
|
||||||
|
SimpleTest.executeSoon(function() { aCallback(win); });
|
||||||
|
}, true);
|
||||||
|
win.gBrowser.loadURI(contentPage);
|
||||||
|
}, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
function doTest() {
|
||||||
|
testOnWindow(false, function(aWin) {
|
||||||
|
aWin.content.localStorage.setItem("persistent", "persistent1");
|
||||||
|
|
||||||
|
testOnWindow(true, function(privateWin) {
|
||||||
|
is(privateWin.content.localStorage.getItem("persistent"), null, "previous values are inaccessible");
|
||||||
|
|
||||||
|
// Initially check the privateWin.content.localStorage is empty
|
||||||
|
is(privateWin.content.localStorage.length, 0, "The storage is empty [1]");
|
||||||
|
is(privateWin.content.localStorage.key(0), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(-1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.getItem("nonexisting"), null, "Nonexisting item is null (getItem())");
|
||||||
|
is(privateWin.content.localStorage["nonexisting"], undefined, "Nonexisting item is null (array access)");
|
||||||
|
is(privateWin.content.localStorage.nonexisting, undefined, "Nonexisting item is null (property access)");
|
||||||
|
privateWin.content.localStorage.removeItem("nonexisting"); // Just check there is no exception
|
||||||
|
|
||||||
|
is(typeof privateWin.content.localStorage.getItem("nonexisting"), "object", "getItem('nonexisting') is object");
|
||||||
|
is(typeof privateWin.content.localStorage["nonexisting"], "undefined", "['nonexisting'] is undefined");
|
||||||
|
is(typeof privateWin.content.localStorage.nonexisting, "undefined", "nonexisting is undefined");
|
||||||
|
is(typeof privateWin.content.localStorage.getItem("nonexisting2"), "object", "getItem('nonexisting2') is object");
|
||||||
|
is(typeof privateWin.content.localStorage["nonexisting2"], "undefined", "['nonexisting2'] is undefined");
|
||||||
|
is(typeof privateWin.content.localStorage.nonexisting2, "undefined", "nonexisting2 is undefined");
|
||||||
|
|
||||||
|
// add an empty-value key
|
||||||
|
privateWin.content.localStorage.setItem("empty", "");
|
||||||
|
is(privateWin.content.localStorage.getItem("empty"), "", "Empty value (getItem())");
|
||||||
|
is(privateWin.content.localStorage["empty"], "", "Empty value (array access)");
|
||||||
|
is(privateWin.content.localStorage.empty, "", "Empty value (property access)");
|
||||||
|
is(typeof privateWin.content.localStorage.getItem("empty"), "string", "getItem('empty') is string");
|
||||||
|
is(typeof privateWin.content.localStorage["empty"], "string", "['empty'] is string");
|
||||||
|
is(typeof privateWin.content.localStorage.empty, "string", "empty is string");
|
||||||
|
privateWin.content.localStorage.removeItem("empty");
|
||||||
|
is(privateWin.content.localStorage.length, 0, "The storage has no keys");
|
||||||
|
is(privateWin.content.localStorage.getItem("empty"), null, "empty item is null (getItem())");
|
||||||
|
is(privateWin.content.localStorage["empty"], null, "empty item is undefined (array access)");
|
||||||
|
is(privateWin.content.localStorage.empty, null, "empty item is undefined (property access)");
|
||||||
|
is(typeof privateWin.content.localStorage.getItem("empty"), "object", "getItem('empty') is object");
|
||||||
|
is(typeof privateWin.content.localStorage["empty"], "undefined", "['empty'] is undefined");
|
||||||
|
is(typeof privateWin.content.localStorage.empty, "undefined", "empty is undefined");
|
||||||
|
|
||||||
|
// add one key, check it is there
|
||||||
|
privateWin.content.localStorage.setItem("key1", "value1");
|
||||||
|
is(privateWin.content.localStorage.length, 1, "The storage has one key-value pair");
|
||||||
|
is(privateWin.content.localStorage.key(0), "key1");
|
||||||
|
is(privateWin.content.localStorage.key(-1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(1), null, "key() should return null for out-of-bounds access");
|
||||||
|
|
||||||
|
// check all access method give the correct result
|
||||||
|
// and are of the correct type
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), "value1", "getItem('key1') == value1");
|
||||||
|
is(privateWin.content.localStorage["key1"], "value1", "['key1'] == value1");
|
||||||
|
is(privateWin.content.localStorage.key1, "value1", "key1 == value1");
|
||||||
|
|
||||||
|
is(typeof privateWin.content.localStorage.getItem("key1"), "string", "getItem('key1') is string");
|
||||||
|
is(typeof privateWin.content.localStorage["key1"], "string", "['key1'] is string");
|
||||||
|
is(typeof privateWin.content.localStorage.key1, "string", "key1 is string");
|
||||||
|
|
||||||
|
// remove the previously added key and check the storage is empty
|
||||||
|
privateWin.content.localStorage.removeItem("key1");
|
||||||
|
is(privateWin.content.localStorage.length, 0, "The storage is empty [2]");
|
||||||
|
is(privateWin.content.localStorage.key(0), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), null, "\'key1\' removed");
|
||||||
|
|
||||||
|
is(typeof privateWin.content.localStorage.getItem("key1"), "object", "getItem('key1') is object");
|
||||||
|
is(typeof privateWin.content.localStorage["key1"], "undefined", "['key1'] is undefined");
|
||||||
|
is(typeof privateWin.content.localStorage.key1, "undefined", "key1 is undefined");
|
||||||
|
|
||||||
|
// add one key, check it is there
|
||||||
|
privateWin.content.localStorage.setItem("key1", "value1");
|
||||||
|
is(privateWin.content.localStorage.length, 1, "The storage has one key-value pair");
|
||||||
|
is(privateWin.content.localStorage.key(0), "key1");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), "value1");
|
||||||
|
|
||||||
|
// add a second key
|
||||||
|
privateWin.content.localStorage.setItem("key2", "value2");
|
||||||
|
is(privateWin.content.localStorage.length, 2, "The storage has two key-value pairs");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), "value1");
|
||||||
|
is(privateWin.content.localStorage.getItem("key2"), "value2");
|
||||||
|
var firstKey = privateWin.content.localStorage.key(0);
|
||||||
|
var secondKey = privateWin.content.localStorage.key(1);
|
||||||
|
ok((firstKey == 'key1' && secondKey == 'key2') ||
|
||||||
|
(firstKey == 'key2' && secondKey == 'key1'),
|
||||||
|
'key() API works.');
|
||||||
|
|
||||||
|
// change the second key
|
||||||
|
privateWin.content.localStorage.setItem("key2", "value2-2");
|
||||||
|
is(privateWin.content.localStorage.length, 2, "The storage has two key-value pairs");
|
||||||
|
is(privateWin.content.localStorage.key(0), firstKey); // After key value changes the order must be preserved
|
||||||
|
is(privateWin.content.localStorage.key(1), secondKey);
|
||||||
|
is(privateWin.content.localStorage.key(-1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(2), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), "value1");
|
||||||
|
is(privateWin.content.localStorage.getItem("key2"), "value2-2");
|
||||||
|
|
||||||
|
// change the first key
|
||||||
|
privateWin.content.localStorage.setItem("key1", "value1-2");
|
||||||
|
is(privateWin.content.localStorage.length, 2, "The storage has two key-value pairs");
|
||||||
|
is(privateWin.content.localStorage.key(0), firstKey); // After key value changes the order must be preserved
|
||||||
|
is(privateWin.content.localStorage.key(1), secondKey);
|
||||||
|
is(privateWin.content.localStorage.key(-1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(2), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), "value1-2");
|
||||||
|
is(privateWin.content.localStorage.getItem("key2"), "value2-2");
|
||||||
|
|
||||||
|
// remove the second key
|
||||||
|
privateWin.content.localStorage.removeItem("key2");
|
||||||
|
is(privateWin.content.localStorage.length, 1, "The storage has one key-value pair");
|
||||||
|
is(privateWin.content.localStorage.key(0), "key1");
|
||||||
|
is(privateWin.content.localStorage.key(-1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), "value1-2");
|
||||||
|
|
||||||
|
// JS property test
|
||||||
|
privateWin.content.localStorage.testA = "valueA";
|
||||||
|
is(privateWin.content.localStorage.testA, "valueA");
|
||||||
|
is(privateWin.content.localStorage["testA"], "valueA");
|
||||||
|
is(privateWin.content.localStorage.getItem("testA"), "valueA");
|
||||||
|
|
||||||
|
privateWin.content.localStorage.testA = "valueA2";
|
||||||
|
is(privateWin.content.localStorage.testA, "valueA2");
|
||||||
|
is(privateWin.content.localStorage["testA"], "valueA2");
|
||||||
|
is(privateWin.content.localStorage.getItem("testA"), "valueA2");
|
||||||
|
|
||||||
|
privateWin.content.localStorage["testB"] = "valueB";
|
||||||
|
is(privateWin.content.localStorage.testB, "valueB");
|
||||||
|
is(privateWin.content.localStorage["testB"], "valueB");
|
||||||
|
is(privateWin.content.localStorage.getItem("testB"), "valueB");
|
||||||
|
|
||||||
|
privateWin.content.localStorage["testB"] = "valueB2";
|
||||||
|
is(privateWin.content.localStorage.testB, "valueB2");
|
||||||
|
is(privateWin.content.localStorage["testB"], "valueB2");
|
||||||
|
is(privateWin.content.localStorage.getItem("testB"), "valueB2");
|
||||||
|
|
||||||
|
privateWin.content.localStorage.setItem("testC", "valueC");
|
||||||
|
is(privateWin.content.localStorage.testC, "valueC");
|
||||||
|
is(privateWin.content.localStorage["testC"], "valueC");
|
||||||
|
is(privateWin.content.localStorage.getItem("testC"), "valueC");
|
||||||
|
|
||||||
|
privateWin.content.localStorage.setItem("testC", "valueC2");
|
||||||
|
is(privateWin.content.localStorage.testC, "valueC2");
|
||||||
|
is(privateWin.content.localStorage["testC"], "valueC2");
|
||||||
|
is(privateWin.content.localStorage.getItem("testC"), "valueC2");
|
||||||
|
|
||||||
|
privateWin.content.localStorage.setItem("testC", null);
|
||||||
|
is("testC" in privateWin.content.localStorage, true);
|
||||||
|
is(privateWin.content.localStorage.getItem("testC"), "null");
|
||||||
|
is(privateWin.content.localStorage["testC"], "null");
|
||||||
|
is(privateWin.content.localStorage.testC, "null");
|
||||||
|
|
||||||
|
privateWin.content.localStorage.removeItem("testC");
|
||||||
|
privateWin.content.localStorage["testC"] = null;
|
||||||
|
is("testC" in privateWin.content.localStorage, true);
|
||||||
|
is(privateWin.content.localStorage.getItem("testC"), "null");
|
||||||
|
is(privateWin.content.localStorage["testC"], "null");
|
||||||
|
is(privateWin.content.localStorage.testC, "null");
|
||||||
|
|
||||||
|
privateWin.content.localStorage.setItem(null, "test");
|
||||||
|
is("null" in privateWin.content.localStorage, true);
|
||||||
|
is(privateWin.content.localStorage.getItem("null"), "test");
|
||||||
|
is(privateWin.content.localStorage.getItem(null), "test");
|
||||||
|
is(privateWin.content.localStorage["null"], "test");
|
||||||
|
privateWin.content.localStorage.removeItem(null, "test");
|
||||||
|
// bug 350023
|
||||||
|
todo_is("null" in privateWin.content.localStorage, false);
|
||||||
|
|
||||||
|
privateWin.content.localStorage.setItem(null, "test");
|
||||||
|
is("null" in privateWin.content.localStorage, true);
|
||||||
|
privateWin.content.localStorage.removeItem("null", "test");
|
||||||
|
// bug 350023
|
||||||
|
todo_is("null" in privateWin.content.localStorage, false);
|
||||||
|
|
||||||
|
// Clear the storage
|
||||||
|
privateWin.content.localStorage.clear();
|
||||||
|
is(privateWin.content.localStorage.length, 0, "The storage is empty [3]");
|
||||||
|
is(privateWin.content.localStorage.key(0), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(-1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.key(1), null, "key() should return null for out-of-bounds access");
|
||||||
|
is(privateWin.content.localStorage.getItem("nonexisting"), null, "Nonexisting item is null");
|
||||||
|
is(privateWin.content.localStorage.getItem("key1"), null, "key1 removed");
|
||||||
|
is(privateWin.content.localStorage.getItem("key2"), null, "key2 removed");
|
||||||
|
privateWin.content.localStorage.removeItem("nonexisting"); // Just check there is no exception
|
||||||
|
privateWin.content.localStorage.removeItem("key1"); // Just check there is no exception
|
||||||
|
privateWin.content.localStorage.removeItem("key2"); // Just check there is no exception
|
||||||
|
|
||||||
|
privateWin.content.localStorage.setItem("must disappear", "private browsing value");
|
||||||
|
|
||||||
|
privateWin.close();
|
||||||
|
|
||||||
|
testOnWindow(true, function(newPrivateWin) {
|
||||||
|
is(newPrivateWin.content.localStorage.getItem("must disappear"), null, "private browsing values threw away");
|
||||||
|
is(newPrivateWin.content.localStorage.length, 0, "No items");
|
||||||
|
|
||||||
|
newPrivateWin.close();
|
||||||
|
is(aWin.content.localStorage.getItem("persistent"), "persistent1", "back in normal mode");
|
||||||
|
aWin.content.localStorage.clear();
|
||||||
|
aWin.close();
|
||||||
|
|
||||||
|
prefBranch.clearUserPref("browser.startup.page")
|
||||||
|
prefBranch.clearUserPref("browser.startup.homepage_override.mstone");
|
||||||
|
SimpleTest.finish();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body onload="startTest();">
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
@ -10,6 +10,7 @@ VPATH = @srcdir@
|
|||||||
|
|
||||||
MODULE = pipnss
|
MODULE = pipnss
|
||||||
DIRS = \
|
DIRS = \
|
||||||
|
browser \
|
||||||
bugs \
|
bugs \
|
||||||
mixedcontent \
|
mixedcontent \
|
||||||
stricttransportsecurity \
|
stricttransportsecurity \
|
||||||
|
24
security/manager/ssl/tests/mochitest/browser/Makefile.in
Normal file
24
security/manager/ssl/tests/mochitest/browser/Makefile.in
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
#
|
||||||
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
|
||||||
|
DEPTH = @DEPTH@
|
||||||
|
topsrcdir = @top_srcdir@
|
||||||
|
srcdir = @srcdir@
|
||||||
|
VPATH = @srcdir@
|
||||||
|
relativesrcdir = @relativesrcdir@
|
||||||
|
|
||||||
|
include $(DEPTH)/config/autoconf.mk
|
||||||
|
|
||||||
|
MOCHITEST_BROWSER_FILES = \
|
||||||
|
head.js \
|
||||||
|
$(NULL)
|
||||||
|
|
||||||
|
ifdef MOZ_PER_WINDOW_PRIVATE_BROWSING
|
||||||
|
MOCHITEST_BROWSER_FILES += \
|
||||||
|
browser_bug627234_perwindowpb.js \
|
||||||
|
$(NULL)
|
||||||
|
endif
|
||||||
|
|
||||||
|
include $(topsrcdir)/config/rules.mk
|
@ -0,0 +1,69 @@
|
|||||||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
|
// This is a template to help porting global private browsing tests
|
||||||
|
// to per-window private browsing tests
|
||||||
|
function test() {
|
||||||
|
// initialization
|
||||||
|
waitForExplicitFinish();
|
||||||
|
let windowsToClose = [];
|
||||||
|
let testURI = "about:blank";
|
||||||
|
let uri;
|
||||||
|
let gSTSService = Cc["@mozilla.org/stsservice;1"].
|
||||||
|
getService(Ci.nsIStrictTransportSecurityService);
|
||||||
|
|
||||||
|
function privacyFlags(aIsPrivateMode) {
|
||||||
|
return aIsPrivateMode ? Ci.nsISocketProvider.NO_PERMANENT_STORAGE : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
function doTest(aIsPrivateMode, aWindow, aCallback) {
|
||||||
|
aWindow.gBrowser.selectedBrowser.addEventListener("load", function onLoad() {
|
||||||
|
aWindow.gBrowser.selectedBrowser.removeEventListener("load", onLoad, true);
|
||||||
|
|
||||||
|
uri = aWindow.Services.io.newURI("https://localhost/img.png", null, null);
|
||||||
|
gSTSService.processStsHeader(uri, "max-age=1000", privacyFlags(aIsPrivateMode));
|
||||||
|
ok(gSTSService.isStsHost("localhost", privacyFlags(aIsPrivateMode)), "checking sts host");
|
||||||
|
|
||||||
|
aCallback();
|
||||||
|
}, true);
|
||||||
|
|
||||||
|
aWindow.gBrowser.selectedBrowser.loadURI(testURI);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testOnWindow(aOptions, aCallback) {
|
||||||
|
whenNewWindowLoaded(aOptions, function(aWin) {
|
||||||
|
windowsToClose.push(aWin);
|
||||||
|
// execute should only be called when need, like when you are opening
|
||||||
|
// web pages on the test. If calling executeSoon() is not necesary, then
|
||||||
|
// call whenNewWindowLoaded() instead of testOnWindow() on your test.
|
||||||
|
executeSoon(function() aCallback(aWin));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// this function is called after calling finish() on the test.
|
||||||
|
registerCleanupFunction(function() {
|
||||||
|
windowsToClose.forEach(function(aWin) {
|
||||||
|
aWin.close();
|
||||||
|
});
|
||||||
|
uri = Services.io.newURI("http://localhost", null, null);
|
||||||
|
gSTSService.removeStsState(uri, privacyFlags(true));
|
||||||
|
});
|
||||||
|
|
||||||
|
// test first when on private mode
|
||||||
|
testOnWindow({private: true}, function(aWin) {
|
||||||
|
doTest(true, aWin, function() {
|
||||||
|
//test when not on private mode
|
||||||
|
testOnWindow({}, function(aWin) {
|
||||||
|
doTest(false, aWin, function() {
|
||||||
|
//test again when on private mode
|
||||||
|
testOnWindow({private: true}, function(aWin) {
|
||||||
|
doTest(true, aWin, function () {
|
||||||
|
finish();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
9
security/manager/ssl/tests/mochitest/browser/head.js
Normal file
9
security/manager/ssl/tests/mochitest/browser/head.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
/* Any copyright is dedicated to the Public Domain.
|
||||||
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||||
|
function whenNewWindowLoaded(aOptions, aCallback) {
|
||||||
|
let win = OpenBrowserWindow(aOptions);
|
||||||
|
win.addEventListener("load", function onLoad() {
|
||||||
|
win.removeEventListener("load", onLoad, false);
|
||||||
|
aCallback(win);
|
||||||
|
}, false);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user