mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 890928 - Crashfix for URL.createURL in subworker. r=bent
--HG-- rename : dom/workers/test/url_worker.js => dom/workers/test/jsm_url_worker.js
This commit is contained in:
parent
b7a0876052
commit
efa2cde200
@ -144,7 +144,7 @@ public:
|
|||||||
|
|
||||||
principal = doc->NodePrincipal();
|
principal = doc->NodePrincipal();
|
||||||
} else {
|
} else {
|
||||||
MOZ_ASSERT(mWorkerPrivate->IsChromeWorker());
|
MOZ_ASSERT_IF(!mWorkerPrivate->GetParent(), mWorkerPrivate->IsChromeWorker());
|
||||||
principal = mWorkerPrivate->GetPrincipal();
|
principal = mWorkerPrivate->GetPrincipal();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,7 +199,7 @@ public:
|
|||||||
|
|
||||||
principal = doc->NodePrincipal();
|
principal = doc->NodePrincipal();
|
||||||
} else {
|
} else {
|
||||||
MOZ_ASSERT(mWorkerPrivate->IsChromeWorker());
|
MOZ_ASSERT_IF(!mWorkerPrivate->GetParent(), mWorkerPrivate->IsChromeWorker());
|
||||||
principal = mWorkerPrivate->GetPrincipal();
|
principal = mWorkerPrivate->GetPrincipal();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,7 +144,7 @@ MOCHITEST_CHROME_FILES = \
|
|||||||
dom_worker_helper.js \
|
dom_worker_helper.js \
|
||||||
test_bug883784.xul \
|
test_bug883784.xul \
|
||||||
test_bug883784.jsm \
|
test_bug883784.jsm \
|
||||||
url_worker.js \
|
jsm_url_worker.js \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
include $(topsrcdir)/config/rules.mk
|
include $(topsrcdir)/config/rules.mk
|
||||||
|
82
dom/workers/test/jsm_url_worker.js
Normal file
82
dom/workers/test/jsm_url_worker.js
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
onmessage = function(event) {
|
||||||
|
if (event.data != 0) {
|
||||||
|
var worker = new Worker('jsm_url_worker.js');
|
||||||
|
worker.onmessage = function(event) {
|
||||||
|
postMessage(event.data);
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.postMessage(event.data - 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
try {
|
||||||
|
if ((URL instanceof Object)) {
|
||||||
|
status = true;
|
||||||
|
}
|
||||||
|
} catch(e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'URL object:' + URL});
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
var blob = null;
|
||||||
|
try {
|
||||||
|
blob = new Blob([]);
|
||||||
|
status = true;
|
||||||
|
} catch(e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'Blob:' + blob});
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
var url = null;
|
||||||
|
try {
|
||||||
|
url = URL.createObjectURL(blob);
|
||||||
|
status = true;
|
||||||
|
} catch(e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'Blob URL:' + url});
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
try {
|
||||||
|
URL.revokeObjectURL(url);
|
||||||
|
status = true;
|
||||||
|
} catch(e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'Blob Revoke URL'});
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
var url = null;
|
||||||
|
try {
|
||||||
|
url = URL.createObjectURL(true);
|
||||||
|
} catch(e) {
|
||||||
|
status = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'CreateObjectURL should fail if the arg is not a blob'});
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
var url = null;
|
||||||
|
try {
|
||||||
|
url = URL.createObjectURL(blob);
|
||||||
|
status = true;
|
||||||
|
} catch(e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'Blob URL2:' + url});
|
||||||
|
postMessage({type: 'url', url: url});
|
||||||
|
|
||||||
|
status = false;
|
||||||
|
try {
|
||||||
|
URL.createObjectURL(new Object());
|
||||||
|
} catch(e) {
|
||||||
|
status = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
postMessage({type: 'status', status: status, msg: 'Exception wanted' });
|
||||||
|
|
||||||
|
postMessage({type: 'finish' });
|
||||||
|
}
|
@ -2,7 +2,7 @@ this.EXPORTED_SYMBOLS = ["Test"];
|
|||||||
|
|
||||||
this.Test = {
|
this.Test = {
|
||||||
start: function(ok, is, finish) {
|
start: function(ok, is, finish) {
|
||||||
let worker = new ChromeWorker("url_worker.js");
|
let worker = new ChromeWorker("jsm_url_worker.js");
|
||||||
worker.onmessage = function(event) {
|
worker.onmessage = function(event) {
|
||||||
|
|
||||||
if (event.data.type == 'finish') {
|
if (event.data.type == 'finish') {
|
||||||
@ -30,6 +30,6 @@ this.Test = {
|
|||||||
finish();
|
finish();
|
||||||
};
|
};
|
||||||
|
|
||||||
worker.postMessage(true);
|
worker.postMessage(0);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
is(event.target, worker);
|
is(event.target, worker);
|
||||||
|
|
||||||
if (event.data.type == 'finish') {
|
if (event.data.type == 'finish') {
|
||||||
SimpleTest.finish();
|
runTest();
|
||||||
} else if (event.data.type == 'status') {
|
} else if (event.data.type == 'status') {
|
||||||
ok(event.data.status, event.data.msg);
|
ok(event.data.status, event.data.msg);
|
||||||
} else if (event.data.type == 'url') {
|
} else if (event.data.type == 'url') {
|
||||||
@ -42,8 +42,22 @@
|
|||||||
SimpleTest.finish();
|
SimpleTest.finish();
|
||||||
};
|
};
|
||||||
|
|
||||||
worker.postMessage(true);
|
var tests = [
|
||||||
|
function() { worker.postMessage(0); },
|
||||||
|
function() { worker.postMessage(1); }
|
||||||
|
];
|
||||||
|
|
||||||
|
function runTest() {
|
||||||
|
if (!tests.length) {
|
||||||
|
SimpleTest.finish();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var test = tests.shift();
|
||||||
|
test();
|
||||||
|
}
|
||||||
|
|
||||||
|
runTest();
|
||||||
SimpleTest.waitForExplicitFinish();
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
@ -1,4 +1,14 @@
|
|||||||
onmessage = function() {
|
onmessage = function(event) {
|
||||||
|
if (event.data != 0) {
|
||||||
|
var worker = new Worker('url_worker.js');
|
||||||
|
worker.onmessage = function(event) {
|
||||||
|
postMessage(event.data);
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.postMessage(event.data - 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
status = false;
|
status = false;
|
||||||
try {
|
try {
|
||||||
if ((URL instanceof Object)) {
|
if ((URL instanceof Object)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user