Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(33)

Unified Diff: LayoutTests/fast/workers/worker-cloneport.html

Issue 40513003: Delete/move the remaining stale tests in TestExpectations. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: delete plugins/reentrant-update-widget-positions.html as well Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: LayoutTests/fast/workers/worker-cloneport.html
diff --git a/LayoutTests/fast/workers/worker-cloneport.html b/LayoutTests/fast/workers/worker-cloneport.html
deleted file mode 100644
index 9d5091bd20821847b212e72ddf6c56da957f62c3..0000000000000000000000000000000000000000
--- a/LayoutTests/fast/workers/worker-cloneport.html
+++ /dev/null
@@ -1,101 +0,0 @@
-<body>
-<p>Test MessagePort messaging/entangle/detangle across threads. Should print "SUCCESS" when done.</p>
-<div id=result></div>
-<script>
-function log(message)
-{
- document.getElementById("result").innerHTML += message + "<br>";
-}
-
-if (window.testRunner) {
- testRunner.dumpAsText();
- testRunner.waitUntilDone();
-}
-
-
-var channel = new MessageChannel();
-var numMessages = 50000;
-
-// Create a channel which we will use to clone and re-clone one end of a
-// MessageChannel.
-var cloneChannel = new MessageChannel();
-var stopCloning = false;
-cloneChannel.port1.onmessage = cloneChannel.port2.onmessage = resendPort;
-cloneChannel.port1.start();
-cloneChannel.port2.start();
-cloneChannel.port1.postMessage("", [channel.port2]);
-
-// Create worker with other end of port and have it send messages back to us
-// while we clone our end of the port repeatedly.
-var worker = new Worker("resources/worker-cloneport.js");
-worker.postMessage("postBack " + numMessages, [channel.port1]);
-
-// Test posting back 50000 messages, make sure ordering is fine
-worker.onmessage = function(evt) {
- if (evt.data == "postBackDone") {
- stopCloning = true;
- } else {
- // Log message from worker
- log(evt.data);
- }
-}
-
-// Keep cloning the passed port until we're told to stop.
-function resendPort(evt)
-{
- if (!evt.ports)
- log("FAIL: evt.ports not set");
- if (evt.ports.length != 1)
- log("FAIL: ports.length = " + evt.ports.length);
-
- if (!stopCloning) {
- evt.target.postMessage("", evt.ports);
- } else {
- // Make sure the messages arrived in order.
- var itemNum = 0;
- // Queue up a task to execute once the messages have been processed. The timeout value is set fairly large to account for Chromium's different message delivery architecture.
- // This only fires in the case of a test failure, so it does not slow down test running.
- var timer = setTimeout(function() {
- log("FAILURE: Received: " + itemNum + " events - expected: " + numMessages);
- }, 1000);
- evt.ports[0].onmessage = function(event) {
- var done = false;
- if (event.data == itemNum) {
- itemNum++;
- if (itemNum == numMessages) {
- log("SUCCESS - received " + numMessages + " messages.");
- done = true;
- }
- } else {
- log("FAILURE: Out of order message: expected #: " + itemNum + ", received: " + event.data);
- done = true;
- }
- clearTimeout(timer);
- if (done) {
- gc();
- setTimeout(reportDone, 100); // Make sure no unexpected events come in.
- }
- }
- evt.ports[0].start();
- }
-}
-
-function gc()
-{
- if (window.GCController)
- return GCController.collect();
-
- for (var i = 0; i < 10000; i++) { // force garbage collection (FF requires about 9K allocations before a collect).
- var s = new String("abc");
- }
-}
-function reportDone()
-{
- log("DONE");
- if (window.testRunner)
- testRunner.notifyDone();
-}
-
-</script>
-</body>
-</html>

Powered by Google App Engine
This is Rietveld 408576698