discourse/plugins/poll/test/javascripts/widgets/discourse-poll-standard-res...

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

91 lines
2.1 KiB
Plaintext
Raw Normal View History

import {
moduleForWidget,
widgetTest,
} from "discourse/tests/helpers/widget-test";
import EmberObject from "@ember/object";
import { queryAll } from "discourse/tests/helpers/qunit-helpers";
2018-06-15 12:42:20 -04:00
moduleForWidget("discourse-poll-standard-results");
const template = `{{mount-widget
widget="discourse-poll-standard-results"
args=(hash poll=poll isMultiple=isMultiple)}}`;
2018-06-15 12:42:20 -04:00
widgetTest("options in descending order", {
template,
2017-06-14 13:57:58 -04:00
beforeEach() {
2018-06-15 12:42:20 -04:00
this.set(
"poll",
EmberObject.create({
2018-06-15 12:42:20 -04:00
options: [{ votes: 5 }, { votes: 4 }],
voters: 9,
2018-06-15 12:42:20 -04:00
})
);
},
test(assert) {
assert.equal(queryAll(".option .percentage")[0].innerText, "56%");
assert.equal(queryAll(".option .percentage")[1].innerText, "44%");
},
});
2018-06-15 12:42:20 -04:00
widgetTest("options in ascending order", {
template,
2017-06-14 13:57:58 -04:00
beforeEach() {
2018-06-15 12:42:20 -04:00
this.set(
"poll",
EmberObject.create({
2018-06-15 12:42:20 -04:00
options: [{ votes: 4 }, { votes: 5 }],
voters: 9,
2018-06-15 12:42:20 -04:00
})
);
},
test(assert) {
assert.equal(queryAll(".option .percentage")[0].innerText, "56%");
assert.equal(queryAll(".option .percentage")[1].innerText, "44%");
},
});
2018-06-15 12:42:20 -04:00
widgetTest("multiple options in descending order", {
template,
2017-06-14 13:57:58 -04:00
beforeEach() {
2018-06-15 12:42:20 -04:00
this.set("isMultiple", true);
this.set(
"poll",
EmberObject.create({
2018-06-15 12:42:20 -04:00
type: "multiple",
options: [
{ votes: 5, html: "a" },
{ votes: 2, html: "b" },
{ votes: 4, html: "c" },
{ votes: 1, html: "b" },
{ votes: 1, html: "a" },
2018-06-15 12:42:20 -04:00
],
voters: 12,
2018-06-15 12:42:20 -04:00
})
);
},
test(assert) {
let percentages = queryAll(".option .percentage");
assert.equal(percentages[0].innerText, "41%");
assert.equal(percentages[1].innerText, "33%");
assert.equal(percentages[2].innerText, "16%");
assert.equal(percentages[3].innerText, "8%");
assert.equal(
queryAll(".option")[3].querySelectorAll("span")[1].innerText,
"a"
);
assert.equal(percentages[4].innerText, "8%");
assert.equal(
queryAll(".option")[4].querySelectorAll("span")[1].innerText,
"b"
);
},
});