summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_post-data-04.js
blob: 5657922873f9ddd3735c6e70c3256ee337c59ea3 (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
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

/**
 * Tests if the POST requests display the correct information in the UI,
 * for JSON payloads.
 */

add_task(function* () {
  let { L10N } = require("devtools/client/netmonitor/l10n");

  let { tab, monitor } = yield initNetMonitor(POST_JSON_URL);
  info("Starting test... ");

  let { document, EVENTS, NetMonitorView } = monitor.panelWin;
  let { RequestsMenu, NetworkDetails } = NetMonitorView;

  RequestsMenu.lazyUpdate = false;
  NetworkDetails._params.lazyEmpty = false;

  let wait = waitForNetworkEvents(monitor, 0, 1);
  yield ContentTask.spawn(tab.linkedBrowser, {}, function* () {
    content.wrappedJSObject.performRequests();
  });
  yield wait;

  let onEvent = monitor.panelWin.once(EVENTS.TAB_UPDATED);
  NetMonitorView.toggleDetailsPane({ visible: true }, 2);
  RequestsMenu.selectedIndex = 0;
  yield onEvent;

  let tabEl = document.querySelectorAll("#event-details-pane tab")[2];
  let tabpanel = document.querySelectorAll("#event-details-pane tabpanel")[2];

  is(tabEl.getAttribute("selected"), "true",
    "The params tab in the network details pane should be selected.");

  is(tabpanel.querySelector("#request-params-box")
    .hasAttribute("hidden"), false,
    "The request params box doesn't have the intended visibility.");
  is(tabpanel.querySelector("#request-post-data-textarea-box")
    .hasAttribute("hidden"), true,
    "The request post data textarea box doesn't have the intended visibility.");

  is(tabpanel.querySelectorAll(".variables-view-scope").length, 1,
    "There should be 1 param scopes displayed in this tabpanel.");
  is(tabpanel.querySelectorAll(".variables-view-empty-notice").length, 0,
    "The empty notice should not be displayed in this tabpanel.");

  let jsonScope = tabpanel.querySelectorAll(".variables-view-scope")[0];
  is(jsonScope.querySelector(".name").getAttribute("value"),
    L10N.getStr("jsonScopeName"),
    "The JSON scope doesn't have the correct title.");

  let valueScope = tabpanel.querySelector(
    ".variables-view-scope > .variables-view-element-details");

  is(valueScope.querySelectorAll(".variables-view-variable").length, 1,
    "There should be 1 value displayed in the JSON scope.");
  is(valueScope.querySelector(".variables-view-property .name")
    .getAttribute("value"),
    "a", "The JSON var name was incorrect.");
  is(valueScope.querySelector(".variables-view-property .value")
    .getAttribute("value"),
    "1", "The JSON var value was incorrect.");

  let detailsParent = valueScope.querySelector(".variables-view-property .name")
    .closest(".variables-view-element-details");
  is(detailsParent.hasAttribute("open"), true, "The JSON value must be visible");

  return teardown(monitor);
});