DEV: Convert composer-editor tests to gjs (#23768)

This commit is contained in:
Jarek Radosz 2023-10-04 03:39:41 +02:00 committed by GitHub
parent d269018c16
commit 6271e02369
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 18 deletions

View File

@ -1,23 +1,23 @@
import { module, test } from "qunit"; import { module, test } from "qunit";
import { setupRenderingTest } from "discourse/tests/helpers/component-test"; import { setupRenderingTest } from "discourse/tests/helpers/component-test";
import { fillIn, render } from "@ember/test-helpers"; import { fillIn, render } from "@ember/test-helpers";
import { hbs } from "ember-cli-htmlbars";
import pretender, { response } from "discourse/tests/helpers/create-pretender"; import pretender, { response } from "discourse/tests/helpers/create-pretender";
import { query } from "discourse/tests/helpers/qunit-helpers"; import { query } from "discourse/tests/helpers/qunit-helpers";
import ComposerEditor from "discourse/components/composer-editor";
module("Integration | Component | ComposerEditor", function (hooks) { module("Integration | Component | ComposerEditor", function (hooks) {
setupRenderingTest(hooks); setupRenderingTest(hooks);
test("warns about users that will not see a mention", async function (assert) { test("warns about users that will not see a mention", async function (assert) {
this.set("model", {}); const model = {};
this.set("noop", () => {}); const noop = () => {};
this.set("expectation", (warning) => { const expectation = (warning) => {
if (warning.name === "user-no") { if (warning.name === "user-no") {
assert.deepEqual(warning, { name: "user-no", reason: "a reason" }); assert.deepEqual(warning, { name: "user-no", reason: "a reason" });
} else if (warning.name === "user-nope") { } else if (warning.name === "user-nope") {
assert.deepEqual(warning, { name: "user-nope", reason: "a reason" }); assert.deepEqual(warning, { name: "user-nope", reason: "a reason" });
} }
}); };
pretender.get("/composer/mentions", () => { pretender.get("/composer/mentions", () => {
return response({ return response({
@ -32,27 +32,24 @@ module("Integration | Component | ComposerEditor", function (hooks) {
}); });
}); });
await render(hbs` await render(<template>
<ComposerEditor <ComposerEditor
@composer={{this.model}} @composer={{model}}
@afterRefresh={{this.noop}} @afterRefresh={{noop}}
@cannotSeeMention={{this.expectation}} @cannotSeeMention={{expectation}}
/> />
`); </template>);
await fillIn("textarea", "@user-no @user-ok @user-nope"); await fillIn("textarea", "@user-no @user-ok @user-nope");
}); });
test("preview sanitizes HTML", async function (assert) { test("preview sanitizes HTML", async function (assert) {
this.set("model", {}); const model = {};
this.set("noop", () => {}); const noop = () => {};
await render(hbs` await render(<template>
<ComposerEditor <ComposerEditor @composer={{model}} @afterRefresh={{noop}} />
@composer={{this.model}} </template>);
@afterRefresh={{this.noop}}
/>
`);
await fillIn(".d-editor-input", `"><svg onload="prompt(/xss/)"></svg>`); await fillIn(".d-editor-input", `"><svg onload="prompt(/xss/)"></svg>`);
assert.strictEqual( assert.strictEqual(