chromium/third_party/blink/web_tests/svg/animations/script-tests/animate-elem-12-t-drt.js

description("A copy of the corresponding W3C-SVG-1.1 test, which dumps the animation at certain times");
embedSVGTestCase("../W3C-SVG-1.1/animate-elem-12-t.svg");

// Setup animation test
function sample1() {
    shouldBeCloseEnough("rect1.height.animVal.value", "210");
    shouldBe("rect1.height.baseVal.value", "210");
    expectTranslationMatrix("getTransformToElement(rootSVGElement, rect2)", "-250", "-250");
}

function sample2() {
    shouldBeCloseEnough("rect1.height.animVal.value", "177");
    shouldBe("rect1.height.baseVal.value", "210");
    expectTranslationMatrix("getTransformToElement(rootSVGElement, rect2)", "-250", "-217");
}

function sample3() {
    shouldBeCloseEnough("rect1.height.animVal.value", "121");
    shouldBe("rect1.height.baseVal.value", "210");
    expectTranslationMatrix("getTransformToElement(rootSVGElement, rect2)", "-250", "-161");
}

function sample4() {
    shouldBeCloseEnough("rect1.height.animVal.value", "10");
    shouldBe("rect1.height.baseVal.value", "210");
    expectTranslationMatrix("getTransformToElement(rootSVGElement, rect2)", "-250", "-50");
}

function executeTest() {
    var rects = rootSVGElement.ownerDocument.getElementsByTagName("rect");
    rect1 = rects[0];
    rect2 = rects[1];

    const expectedValues = [
        // [animationId, time, sampleCallback]
        ["an1", 0.0,   sample1],
        ["an1", 2.999, sample2],
        ["an1", 3.001, sample2],
        ["an1", 5.999, sample3],
        ["an1", 6.001, sample3],
        ["an1", 8.999, sample4],
        ["an1", 9.001, sample4],
        ["an1", 60.0,  sample4]
    ];

    runAnimationTest(expectedValues);
}

window.animationStartsImmediately = true;
var successfullyParsed = true;