summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/animation/test/browser_animation_animation-target_select.js
blob: 970778c4c64c7883ad31f4a46af3afb49b6ab612 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

// Test for following selection feature related AnimationTarget component works:
// * select selected node by clicking on target node

add_task(async function () {
  await addTab(URL_ROOT + "doc_simple_animation.html");
  await removeAnimatedElementsExcept([".multi", ".long"]);
  const { animationInspector, panel } = await openAnimationInspector();

  info("Check initial status");
  is(
    panel.querySelectorAll(".animation-item").length,
    3,
    "The length of animations should be 3. Two .multi animations and one .long animation"
  );

  info("Check selecting an animated node by clicking on the target node");
  await clickOnTargetNode(animationInspector, panel, 0);
  assertNodeFront(
    animationInspector.inspector.selection.nodeFront,
    "DIV",
    "ball multi"
  );
  is(
    panel.querySelectorAll(".animation-item").length,
    2,
    "The length of animations should be 2"
  );

  info("Check if the both target nodes refer to the same node");
  await clickOnTargetNode(animationInspector, panel, 1);
  assertNodeFront(
    animationInspector.inspector.selection.nodeFront,
    "DIV",
    "ball multi"
  );
  is(
    panel.querySelectorAll(".animation-item").length,
    2,
    "The length of animations should be 2"
  );
});

function assertNodeFront(nodeFront, tagName, classValue) {
  is(
    nodeFront.tagName,
    tagName,
    "The highlighted node has the correct tagName"
  );
  is(
    nodeFront.attributes[0].name,
    "class",
    "The highlighted node has the correct attributes"
  );
  is(
    nodeFront.attributes[0].value,
    classValue,
    "The highlighted node has the correct class"
  );
}