DEV: Update theme-settings-editor tests (#28582)

Convert them to proper integration tests.
This commit is contained in:
Jarek Radosz 2024-08-27 18:47:24 +02:00 committed by GitHub
parent ee3b175373
commit 7317b5a120
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 78 additions and 56 deletions

View File

@ -6,6 +6,7 @@ import { service } from "@ember/service";
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";
import { isTesting } from "discourse-common/config/environment";
import { bind } from "discourse-common/utils/decorators"; import { bind } from "discourse-common/utils/decorators";
import I18n from "discourse-i18n"; import I18n from "discourse-i18n";
@ -143,6 +144,10 @@ export default class AceEditor extends Component {
this.editor.$blockScrolling = Infinity; this.editor.$blockScrolling = Infinity;
this.editor.renderer.setScrollMargin(10, 10); this.editor.renderer.setScrollMargin(10, 10);
if (isTesting()) {
element.aceEditor = this.editor;
}
this.changeDisabledState(); this.changeDisabledState();
this.warnSCSSDeprecations(); this.warnSCSSDeprecations();

View File

@ -1,15 +1,9 @@
import { render } from "@ember/test-helpers"; import { click, fillIn, render } from "@ember/test-helpers";
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 { query } from "discourse/tests/helpers/qunit-helpers";
import ThemeSettingsEditor from "admin/components/theme-settings-editor"; import ThemeSettingsEditor from "admin/components/theme-settings-editor";
function glimmerComponent(owner, componentClass, args = {}) {
const componentManager = owner.lookup("component-manager:glimmer");
return componentManager.createComponent(componentClass, {
named: args,
});
}
module( module(
"Integration | Component | admin-theme-settings-editor", "Integration | Component | admin-theme-settings-editor",
function (hooks) { function (hooks) {
@ -33,81 +27,104 @@ module(
}); });
test("input is valid json", async function (assert) { test("input is valid json", async function (assert) {
const component = glimmerComponent(this.owner, ThemeSettingsEditor, { const model = [];
model: [],
});
component.editedContent = "foo"; await render(<template>
component.save(); <ThemeSettingsEditor @model={{model}} />
assert.strictEqual(component.errors[0].setting, "Syntax Error"); </template>);
await fillIn(".ace textarea", "foo");
await click("button#save");
assert.dom(".validation-error").hasText(/Syntax Error/);
}); });
test("'setting' key is present for each setting", async function (assert) { test("'setting' key is present for each setting", async function (assert) {
const component = glimmerComponent(this.owner, ThemeSettingsEditor, { const model = [];
model: [],
});
component.editedContent = JSON.stringify([{ value: "value1" }]); await render(<template>
component.save(); <ThemeSettingsEditor @model={{model}} />
assert.strictEqual(component.errors[0].setting, "Syntax Error"); </template>);
await fillIn(".ace textarea", `[{ "value": "value1" }]`);
await click("button#save");
assert.dom(".validation-error").hasText(/Syntax Error/);
}); });
test("'value' key is present for each setting", async function (assert) { test("'value' key is present for each setting", async function (assert) {
const component = glimmerComponent(this.owner, ThemeSettingsEditor, { const model = [];
model: [],
});
component.editedContent = JSON.stringify([{ setting: "setting1" }]); await render(<template>
component.save(); <ThemeSettingsEditor @model={{model}} />
assert.strictEqual(component.errors[0].setting, "Syntax Error"); </template>);
await fillIn(".ace textarea", `[{ "setting": "setting1" }]`);
await click("button#save");
assert.dom(".validation-error").hasText(/Syntax Error/);
}); });
test("only 'setting' and 'value' keys are present, no others", async function (assert) { test("only 'setting' and 'value' keys are present, no others", async function (assert) {
const component = glimmerComponent(this.owner, ThemeSettingsEditor, { const model = [];
model: [],
});
component.editedContent = JSON.stringify([{ other_key: "other-key-1" }]); await render(<template>
component.save(); <ThemeSettingsEditor @model={{model}} />
assert.strictEqual(component.errors[0].setting, "Syntax Error"); </template>);
await fillIn(".ace textarea", `[{ "other_key": "other-key-1" }]`);
await click("button#save");
assert.dom(".validation-error").hasText(/Syntax Error/);
}); });
test("no settings are deleted", async function (assert) { test("no settings are deleted", async function (assert) {
const component = glimmerComponent(this.owner, ThemeSettingsEditor, { const model = {
model: { model: {
model: { settings: [{ setting: "foo", value: "foo" }],
settings: [
{ setting: "foo", value: "foo" },
{ setting: "bar", value: "bar" },
],
}, },
}, };
});
component.editedContent = JSON.stringify([ await render(<template>
{ setting: "bar", value: "bar" }, <ThemeSettingsEditor @model={{model}} />
]); </template>);
component.save();
assert.strictEqual(component.errors[0].setting, "foo"); query(".ace").aceEditor.session.doc.setValue(
JSON.stringify([{ setting: "bar", value: "bar" }])
);
await click("button#save");
assert
.dom(".validation-error")
.hasText(
"foo: These settings were deleted. Please restore them and try again."
);
}); });
test("no settings are added", async function (assert) { test("no settings are added", async function (assert) {
const component = glimmerComponent(this.owner, ThemeSettingsEditor, { const model = {
model: {
model: { model: {
settings: [{ setting: "bar", value: "bar" }], settings: [{ setting: "bar", value: "bar" }],
}, },
}, };
});
component.editedContent = JSON.stringify([ await render(<template>
<ThemeSettingsEditor @model={{model}} />
</template>);
query(".ace").aceEditor.session.doc.setValue(
JSON.stringify([
{ setting: "foo", value: "foo" }, { setting: "foo", value: "foo" },
{ setting: "bar", value: "bar" }, { setting: "bar", value: "bar" },
]); ])
component.save(); );
await click("button#save");
assert.strictEqual(component.errors[0].setting, "foo"); assert
.dom(".validation-error")
.hasText(
"foo: These settings were added. Please remove them and try again."
);
}); });
} }
); );