From 832fc6e22e9b195c70c7f97c4bdac92281133c9b Mon Sep 17 00:00:00 2001 From: Sean Doyle Date: Tue, 15 Oct 2024 11:12:22 -0400 Subject: [PATCH] Fix CI: `.validationMessage` assertion Resolve a [CI failure][] related to a hard-coded English validation message expectation failing due to an internationalized actual validation message value. [CI failure]: https://github.com/basecamp/trix/actions/runs/11317691021/job/31471435810#step:5:75 --- src/test/system/custom_element_test.js | 5 +++-- src/trix/elements/trix_editor_element.js | 2 +- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/test/system/custom_element_test.js b/src/test/system/custom_element_test.js index 3a14bb90e..e28d2f86d 100644 --- a/src/test/system/custom_element_test.js +++ b/src/test/system/custom_element_test.js @@ -1,4 +1,4 @@ -import { rangesAreEqual } from "trix/core/helpers" +import { makeElement, rangesAreEqual } from "trix/core/helpers" import TrixEditorElement from "trix/elements/trix_editor_element" import { @@ -635,6 +635,7 @@ testGroup("form property references its
", { template: "editors_with_forms testIf(TrixEditorElement.formAssociated, "validates with [required] attribute as invalid", () => { const editor = document.getElementById("editor-with-ancestor-form") const form = editor.form + const invalidInput = makeElement("input", { required: true }) let invalidEvent, submitEvent = null editor.addEventListener("invalid", event => invalidEvent = event, { once: true }) @@ -646,7 +647,7 @@ testGroup("form property references its ", { template: "editors_with_forms // assert.equal(document.activeElement, editor, "editor receives focus") assert.equal(editor.required, true, ".required property retrurns true") assert.equal(editor.validity.valid, false, "validity.valid is false") - assert.equal(editor.validationMessage, "Please fill out this field.", "sets .validationMessage") + assert.equal(editor.validationMessage, invalidInput.validationMessage, "sets .validationMessage") assert.equal(invalidEvent.target, editor, "dispatches 'invalid' event on editor") assert.equal(submitEvent, null, "does not dispatch a 'submit' event") }) diff --git a/src/trix/elements/trix_editor_element.js b/src/trix/elements/trix_editor_element.js index 7837f61b5..846c8dc61 100644 --- a/src/trix/elements/trix_editor_element.js +++ b/src/trix/elements/trix_editor_element.js @@ -228,7 +228,7 @@ class ElementInternalsDelegate { const { required, value } = this.element const valueMissing = required && !value const customError = !!customValidationMessage - const input = Object.assign(document.createElement("input"), { required }) + const input = makeElement("input", { required }) const validationMessage = customValidationMessage || input.validationMessage this.#internals.setValidity({ valueMissing, customError }, validationMessage)