We used many global functions to handle tests when they should be imported like other libraries in our application. This also gets us closer to the way Ember CLI prefers our tests to be laid out.
103 lines
2.7 KiB
JavaScript
103 lines
2.7 KiB
JavaScript
import { test } from "qunit";
|
|
import selectKit from "discourse/tests/helpers/select-kit-helper";
|
|
import { acceptance } from "discourse/tests/helpers/qunit-helpers";
|
|
|
|
acceptance("Admin - Suspend User", {
|
|
loggedIn: true,
|
|
|
|
pretend(server, helper) {
|
|
server.put("/admin/users/:user_id/suspend", () =>
|
|
helper.response(200, {
|
|
suspension: {
|
|
suspended_till: "2099-01-01T12:00:00.000Z",
|
|
},
|
|
})
|
|
);
|
|
|
|
server.put("/admin/users/:user_id/unsuspend", () =>
|
|
helper.response(200, {
|
|
suspension: {
|
|
suspended_till: null,
|
|
},
|
|
})
|
|
);
|
|
},
|
|
});
|
|
|
|
test("suspend a user - cancel", async (assert) => {
|
|
await visit("/admin/users/1234/regular");
|
|
await click(".suspend-user");
|
|
|
|
assert.equal(find(".suspend-user-modal:visible").length, 1);
|
|
|
|
await click(".d-modal-cancel");
|
|
|
|
assert.equal(find(".suspend-user-modal:visible").length, 0);
|
|
});
|
|
|
|
test("suspend a user - cancel with input", async (assert) => {
|
|
await visit("/admin/users/1234/regular");
|
|
await click(".suspend-user");
|
|
|
|
assert.equal(find(".suspend-user-modal:visible").length, 1);
|
|
|
|
await fillIn(".suspend-reason", "for breaking the rules");
|
|
await fillIn(".suspend-message", "this is an email reason why");
|
|
|
|
await click(".d-modal-cancel");
|
|
|
|
assert.equal(find(".bootbox.modal:visible").length, 1);
|
|
|
|
await click(".modal-footer .btn-default");
|
|
assert.equal(find(".suspend-user-modal:visible").length, 1);
|
|
assert.equal(
|
|
find(".suspend-message")[0].value,
|
|
"this is an email reason why"
|
|
);
|
|
|
|
await click(".d-modal-cancel");
|
|
assert.equal(find(".bootbox.modal:visible").length, 1);
|
|
assert.equal(find(".suspend-user-modal:visible").length, 0);
|
|
await click(".modal-footer .btn-primary");
|
|
assert.equal(find(".bootbox.modal:visible").length, 0);
|
|
});
|
|
|
|
test("suspend, then unsuspend a user", async (assert) => {
|
|
const suspendUntilCombobox = selectKit(".suspend-until .combobox");
|
|
|
|
await visit("/admin/flags/active");
|
|
|
|
await visit("/admin/users/1234/regular");
|
|
|
|
assert.ok(!exists(".suspension-info"));
|
|
|
|
await click(".suspend-user");
|
|
|
|
assert.equal(
|
|
find(".perform-suspend[disabled]").length,
|
|
1,
|
|
"disabled by default"
|
|
);
|
|
|
|
await suspendUntilCombobox.expand();
|
|
await suspendUntilCombobox.selectRowByValue("tomorrow");
|
|
|
|
await fillIn(".suspend-reason", "for breaking the rules");
|
|
await fillIn(".suspend-message", "this is an email reason why");
|
|
|
|
assert.equal(
|
|
find(".perform-suspend[disabled]").length,
|
|
0,
|
|
"no longer disabled"
|
|
);
|
|
|
|
await click(".perform-suspend");
|
|
|
|
assert.equal(find(".suspend-user-modal:visible").length, 0);
|
|
assert.ok(exists(".suspension-info"));
|
|
|
|
await click(".unsuspend-user");
|
|
|
|
assert.ok(!exists(".suspension-info"));
|
|
});
|