chromium/third_party/blink/web_tests/fast/events/page-visibility-iframe-propagation-test.html

<html>
<body>

<script src="../../resources/js-test.js"></script>

<script>

description("This test checks that Page Visibility state events are propagated to child frames.");

var jsTestIsAsync = true;

function makePageVisible() {
    if (window.testRunner)
        testRunner.setMainWindowHidden(false);
}

function makePageHidden() {
    if (window.testRunner)
        testRunner.setMainWindowHidden(true);
}

function checkIsPageVisible() {
    debug("Main Page:");
    shouldBeEqualToString("document.visibilityState", "visible");
    shouldBeFalse("document.hidden");
}

function checkIsPageHidden() {
    debug("Main Page:");
    shouldBeEqualToString("document.visibilityState", "hidden");
    shouldBeTrue("document.hidden");
}

function checkIsChildFrameVisible() {
    debug("Child Frame:");
    shouldBeEqualToString("childFrame.contentDocument.visibilityState",
                          "visible");
    shouldBeFalse("childFrame.contentDocument.hidden");
}

function checkIsChildFrameHidden() {
    debug("Child Frame:");
    shouldBeEqualToString("childFrame.contentDocument.visibilityState",
                          "hidden");
    shouldBeTrue("childFrame.contentDocument.hidden");
}

// We will try to change the visibility states as:
//  0 - visible. (Initial - i.e. on load).
//  1 - hidden
//  2 - visible
var numVisibilityChanges = 0;

var childFrame;

function startTest() {
    childFrame = document.getElementById("childFrame");
    childFrame.contentDocument.addEventListener(
        "visibilitychange", onChildFrameVisibilityChange, false);
    document.addEventListener("visibilitychange",
                              onVisibilityChange, false);

    checkIsPageVisible();
    checkIsChildFrameVisible();

    numVisibilityChanges++;
    makePageHidden();
}

var numFinishes = 0;
function finishTest() {
    numFinishes++;
    if (numFinishes < 2) {
      return;
    }
    finishJSTest();
}

function onVisibilityChange() {
    if (numVisibilityChanges == 1) {
        checkIsPageHidden();
        return;
    } else if (numVisibilityChanges == 2) {
        checkIsPageVisible();
        finishTest();
        return;
    } else {
        testFailed("Too many visibility transitions");
        finishTest();
        return;
    }
}

function onChildFrameVisibilityChange() {
    if (numVisibilityChanges == 1) {
        checkIsChildFrameHidden();
        numVisibilityChanges++;
        makePageVisible();
        return;
    } else if (numVisibilityChanges == 2) {
        checkIsChildFrameVisible();
        finishTest();
        return;
    } else {
        testFailed("Child Frame: Too many visibility transitions");
        finishTest();
    }
}

</script>


<iframe id="childFrame" onload="startTest()"></iframe>
</body>
</html>