https://bugs.webkit.org/show_bug.cgi?id=173798
Reviewed by Simon Fraser.
Modernize the test and deflake it by not making it rely on a specific order
for the visibilitychange events. The event queues are per documents and there
is therefore no guarantee those events will fire in frame tree order.
* fast/events/page-visibility-iframe-delete-test-expected.txt:
* fast/events/page-visibility-iframe-delete-test.html:
git-svn-id: https://svn.webkit.org/repository/webkit/trunk@218779
268f45cc-cd09-0410-ab3c-
d52691b4dbfc
+2017-06-23 Chris Dumez <cdumez@apple.com>
+
+ fast/events/page-visibility-iframe-delete-test.html is flaky
+ https://bugs.webkit.org/show_bug.cgi?id=173798
+
+ Reviewed by Simon Fraser.
+
+ Modernize the test and deflake it by not making it rely on a specific order
+ for the visibilitychange events. The event queues are per documents and there
+ is therefore no guarantee those events will fire in frame tree order.
+
+ * fast/events/page-visibility-iframe-delete-test-expected.txt:
+ * fast/events/page-visibility-iframe-delete-test.html:
+
2017-06-23 Youenn Fablet <youenn@apple.com>
Add a binary data channel webrtc test
2017-06-23 Youenn Fablet <youenn@apple.com>
Add a binary data channel webrtc test
-Visibility of main document changed.
-Visibility of sub frame 2 changed.
+Received visibilitychange event
+Received visibilitychange event
PASS successfullyParsed is true
TEST COMPLETE
PASS successfullyParsed is true
TEST COMPLETE
-<body onload="startTest()">
-
-<script src="../../resources/js-test-pre.js"></script>
-
+<body>
+<script src="../../resources/js-test.js"></script>
description("This test checks that the page visibility event propagation does not crash the browser when frames are added / deleted.");
description("This test checks that the page visibility event propagation does not crash the browser when frames are added / deleted.");
-var jsTestIsAsync = true;
-
-var numVisibilityChanges = 0;
-var frame1, frame2, frame3, frame4, frame5, subframe1, subFrame2, subFrame3;
-
-var docsLoaded = 0;
-var mainPageVisibilityChangeDone = false;
-var frame2VisiblityChangeDone = false;
-var finishTestDone = false;
-
-function startTest() {
- ++docsLoaded;
- if (docsLoaded < 8) {
- return;
- }
+let visibilityChangeEventCount = 0;
debug("Loaded all frames.");
frame1 = document.getElementById("topFrame1");
debug("Loaded all frames.");
frame1 = document.getElementById("topFrame1");
subFrame1 = frame3.contentDocument.getElementById("subIframe1");
subFrame2 = frame3.contentDocument.getElementById("subIframe2");
subFrame1 = frame3.contentDocument.getElementById("subIframe1");
subFrame2 = frame3.contentDocument.getElementById("subIframe2");
- document.addEventListener(
- "visibilitychange", onMainPageVisibilityChange, false);
- frame2.contentDocument.addEventListener(
- "visibilitychange", onFrame2VisibilityChange, false);
+ document.addEventListener("visibilitychange", onMainPageVisibilityChange);
+ frame2.contentDocument.addEventListener("visibilitychange", onFrame2VisibilityChange);
+
// Change the visibility of the current page to invisible.
// Change the visibility of the current page to invisible.
- if (window.testRunner) {
- numVisibilityChanges++;
testRunner.setPageVisibility("hidden");
testRunner.setPageVisibility("hidden");
-function finishTest() {
- document.removeEventListener(
- "visibilitychange", onMainPageVisibilityChange, false);
- frame2.contentDocument.removeEventListener(
- "visibilitychange", onFrame2VisibilityChange, false);
+function onMainPageVisibilityChange()
+{
+ ++visibilityChangeEventCount;
+ debug("Received visibilitychange event");
- if (window.testRunner)
- testRunner.resetPageVisibility();
- finishJSTest();
-}
-
-function onMainPageVisibilityChange() {
- if (mainPageVisibilityChangeDone && frame2VisiblityChangeDone) {
- finishTest();
- } else if (!mainPageVisibilityChangeDone) {
- debug("Visibility of main document changed.");
- // Delete frame 4.
- document.body.removeChild(frame4);
+ // Delete frame 4.
+ frame4.remove();
- frame3.contentDocument.body.removeChild(subFrame2);
-
- // Add a new frame to top level.
- frame5 = document.createElement("iframe");
- frame5.src = '';
- document.body.appendChild(frame5);
+ frame3.contentDocument.body.removeChild(subFrame2);
- // Add a new frame to frame2.
- subFrame3 = frame2.contentDocument.createElement("iframe");
- subFrame3.src = '';
- frame2.contentDocument.body.appendChild(subFrame3);
+ // Add a new frame to top level.
+ frame5 = document.createElement("iframe");
+ document.body.appendChild(frame5);
- mainPageVisibilityChangeDone = true;
- }
+ // Add a new frame to frame2.
+ subFrame3 = frame2.contentDocument.createElement("iframe");
+ frame2.contentDocument.body.appendChild(subFrame3);
- if (mainPageVisibilityChangeDone && frame2VisiblityChangeDone) {
- finishTest();
- }
+ if (visibilityChangeEventCount == 2)
+ finishJSTest();
-function onFrame2VisibilityChange() {
- if (mainPageVisibilityChangeDone && frame2VisiblityChangeDone) {
- finishTest();
- } else if (!frame2VisiblityChangeDone) {
- debug("Visibility of sub frame 2 changed.");
+function onFrame2VisibilityChange()
+{
+ ++visibilityChangeEventCount;
+ debug("Received visibilitychange event");
- // Delete frame 1.
- document.body.removeChild(frame1);
+ // Delete frame 1.
+ frame1.remove();
- frame2VisiblityChangeDone = true;
- }
-
- if (mainPageVisibilityChangeDone && frame2VisiblityChangeDone) {
- finishTest();
- }
+ if (visibilityChangeEventCount == 2)
+ finishJSTest();
-
-<script src="../../resources/js-test-post.js"></script>
-
-<iframe id="topFrame1" onload="startTest()" ></iframe>
-<iframe id="topFrame2" onload="startTest()" ></iframe>
-<iframe id="topFrame3" onload="startTest()" src="resources/page-visibility-iframe-delete-test-frame.html"></iframe>
-<iframe id="topFrame4" onload="startTest()" ></iframe>
+<iframe id="topFrame1"></iframe>
+<iframe id="topFrame2"></iframe>
+<iframe id="topFrame3" src="resources/page-visibility-iframe-delete-test-frame.html"></iframe>
+<iframe id="topFrame4"></iframe>
-<body onload="parent.startTest()">
-<iframe id="subIframe1" onload="parent.parent.startTest()"></iframe>
-<iframe id="subIframe2" onload="parent.parent.startTest()"></iframe>
+<body>
+<iframe id="subIframe1"></iframe>
+<iframe id="subIframe2"></iframe>