summaryrefslogtreecommitdiffstats
path: root/browser/components/screenshots/tests/browser/browser_screenshots_overlay_panel_sync.js
blob: b66a4d2b5759b82cf11c379bde601b5e724e0502 (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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

async function waitOnTabSwitch() {
  // eslint-disable-next-line mozilla/no-arbitrary-setTimeout
  await new Promise(r => setTimeout(r, 300));
}

add_task(async function test_overlay_and_panel_state() {
  let tab1 = await BrowserTestUtils.openNewForegroundTab(gBrowser, TEST_PAGE);

  let screenshotsTab = await BrowserTestUtils.openNewForegroundTab(
    gBrowser,
    TEST_PAGE
  );
  let browser = screenshotsTab.linkedBrowser;

  let helper = new ScreenshotsHelper(browser);

  helper.triggerUIFromToolbar();

  await helper.waitForOverlay();

  helper.assertPanelVisible();

  await helper.dragOverlay(10, 10, 500, 500);

  await helper.waitForStateChange("selected");
  let state = await helper.getOverlayState();
  is(state, "selected", "The overlay is in the selected state");

  helper.assertPanelNotVisible();

  mouse.click(600, 600);

  await helper.waitForStateChange("crosshairs");
  state = await helper.getOverlayState();
  is(state, "crosshairs", "The overlay is in the crosshairs state");

  await helper.waitForOverlay();

  helper.assertPanelVisible();

  await BrowserTestUtils.switchTab(gBrowser, tab1);
  await BrowserTestUtils.switchTab(gBrowser, screenshotsTab);

  await helper.waitForOverlayClosed();

  Assert.ok(!(await helper.isOverlayInitialized()), "Overlay is closed");
  helper.assertPanelNotVisible();

  helper.triggerUIFromToolbar();

  await helper.waitForOverlay();

  helper.assertPanelVisible();

  await helper.dragOverlay(10, 10, 500, 500);

  await helper.waitForStateChange("selected");
  state = await helper.getOverlayState();
  is(state, "selected", "The overlay is in the selected state");

  await BrowserTestUtils.switchTab(gBrowser, tab1);
  await BrowserTestUtils.switchTab(gBrowser, screenshotsTab);

  Assert.ok(await helper.isOverlayInitialized(), "Overlay is open");
  helper.assertPanelNotVisible();
  state = await helper.getOverlayState();
  is(state, "selected", "The overlay is in the selected state");

  helper.triggerUIFromToolbar();
  await helper.waitForOverlayClosed();

  Assert.ok(!(await helper.isOverlayInitialized()), "Overlay is closed");
  helper.assertPanelNotVisible();

  gBrowser.removeTab(tab1);
  gBrowser.removeTab(screenshotsTab);
});