discourse/plugins/poll/test/javascripts/acceptance/poll-builder-enabled-test.js
Martin Brennan a03f87bdbd
DEV: Move core plugin TL -> group settings (#25355)
* DEV: Change poll_minimum_trust_level_to_create to group based setting

New setting is poll_create_allowed_groups

c.f. https://meta.discourse.org/t/changes-coming-to-settings-for-giving-access-to-features-from-trust-levels-to-groups/283408

* DEV: Move styleguide_admin_only to group based setting

Not exactly a TL -> group change, but still part of the
overall effort here:

https://meta.discourse.org/t/changes-coming-to-settings-for-giving-access-to-features-from-trust-levels-to-groups/283408

New setting is styleguide_allowed_groups
2024-01-23 11:35:14 +10:00

83 lines
2.1 KiB
JavaScript

import { click } from "@ember/test-helpers";
import { test } from "qunit";
import { AUTO_GROUPS } from "discourse/lib/constants";
import {
acceptance,
exists,
updateCurrentUser,
} from "discourse/tests/helpers/qunit-helpers";
import I18n from "discourse-i18n";
import { displayPollBuilderButton } from "discourse/plugins/poll/helpers/display-poll-builder-button";
acceptance("Poll Builder - polls are enabled", function (needs) {
needs.user();
needs.settings({
poll_enabled: true,
poll_create_allowed_groups: AUTO_GROUPS.trust_level_1,
});
test("regular user - sufficient trust level", async function (assert) {
updateCurrentUser({
moderator: false,
admin: false,
trust_level: 1,
can_create_poll: true,
});
await displayPollBuilderButton();
const pollBuilderButtonSelector = `.select-kit-row[data-name='${I18n.t(
"poll.ui_builder.title"
)}']`;
assert.dom(pollBuilderButtonSelector).exists("it shows the builder button");
await click(pollBuilderButtonSelector);
assert.true(
exists(".poll-type-value-regular.active"),
"regular type is active"
);
await click(".poll-type-value-multiple");
assert.true(
exists(".poll-type-value-multiple.active"),
"multiple type is active"
);
await click(".poll-type-value-regular");
assert.true(
exists(".poll-type-value-regular.active"),
"regular type is active"
);
});
test("regular user - insufficient trust level", async function (assert) {
updateCurrentUser({
moderator: false,
admin: false,
trust_level: 0,
can_create_poll: false,
});
await displayPollBuilderButton();
assert.ok(
!exists(".select-kit-row[data-value='showPollBuilder]"),
"it hides the builder button"
);
});
test("staff - with insufficient trust level", async function (assert) {
updateCurrentUser({ moderator: true, trust_level: 0 });
await displayPollBuilderButton();
assert
.dom(`.select-kit-row[data-name='${I18n.t("poll.ui_builder.title")}']`)
.exists("it shows the builder button");
});
});