/* 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(function* () {
  let { L10N } = require("devtools/client/netmonitor/l10n");

  let { monitor } = yield initNetMonitor(SIMPLE_URL);
  info("Starting test... ");

  let { document, Chart } = monitor.panelWin;

  let 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",
    }
  });

  let node = table.node;
  let title = node.querySelector(".table-chart-title");
  let grid = node.querySelector(".table-chart-grid");
  let totals = node.querySelector(".table-chart-totals");
  let rows = grid.querySelectorAll(".table-chart-row");
  let 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.getAttribute("value"), "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("label")[0].getAttribute("name"), "label1",
    "The first column of the header exists.");
  is(rows[0].querySelectorAll("label")[1].getAttribute("name"), "label2",
    "The second column of the header exists.");
  is(rows[0].querySelectorAll("span")[0].textContent, "label1header",
    "The first column of the header displays the correct text.");
  is(rows[0].querySelectorAll("span")[1].textContent, "label2header",
    "The second column of the header displays the correct text.");

  ok(rows[1].querySelector(".table-chart-row-box.chart-colored-blob"),
    "A colored blob exists for the firt row.");
  is(rows[1].querySelectorAll("span")[0].getAttribute("name"), "label1",
    "The first column of the first row exists.");
  is(rows[1].querySelectorAll("span")[1].getAttribute("name"), "label2",
    "The second column of the first row exists.");
  is(rows[1].querySelectorAll("label")[0].getAttribute("value"), "1",
    "The first column of the first row displays the correct text.");
  is(rows[1].querySelectorAll("label")[1].getAttribute("value"), "11.1foo",
    "The second column of the first row displays the correct text.");

  ok(rows[2].querySelector(".table-chart-row-box.chart-colored-blob"),
    "A colored blob exists for the second row.");
  is(rows[2].querySelectorAll("label")[0].getAttribute("name"), "label1",
    "The first column of the second row exists.");
  is(rows[2].querySelectorAll("label")[1].getAttribute("name"), "label2",
    "The second column of the second row exists.");
  is(rows[2].querySelectorAll("label")[0].getAttribute("value"), "2",
    "The first column of the second row displays the correct text.");
  is(rows[2].querySelectorAll("label")[1].getAttribute("value"), "12.2bar",
    "The second column of the first row displays the correct text.");

  ok(rows[3].querySelector(".table-chart-row-box.chart-colored-blob"),
    "A colored blob exists for the third row.");
  is(rows[3].querySelectorAll("label")[0].getAttribute("name"), "label1",
    "The first column of the third row exists.");
  is(rows[3].querySelectorAll("label")[1].getAttribute("name"), "label2",
    "The second column of the third row exists.");
  is(rows[3].querySelectorAll("label")[0].getAttribute("value"), "3",
    "The first column of the third row displays the correct text.");
  is(rows[3].querySelectorAll("label")[1].getAttribute("value"), "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].getAttribute("value"),
    "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].getAttribute("value"),
    "World 36.60",
    "The second sum's value is correct.");

  yield teardown(monitor);
});