diff options
Diffstat (limited to 'devtools/client/netmonitor/test/browser_net_charts-03.js')
-rw-r--r-- | devtools/client/netmonitor/test/browser_net_charts-03.js | 195 |
1 files changed, 195 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_charts-03.js b/devtools/client/netmonitor/test/browser_net_charts-03.js new file mode 100644 index 0000000000..f938bb3932 --- /dev/null +++ b/devtools/client/netmonitor/test/browser_net_charts-03.js @@ -0,0 +1,195 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +/** + * Makes sure Table Charts have the right internal structure. + */ + +add_task(async function () { + const { + L10N, + } = require("resource://devtools/client/netmonitor/src/utils/l10n.js"); + + const { monitor } = await initNetMonitor(HTTPS_SIMPLE_URL, { + requestCount: 1, + }); + info("Starting test... "); + + const { document, windowRequire } = monitor.panelWin; + const { Chart } = windowRequire("devtools/client/shared/widgets/Chart"); + + const wait = waitForNetworkEvents(monitor, 1); + await navigateTo(HTTPS_SIMPLE_URL); + await wait; + + const table = Chart.Table(document, { + title: "Table title", + data: [ + { + label1: 1, + label2: 11.1, + }, + { + label1: 2, + label2: 12.2, + }, + { + label1: 3, + label2: 13.3, + }, + ], + strings: { + label2: (value, index) => value + ["foo", "bar", "baz"][index], + }, + totals: { + label1: value => "Hello " + L10N.numberWithDecimals(value, 2), + label2: value => "World " + L10N.numberWithDecimals(value, 2), + }, + header: { + label1: "label1header", + label2: "label2header", + }, + }); + + const { node } = table; + const title = node.querySelector(".table-chart-title"); + const grid = node.querySelector(".table-chart-grid"); + const totals = node.querySelector(".table-chart-totals"); + const rows = grid.querySelectorAll(".table-chart-row"); + const sums = node.querySelectorAll(".table-chart-summary-label"); + + ok( + node.classList.contains("table-chart-container") && + node.classList.contains("generic-chart-container"), + "A table chart container was created successfully." + ); + + ok(title, "A title node was created successfully."); + is( + title.textContent, + "Table title", + "The title node displays the correct text." + ); + + is( + rows.length, + 4, + "There should be 3 table chart rows and a header created." + ); + + is( + rows[0].querySelectorAll(".table-chart-row-label")[0].getAttribute("name"), + "label1", + "The first column of the header exists." + ); + is( + rows[0].querySelectorAll(".table-chart-row-label")[1].getAttribute("name"), + "label2", + "The second column of the header exists." + ); + is( + rows[0].querySelectorAll(".table-chart-row-label")[0].textContent, + "label1header", + "The first column of the header displays the correct text." + ); + is( + rows[0].querySelectorAll(".table-chart-row-label")[1].textContent, + "label2header", + "The second column of the header displays the correct text." + ); + + is( + rows[1].querySelectorAll(".table-chart-row-label")[0].getAttribute("name"), + "label1", + "The first column of the first row exists." + ); + is( + rows[1].querySelectorAll(".table-chart-row-label")[1].getAttribute("name"), + "label2", + "The second column of the first row exists." + ); + is( + rows[1].querySelectorAll(".table-chart-row-label")[0].textContent, + "1", + "The first column of the first row displays the correct text." + ); + is( + rows[1].querySelectorAll(".table-chart-row-label")[1].textContent, + "11.1foo", + "The second column of the first row displays the correct text." + ); + + is( + rows[2].querySelectorAll(".table-chart-row-label")[0].getAttribute("name"), + "label1", + "The first column of the second row exists." + ); + is( + rows[2].querySelectorAll(".table-chart-row-label")[1].getAttribute("name"), + "label2", + "The second column of the second row exists." + ); + is( + rows[2].querySelectorAll(".table-chart-row-label")[0].textContent, + "2", + "The first column of the second row displays the correct text." + ); + is( + rows[2].querySelectorAll(".table-chart-row-label")[1].textContent, + "12.2bar", + "The second column of the first row displays the correct text." + ); + + is( + rows[3].querySelectorAll(".table-chart-row-label")[0].getAttribute("name"), + "label1", + "The first column of the third row exists." + ); + is( + rows[3].querySelectorAll(".table-chart-row-label")[1].getAttribute("name"), + "label2", + "The second column of the third row exists." + ); + is( + rows[3].querySelectorAll(".table-chart-row-label")[0].textContent, + "3", + "The first column of the third row displays the correct text." + ); + is( + rows[3].querySelectorAll(".table-chart-row-label")[1].textContent, + "13.3baz", + "The second column of the third row displays the correct text." + ); + + is(sums.length, 2, "There should be 2 total summaries created."); + + is( + totals + .querySelectorAll(".table-chart-summary-label")[0] + .getAttribute("name"), + "label1", + "The first sum's type is correct." + ); + is( + totals.querySelectorAll(".table-chart-summary-label")[0].textContent, + "Hello 6", + "The first sum's value is correct." + ); + + is( + totals + .querySelectorAll(".table-chart-summary-label")[1] + .getAttribute("name"), + "label2", + "The second sum's type is correct." + ); + is( + totals.querySelectorAll(".table-chart-summary-label")[1].textContent, + "World 36.60", + "The second sum's value is correct." + ); + + await teardown(monitor); +}); |