summaryrefslogtreecommitdiffstats
path: root/widget/tests/test_ime_state_in_contenteditable_on_readonly_change_in_parent.html
diff options
context:
space:
mode:
Diffstat (limited to 'widget/tests/test_ime_state_in_contenteditable_on_readonly_change_in_parent.html')
-rw-r--r--widget/tests/test_ime_state_in_contenteditable_on_readonly_change_in_parent.html72
1 files changed, 72 insertions, 0 deletions
diff --git a/widget/tests/test_ime_state_in_contenteditable_on_readonly_change_in_parent.html b/widget/tests/test_ime_state_in_contenteditable_on_readonly_change_in_parent.html
new file mode 100644
index 0000000000..8d8662a8d8
--- /dev/null
+++ b/widget/tests/test_ime_state_in_contenteditable_on_readonly_change_in_parent.html
@@ -0,0 +1,72 @@
+<html>
+<head>
+ <title>Test for IME state of contenteditable on readonly state change</title>
+ <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
+ <script src="file_ime_state_test_helper.js"></script>
+ <script src="file_test_ime_state_in_contenteditable_on_readonly_change.js"></script>
+ <link rel="stylesheet" href="chrome://mochikit/content/tests/SimpleTest/test.css">
+<script>
+"use strict";
+
+/* import-globals-from file_ime_state_test_helper.js */
+/* import-globals-from file_test_ime_state_in_contenteditable_on_readonly_change.js */
+
+SimpleTest.waitForExplicitFinish();
+SimpleTest.waitForFocus(async () => {
+ const tipWrapper = new TIPWrapper(window);
+ const editingHost = document.querySelector("div[contenteditable]");
+ await (async function test_ime_state_in_contenteditable_on_readonly_change() {
+ const tester = new IMEStateInContentEditableOnReadonlyChangeTester();
+ tester.checkResultOfPreparation(await tester.prepareToRun(editingHost, editingHost), window, tipWrapper);
+ tester.checkResultOfMakingHTMLEditorReadonly(await tester.runToMakeHTMLEditorReadonly());
+ tester.checkResultOfMakingHTMLEditorEditable(await tester.runToMakeHTMLEditorEditable());
+ tester.checkResultOfRemovingContentEditableAttribute(await tester.runToRemoveContentEditableAttribute());
+ tester.clear();
+ })();
+
+ await (async function test_ime_state_in_button_in_contenteditable_on_readonly_change() {
+ const tester = new IMEStateInContentEditableOnReadonlyChangeTester();
+ const button = editingHost.querySelector("button");
+ tester.checkResultOfPreparation(await tester.prepareToRun(editingHost, button), window, tipWrapper);
+ tester.checkResultOfMakingHTMLEditorReadonly(await tester.runToMakeHTMLEditorReadonly());
+ tester.checkResultOfMakingHTMLEditorEditable(await tester.runToMakeHTMLEditorEditable());
+ tester.checkResultOfRemovingContentEditableAttribute(await tester.runToRemoveContentEditableAttribute());
+ tester.clear();
+ })();
+
+ await (async function test_ime_state_of_text_controls_in_contenteditable_on_readonly_change() {
+ const tester = new IMEStateOfTextControlInContentEditableOnReadonlyChangeTester();
+ for (let index = 0;
+ index < IMEStateOfTextControlInContentEditableOnReadonlyChangeTester.numberOfTextControlTypes;
+ index++) {
+ tester.checkResultOfPreparation(await tester.prepareToRun(index, editingHost), window, tipWrapper);
+ tester.checkResultOfMakingParentEditingHost(await tester.runToMakeParentEditingHost());
+ tester.checkResultOfMakingHTMLEditorReadonly(await tester.runToMakeHTMLEditorReadonly());
+ tester.checkResultOfMakingHTMLEditorEditable(await tester.runToMakeHTMLEditorEditable());
+ tester.checkResultOfMakingParentNonEditable(await tester.runToMakeParentNonEditingHost());
+ tester.clear();
+ }
+ editingHost.setAttribute("contenteditable", "");
+ })();
+
+ await (async function test_ime_state_outside_contenteditable_on_readonly_change() {
+ const tester = new IMEStateOutsideContentEditableOnReadonlyChangeTester();
+ for (let index = 0;
+ index < IMEStateOutsideContentEditableOnReadonlyChangeTester.numberOfFocusTargets;
+ index++) {
+ tester.checkResultOfPreparation(await tester.prepareToRun(index, editingHost), window, tipWrapper);
+ tester.checkResultOfMakingParentEditingHost(await tester.runToMakeParentEditingHost());
+ tester.checkResultOfMakingHTMLEditorReadonly(await tester.runToMakeHTMLEditorReadonly());
+ tester.checkResultOfMakingHTMLEditorEditable(await tester.runToMakeHTMLEditorEditable());
+ tester.checkResultOfMakingParentNonEditable(await tester.runToMakeParentNonEditingHost());
+ tester.clear();
+ }
+ editingHost.setAttribute("contenteditable", "");
+ })();
+
+ SimpleTest.finish();
+});
+</script>
+</head>
+<body><div contenteditable><br><button>button</button></div></body>
+</html>