discourse/plugins/automation/test/javascripts/integration/components/da-message-field-test.js
Joffrey JAFFEUX dc1afeac89
FIX: ensures message field is rendering placeholders (#28753)
A previous commit had broken this codepath, this commit ensures it's fixed and is adding a test. It's not testing the copy/paste behavior as fairly complex to test.
2024-09-05 11:18:21 +02:00

41 lines
1.3 KiB
JavaScript

import { getOwner } from "@ember/owner";
import { fillIn, render } from "@ember/test-helpers";
import { hbs } from "ember-cli-htmlbars";
import { module, test } from "qunit";
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
import AutomationFabricators from "discourse/plugins/automation/admin/lib/fabricators";
module("Integration | Component | da-message-field", function (hooks) {
setupRenderingTest(hooks);
hooks.beforeEach(function () {
this.automation = new AutomationFabricators(getOwner(this)).automation();
});
test("set value", async function (assert) {
this.field = new AutomationFabricators(getOwner(this)).field({
component: "message",
});
await render(
hbs`<AutomationField @automation={{this.automation}} @field={{this.field}} />`
);
await fillIn("textarea", "Hello World");
assert.strictEqual(this.field.metadata.value, "Hello World");
});
test("render placeholders", async function (assert) {
this.field = new AutomationFabricators(getOwner(this)).field({
component: "message",
});
this.automation.placeholders = ["foo", "bar"];
await render(
hbs`<AutomationField @automation={{this.automation}} @field={{this.field}} />`
);
assert.dom(".placeholders-list").hasText("foo bar");
});
});