Files
Joffrey JAFFEUX c9425c93cc FIX: ensures empty fields don't store an empty array (#33274)
This is a follow-up to
299d28cb73
to apply it to more fields.
2025-06-19 20:46:48 +02:00

66 lines
1.8 KiB
Plaintext

import { getOwner } from "@ember/owner";
import { render } from "@ember/test-helpers";
import { module, test } from "qunit";
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
import selectKit from "discourse/tests/helpers/select-kit-helper";
import AutomationField from "discourse/plugins/automation/admin/components/automation-field";
import AutomationFabricators from "discourse/plugins/automation/admin/lib/fabricators";
module("Integration | Component | da-choices-field", function (hooks) {
setupRenderingTest(hooks);
hooks.beforeEach(function () {
this.automation = new AutomationFabricators(getOwner(this)).automation();
});
test("set value", async function (assert) {
const self = this;
this.field = new AutomationFabricators(getOwner(this)).field({
component: "choices",
extra: { content: [{ name: "One", id: 1 }] },
});
await render(
<template>
<AutomationField
@automation={{self.automation}}
@field={{self.field}}
/>
</template>
);
await selectKit().expand();
await selectKit().selectRowByValue(1);
assert.strictEqual(this.field.metadata.value, 1);
});
test("empty multiselect", async function (assert) {
const self = this;
this.field = new AutomationFabricators(getOwner(this)).field({
component: "choices",
extra: { multiselect: true, content: [{ name: "One", id: 1 }] },
});
await render(
<template>
<AutomationField
@automation={{self.automation}}
@field={{self.field}}
/>
</template>
);
await selectKit().expand();
await selectKit().selectRowByValue(1);
assert.deepEqual(this.field.metadata.value, [1]);
await selectKit().deselectItemByValue(1);
assert.strictEqual(this.field.metadata.value, undefined);
});
});