mirror of
https://github.com/discourse/discourse.git
synced 2025-01-06 09:43:46 +08:00
116 lines
3.1 KiB
JavaScript
116 lines
3.1 KiB
JavaScript
import { render } from "@ember/test-helpers";
|
|
import hbs from "htmlbars-inline-precompile";
|
|
import { module, test } from "qunit";
|
|
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
|
import { count } from "discourse/tests/helpers/qunit-helpers";
|
|
|
|
const OPTIONS = [
|
|
{ id: "1ddc47be0d2315b9711ee8526ca9d83f", html: "This", votes: 0, rank: 0 },
|
|
{ id: "70e743697dac09483d7b824eaadb91e1", html: "That", votes: 0, rank: 0 },
|
|
{ id: "6c986ebcde3d5822a6e91a695c388094", html: "Other", votes: 0, rank: 0 },
|
|
];
|
|
|
|
const IMAGE_OPTIONS = [
|
|
{
|
|
id: "1ddc47be0d2315b9711ee8526ca9d83f",
|
|
html: "<img src='upload://tpbXHFLPCTLWjyGvtyekmXQN49A.jpeg'></img>",
|
|
votes: 0,
|
|
rank: 0,
|
|
},
|
|
{
|
|
id: "70e743697dac09483d7b824eaadb91e1",
|
|
html: "<img src='upload://eurierXHFETLWjHsdfLKKJDFLKJ.jpeg'></img>",
|
|
votes: 0,
|
|
rank: 0,
|
|
},
|
|
];
|
|
|
|
module("Poll | Component | poll-options", function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
test("single, not selected", async function (assert) {
|
|
this.setProperties({
|
|
isCheckbox: false,
|
|
options: OPTIONS,
|
|
votes: [],
|
|
});
|
|
|
|
await render(hbs`<PollOptions
|
|
@isCheckbox={{this.isCheckbox}}
|
|
@options={{this.options}}
|
|
@votes={{this.votes}}
|
|
@sendRadioClick={{this.toggleOption}}
|
|
/>`);
|
|
|
|
assert.strictEqual(count("li .d-icon-far-circle:nth-of-type(1)"), 3);
|
|
});
|
|
|
|
test("single, selected", async function (assert) {
|
|
this.setProperties({
|
|
isCheckbox: false,
|
|
options: OPTIONS,
|
|
votes: ["6c986ebcde3d5822a6e91a695c388094"],
|
|
});
|
|
|
|
await render(hbs`<PollOptions
|
|
@isCheckbox={{this.isCheckbox}}
|
|
@options={{this.options}}
|
|
@votes={{this.votes}}
|
|
@sendRadioClick={{this.toggleOption}}
|
|
/>`);
|
|
|
|
assert.strictEqual(count("li .d-icon-circle:nth-of-type(1)"), 1);
|
|
});
|
|
|
|
test("multi, not selected", async function (assert) {
|
|
this.setProperties({
|
|
isCheckbox: true,
|
|
options: OPTIONS,
|
|
votes: [],
|
|
});
|
|
|
|
await render(hbs`<PollOptions
|
|
@isCheckbox={{this.isCheckbox}}
|
|
@options={{this.options}}
|
|
@votes={{this.votes}}
|
|
@sendRadioClick={{this.toggleOption}}
|
|
/>`);
|
|
|
|
assert.strictEqual(count("li .d-icon-far-square:nth-of-type(1)"), 3);
|
|
});
|
|
|
|
test("multi, selected", async function (assert) {
|
|
this.setProperties({
|
|
isCheckbox: true,
|
|
options: OPTIONS,
|
|
votes: ["6c986ebcde3d5822a6e91a695c388094"],
|
|
});
|
|
|
|
await render(hbs`<PollOptions
|
|
@isCheckbox={{this.isCheckbox}}
|
|
@options={{this.options}}
|
|
@votes={{this.votes}}
|
|
@sendRadioClick={{this.toggleOption}}
|
|
/>`);
|
|
|
|
assert.strictEqual(count("li .d-icon-far-check-square:nth-of-type(1)"), 1);
|
|
});
|
|
|
|
test("single with images", async function (assert) {
|
|
this.setProperties({
|
|
isCheckbox: false,
|
|
options: IMAGE_OPTIONS,
|
|
votes: [],
|
|
});
|
|
|
|
await render(hbs`<PollOptions
|
|
@isCheckbox={{this.isCheckbox}}
|
|
@options={{this.options}}
|
|
@votes={{this.votes}}
|
|
@sendRadioClick={{this.toggleOption}}
|
|
/>`);
|
|
|
|
assert.strictEqual(count("li img"), 2);
|
|
});
|
|
});
|