chromium/third_party/blink/web_tests/animations/timing/longhand-timing-function.html

<!DOCTYPE html>

<html>
<head>
    <style type="text/css" media="screen">
        .box {
            position: relative;
            height: 100px;
            width: 100px;
            margin: 20px;
            background-color: blue;
        }

        #movers.moved > .box {
            animation: move 1s linear;
        }

        #movers > #test {
            animation-iteration-count: 1;
        }
        
        @keyframes move {
            from { left: 0px;   }
            to   { left: 400px; }
        }
    </style>
    <script src="../resources/animation-test-helpers.js" type="text/javascript" charset="utf-8"></script>
    <script type="text/javascript" charset="utf-8">
        if (window.testRunner)
            testRunner.waitUntilDone();

        const expectedValues = [
            // [time, element-id, property, expected-value, tolerance]
            [0.5, "control", "left", 200, 0],
            [0.5, "test", "left", 200, 0],
        ];

        function setupTest()
        {
            movers.offsetTop; // force style recalc
            movers.className = 'moved';
            runAnimationTest(expectedValues);
        }

        window.addEventListener('load', setupTest, false);
    </script>
</head>
<body>
    <p>Animations should both use a linear timing function.</p>
    <div id="movers">
        <div id="control" class="box"></div>
        <div id="test" class="box"></div>
    </div>
    <div id="result"></div>
</body>
</html>