diff options
Diffstat (limited to 'devtools/client/animationinspector/test/browser_animation_timeline_shows_iterations.js')
-rw-r--r-- | devtools/client/animationinspector/test/browser_animation_timeline_shows_iterations.js | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/devtools/client/animationinspector/test/browser_animation_timeline_shows_iterations.js b/devtools/client/animationinspector/test/browser_animation_timeline_shows_iterations.js new file mode 100644 index 000000000..08e5a2620 --- /dev/null +++ b/devtools/client/animationinspector/test/browser_animation_timeline_shows_iterations.js @@ -0,0 +1,47 @@ +/* vim: set ts=2 et sw=2 tw=80: */ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +requestLongerTimeout(2); + +// Check that the timeline is displays as many iteration elements as there are +// iterations in an animation. + +add_task(function* () { + yield addTab(URL_ROOT + "doc_simple_animation.html"); + let {inspector, panel} = yield openAnimationInspector(); + + info("Selecting the test node"); + yield selectNodeAndWaitForAnimations(".delayed", inspector); + + info("Getting the animation element from the panel"); + const timelineComponent = panel.animationsTimelineComponent; + const timelineEl = timelineComponent.rootWrapperEl; + let animation = timelineEl.querySelector(".time-block"); + // Get iteration count from summary graph path. + let iterationCount = getIterationCount(animation); + + is(iterationCount, 10, + "The animation timeline contains the right number of iterations"); + ok(!animation.querySelector(".infinity"), + "The summary graph does not have any elements " + + " that have infinity class"); + + info("Selecting another test node with an infinite animation"); + yield selectNodeAndWaitForAnimations(".animated", inspector); + + info("Getting the animation element from the panel again"); + animation = timelineEl.querySelector(".time-block"); + iterationCount = getIterationCount(animation); + + is(iterationCount, 1, + "The animation timeline contains one iteration"); + ok(animation.querySelector(".infinity"), + "The summary graph has an element that has infinity class"); +}); + +function getIterationCount(timeblockEl) { + return timeblockEl.querySelectorAll(".iteration-path").length; +} |