2023-10-11 02:38:59 +08:00
|
|
|
import { click, visit } from "@ember/test-helpers";
|
|
|
|
import { test } from "qunit";
|
2021-06-08 23:54:12 +08:00
|
|
|
import {
|
|
|
|
acceptance,
|
|
|
|
count,
|
|
|
|
query,
|
|
|
|
} from "discourse/tests/helpers/qunit-helpers";
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2020-10-21 01:56:52 +08:00
|
|
|
acceptance("Poll breakdown", function (needs) {
|
|
|
|
needs.user();
|
|
|
|
needs.settings({
|
|
|
|
poll_enabled: true,
|
|
|
|
poll_groupable_user_fields: "something",
|
|
|
|
});
|
2023-10-06 07:43:40 +08:00
|
|
|
|
2020-10-21 01:56:52 +08:00
|
|
|
needs.pretender((server, helper) => {
|
|
|
|
server.get("/polls/grouped_poll_results.json", () =>
|
|
|
|
helper.response({
|
|
|
|
grouped_results: [
|
|
|
|
{
|
|
|
|
group: "Engineering",
|
|
|
|
options: [
|
2020-08-06 23:57:06 +08:00
|
|
|
{
|
2020-10-21 01:56:52 +08:00
|
|
|
digest: "687a1ccf3c6a260f9aeeb7f68a1d463c",
|
|
|
|
html: "This Is",
|
|
|
|
votes: 1,
|
2020-08-06 23:57:06 +08:00
|
|
|
},
|
|
|
|
{
|
2020-10-21 01:56:52 +08:00
|
|
|
digest: "9377906763a1221d31d656ea0c4a4495",
|
|
|
|
html: "A test for sure",
|
|
|
|
votes: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
digest: "ecf47c65a85a0bb20029072b1b721977",
|
|
|
|
html: "Why not give it some more",
|
|
|
|
votes: 1,
|
2020-09-05 02:01:14 +08:00
|
|
|
},
|
|
|
|
],
|
2020-10-21 01:56:52 +08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
group: "Marketing",
|
|
|
|
options: [
|
|
|
|
{
|
|
|
|
digest: "687a1ccf3c6a260f9aeeb7f68a1d463c",
|
|
|
|
html: "This Is",
|
|
|
|
votes: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
digest: "9377906763a1221d31d656ea0c4a4495",
|
|
|
|
html: "A test for sure",
|
|
|
|
votes: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
digest: "ecf47c65a85a0bb20029072b1b721977",
|
|
|
|
html: "Why not give it some more",
|
|
|
|
votes: 1,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2020-10-31 00:37:32 +08:00
|
|
|
test("Displaying the poll breakdown modal", async function (assert) {
|
2020-10-21 01:56:52 +08:00
|
|
|
await visit("/t/-/topic_with_pie_chart_poll");
|
2024-07-04 19:34:48 +08:00
|
|
|
|
2023-07-06 00:20:18 +08:00
|
|
|
await click(".widget-dropdown-header");
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2024-10-15 23:11:20 +08:00
|
|
|
assert
|
|
|
|
.dom("button.show-breakdown")
|
|
|
|
.exists(
|
|
|
|
"shows the breakdown button when poll_groupable_user_fields is non-empty"
|
|
|
|
);
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2024-07-04 19:34:48 +08:00
|
|
|
await click("button.show-breakdown");
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2024-10-15 23:11:20 +08:00
|
|
|
assert.dom(".poll-breakdown-total-votes").exists("displays the vote count");
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2021-11-08 17:26:28 +08:00
|
|
|
assert.strictEqual(
|
2021-06-08 23:54:12 +08:00
|
|
|
count(".poll-breakdown-chart-container"),
|
2020-10-21 01:56:52 +08:00
|
|
|
2,
|
|
|
|
"renders a chart for each of the groups in group_results response"
|
|
|
|
);
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2020-10-21 01:56:52 +08:00
|
|
|
assert.ok(
|
2021-06-08 23:54:12 +08:00
|
|
|
query(".poll-breakdown-chart-container > canvas").$chartjs,
|
2020-10-21 01:56:52 +08:00
|
|
|
"$chartjs is defined on the pie charts"
|
|
|
|
);
|
|
|
|
});
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2020-10-31 00:37:32 +08:00
|
|
|
test("Changing the display mode from percentage to count", async function (assert) {
|
2020-10-21 01:56:52 +08:00
|
|
|
await visit("/t/-/topic_with_pie_chart_poll");
|
2023-07-06 00:20:18 +08:00
|
|
|
await click(".widget-dropdown-header");
|
2024-07-04 19:34:48 +08:00
|
|
|
|
|
|
|
await click("button.show-breakdown");
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2021-11-08 17:26:28 +08:00
|
|
|
assert.strictEqual(
|
2021-06-08 23:54:12 +08:00
|
|
|
query(".poll-breakdown-option-count").textContent.trim(),
|
2020-10-21 01:56:52 +08:00
|
|
|
"40.0%",
|
|
|
|
"displays the correct vote percentage"
|
|
|
|
);
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2020-10-21 01:56:52 +08:00
|
|
|
await click(".modal-tabs .count");
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2021-11-08 17:26:28 +08:00
|
|
|
assert.strictEqual(
|
2021-06-08 23:54:12 +08:00
|
|
|
query(".poll-breakdown-option-count").textContent.trim(),
|
2020-10-21 01:56:52 +08:00
|
|
|
"2",
|
|
|
|
"displays the correct vote count"
|
|
|
|
);
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2020-10-21 01:56:52 +08:00
|
|
|
await click(".modal-tabs .percentage");
|
2020-08-06 23:57:06 +08:00
|
|
|
|
2021-11-08 17:26:28 +08:00
|
|
|
assert.strictEqual(
|
2021-06-08 23:54:12 +08:00
|
|
|
query(".poll-breakdown-option-count").textContent.trim(),
|
|
|
|
"40.0%",
|
2020-10-21 01:56:52 +08:00
|
|
|
"displays the percentage again"
|
|
|
|
);
|
|
|
|
});
|
2020-08-06 23:57:06 +08:00
|
|
|
});
|