summaryrefslogtreecommitdiffstats
path: root/devtools/client/webaudioeditor/test/browser_wa_automation-view-02.js
blob: a0f5f5a04e762b0b7b5e4fa8e19a78fc91f8f803 (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
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

/**
 * Tests that automation view selects the first parameter by default and
 * switching between AudioParam rerenders the graph.
 */

add_task(function* () {
  let { target, panel } = yield initWebAudioEditor(AUTOMATION_URL);
  let { panelWin } = panel;
  let { gFront, $, $$, EVENTS, AutomationView } = panelWin;

  let started = once(gFront, "start-context");

  let events = Promise.all([
    get3(gFront, "create-node"),
    waitForGraphRendered(panelWin, 3, 2)
  ]);
  reload(target);
  let [actors] = yield events;
  let nodeIds = actors.map(actor => actor.actorID);

  // Oscillator node
  click(panelWin, findGraphNode(panelWin, nodeIds[1]));
  yield waitForInspectorRender(panelWin, EVENTS);
  click(panelWin, $("#automation-tab"));

  ok(AutomationView._selectedParamName, "frequency",
    "AutomatioView is set on 'frequency'");
  ok($(".automation-param-button[data-param='frequency']").getAttribute("selected"),
    "frequency param should be selected on load");
  ok(!$(".automation-param-button[data-param='detune']").getAttribute("selected"),
    "detune param should not be selected on load");
  ok(isVisible($("#automation-content")), "automation content should be visible");
  ok(isVisible($("#automation-graph-container")), "graph container should be visible");
  ok(!isVisible($("#automation-no-events")), "no-events panel should not be visible");

  click(panelWin, $(".automation-param-button[data-param='detune']"));
  yield once(panelWin, EVENTS.UI_AUTOMATION_TAB_RENDERED);

  ok(true, "automation tab rerendered");

  ok(AutomationView._selectedParamName, "detune",
    "AutomatioView is set on 'detune'");
  ok(!$(".automation-param-button[data-param='frequency']").getAttribute("selected"),
    "frequency param should not be selected after clicking detune");
  ok($(".automation-param-button[data-param='detune']").getAttribute("selected"),
    "detune param should be selected after clicking detune");
  ok(isVisible($("#automation-content")), "automation content should be visible");
  ok(!isVisible($("#automation-graph-container")), "graph container should not be visible");
  ok(isVisible($("#automation-no-events")), "no-events panel should be visible");

  yield teardown(target);
});