DEV: Await for ace render in tests (#28586)

Why all the manual setting of `width` and `height`? Without it all ace editors were 0x0, invisible.

Why didn't it affect the tests before? ace-editor tests only confirms that there is an element, theme-settings-editor tests were effectively unit tests before 7317b5a, fk-code test avoids interacting with ace.
This commit is contained in:
Jarek Radosz 2024-08-28 11:24:30 +02:00 committed by GitHub
parent 80449d39d3
commit 480f26a2c2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 33 additions and 7 deletions

View File

@ -3,6 +3,7 @@ import { tracked } from "@glimmer/tracking";
import didInsert from "@ember/render-modifiers/modifiers/did-insert"; import didInsert from "@ember/render-modifiers/modifiers/did-insert";
import didUpdate from "@ember/render-modifiers/modifiers/did-update"; import didUpdate from "@ember/render-modifiers/modifiers/did-update";
import { service } from "@ember/service"; import { service } from "@ember/service";
import { registerWaiter } from "@ember/test";
import { modifier } from "ember-modifier"; import { modifier } from "ember-modifier";
import ConditionalLoadingSpinner from "discourse/components/conditional-loading-spinner"; import ConditionalLoadingSpinner from "discourse/components/conditional-loading-spinner";
import loadAce from "discourse/lib/load-ace-editor"; import loadAce from "discourse/lib/load-ace-editor";
@ -70,6 +71,12 @@ export default class AceEditor extends Component {
this.skipChangePropagation = true; this.skipChangePropagation = true;
this.editor.getSession().setValue(this.args.content || ""); this.editor.getSession().setValue(this.args.content || "");
this.skipChangePropagation = false; this.skipChangePropagation = false;
if (isTesting()) {
let finished = false;
registerWaiter(() => finished);
this.editor.renderer.once("afterRender", () => (finished = true));
}
}); });
constructor() { constructor() {
@ -165,7 +172,7 @@ export default class AceEditor extends Component {
@bind @bind
editorIdChanged() { editorIdChanged() {
if (this.autofocus) { if (this.autofocus) {
this.send("focus"); this.focus();
} }
} }

View File

@ -7,34 +7,52 @@ module("Integration | Component | ace-editor", function (hooks) {
setupRenderingTest(hooks); setupRenderingTest(hooks);
test("css editor", async function (assert) { test("css editor", async function (assert) {
await render(<template><AceEditor @mode="css" /></template>); await render(<template>
<AceEditor @mode="css" style="width: 300px; height: 200px" />
</template>);
assert.dom(".ace_editor").exists("it renders the ace editor"); assert.dom(".ace_editor").exists("it renders the ace editor");
}); });
test("html editor", async function (assert) { test("html editor", async function (assert) {
await render(<template> await render(<template>
<AceEditor @mode="html" @content="<b>wat</b>" /> <AceEditor
@mode="html"
@content="<b>wat</b>"
style="width: 300px; height: 200px"
/>
</template>); </template>);
assert.dom(".ace_editor").exists("it renders the ace editor"); assert.dom(".ace_editor").exists("it renders the ace editor");
}); });
test("sql editor", async function (assert) { test("sql editor", async function (assert) {
await render(<template> await render(<template>
<AceEditor @mode="sql" @content="SELECT * FROM users" /> <AceEditor
@mode="sql"
@content="SELECT * FROM users"
style="width: 300px; height: 200px"
/>
</template>); </template>);
assert.dom(".ace_editor").exists("it renders the ace editor"); assert.dom(".ace_editor").exists("it renders the ace editor");
}); });
test("yaml editor", async function (assert) { test("yaml editor", async function (assert) {
await render(<template> await render(<template>
<AceEditor @mode="yaml" @content="test: true" /> <AceEditor
@mode="yaml"
@content="test: true"
style="width: 300px; height: 200px"
/>
</template>); </template>);
assert.dom(".ace_editor").exists("it renders the ace editor"); assert.dom(".ace_editor").exists("it renders the ace editor");
}); });
test("javascript editor", async function (assert) { test("javascript editor", async function (assert) {
await render(<template> await render(<template>
<AceEditor @mode="javascript" @content="test: true" /> <AceEditor
@mode="javascript"
@content="test: true"
style="width: 300px; height: 200px"
/>
</template>); </template>);
assert.dom(".ace_editor").exists("it renders the ace editor"); assert.dom(".ace_editor").exists("it renders the ace editor");
}); });
@ -45,6 +63,7 @@ module("Integration | Component | ace-editor", function (hooks) {
@mode="sql" @mode="sql"
@content="SELECT * FROM users" @content="SELECT * FROM users"
@disabled={{true}} @disabled={{true}}
style="width: 300px; height: 200px"
/> />
</template>); </template>);

View File

@ -14,7 +14,7 @@ module("Integration | Component | FormKit | Controls | Code", function (hooks) {
await render(<template> await render(<template>
<Form @onSubmit={{mutateData}} @data={{data}} as |form|> <Form @onSubmit={{mutateData}} @data={{data}} as |form|>
<form.Field @name="foo" @title="Foo" as |field|> <form.Field @name="foo" @title="Foo" as |field|>
<field.Code /> <field.Code @height={{100}} style="width: 200px" />
</form.Field> </form.Field>
</Form> </Form>
</template>); </template>);