DEV: Update theme-settings-editor tests (#28582)
Convert them to proper integration tests.
This commit is contained in:
parent
ee3b175373
commit
7317b5a120
|
@ -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();
|
||||||
|
|
||||||
|
|
|
@ -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."
|
||||||
|
);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue