chromium/third_party/blink/web_tests/printing/pseudo-class-outside-page.html

<!DOCTYPE html>
<html>
<head>

<style type="text/css" media="screen">
    #green {
        background-color: green;
    }
    #test1 {
        width: 100px;
        height: 100px;
        background-color: green;
    }
    .exception_test {
        color: red;
    }
    /* These selectors should be ignored */
    #test1:first {
        background-color: red;
    }
    #test1:left {
        background-color: red;
    }
    #test1:right {
        background-color: red;
    }
</style>
<script>
    if (window.testRunner)
        testRunner.dumpAsText();

    function test()
    {
        var expected = getComputedStyle(document.getElementById("green"), null).backgroundColor;
        var actual = getComputedStyle(document.getElementById("test1"), null).backgroundColor;
        var result = "PASS";
        if (actual != expected)
            result = "Expected " + expected + ", but comes " + actual;
        document.getElementById("result").innerHTML = result;

        var invalidSelectors = [":first", ":left", ":right", "::first", "::left", "::right",
                                ".login-popup:first", ".login-popup:left", ".login-popup:right", ".login-popup::first", ".login-popup::left", ".login-popup::right"];
        for (var testId = 2; testId <= 13; testId++) {
            var element = document.getElementById("test" + testId);
            var invalidSelector = invalidSelectors[testId - 2];
            try {
                document.querySelectorAll(invalidSelector);
                element.innerHTML = "Test " + testId + ": FAIL";
            } catch (e) {
                element.innerHTML = "Test " + testId + ": PASS";
                element.style.color = "green";
            }
        }
    }
</script>
</head>
<body onload="test()">

<p>
Test case for <a href="https://bugs.webkit.org/show_bug.cgi?id=38272">SHOULD NEVER BE REACHED assertion loading forbes.com</a>.
Paged media related pseudo-classes should be ignored outside of @page.

<p>
You should see a green box for Test 1, "Test n: PASS" for the rest.

<div id="green"></div>
<div id="test1"></div>
<div id="test2" class="exception_test">Test 2: Didn't run</div>
<div id="test3" class="exception_test">Test 3: Didn't run</div>
<div id="test4" class="exception_test">Test 4: Didn't run</div>
<div id="test5" class="exception_test">Test 5: Didn't run</div>
<div id="test6" class="exception_test">Test 6: Didn't run</div>
<div id="test7" class="exception_test">Test 7: Didn't run</div>
<div id="test8" class="exception_test">Test 8: Didn't run</div>
<div id="test9" class="exception_test">Test 9: Didn't run</div>
<div id="test10" class="exception_test">Test 10: Didn't run</div>
<div id="test11" class="exception_test">Test 11: Didn't run</div>
<div id="test12" class="exception_test">Test 12: Didn't run</div>
<div id="test13" class="exception_test">Test 13: Didn't run</div>
<div id="result"></div>

</body>
</html>