summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html')
-rw-r--r--testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html180
1 files changed, 180 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html b/testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html
new file mode 100644
index 0000000000..b61a829b30
--- /dev/null
+++ b/testing/web-platform/tests/css/selectors/dir-pseudo-on-input-element.html
@@ -0,0 +1,180 @@
+<!DOCTYPE html>
+<html>
+<head>
+<meta name="author" title="Ryosuke Niwa" href="mailto:rniwa@webkit.org">
+<link rel="help" href="https://html.spec.whatwg.org/multipage/dom.html#the-directionality">
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+</head>
+<body>
+<script>
+
+test(() => {
+ const input = document.createElement('input');
+ input.type = 'tel';
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'foo');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'rtl');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'RTL');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'ltr');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'LTR');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'auto');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.value = '\u05EA';
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'AUTO');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.removeAttribute('dir');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+}, 'input element whose type attribute is in the telephone state');
+
+test(() => {
+ const input = document.createElement('input');
+ input.type = 'tel';
+
+ const container = document.createElement('div');
+ container.setAttribute('dir', 'rtl');
+ container.appendChild(input);
+
+ // Insert the element into the document so that we can also check for
+ // 'direction' in computed style.
+ document.body.appendChild(container);
+
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+ // Per https://html.spec.whatwg.org/multipage/rendering.html#bidi-rendering:
+ assert_equals(getComputedStyle(input).direction, 'ltr');
+
+ // Changing to a different type causes the special type=tel rule to no longer apply.
+ input.type = 'text';
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+ assert_equals(getComputedStyle(input).direction, 'rtl');
+
+ // And restoring type=tel brings back that behavior.
+ input.type = 'tel';
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+ assert_equals(getComputedStyle(input).direction, 'ltr');
+
+ document.body.removeChild(container);
+}, 'input element whose type attribute is in the telephone state in a RTL block');
+
+for (let type of ['text', 'search', 'url', 'email']) {
+ test(() => {
+ const input = document.createElement('input');
+ input.type = type;
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'foo');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'rtl');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'RTL');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'ltr');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'LTR');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'auto');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.value = '\u05EA';
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'AUTO');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'))
+
+ input.removeAttribute('dir');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+ }, `input element whose type attribute is in the ${type} state`);
+}
+
+for (let type of ['password', 'date', 'time', 'number', 'range', 'color',
+ 'checkbox', 'radio', 'submit', 'image', 'reset', 'button']) {
+ test(() => {
+ const input = document.createElement('input');
+ input.type = type;
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'foo');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'rtl');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'RTL');
+ assert_false(input.matches(':dir(ltr)'));
+ assert_true(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'ltr');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'LTR');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'auto');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.value = '\u05EA';
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+
+ input.setAttribute('dir', 'AUTO');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'))
+
+ input.removeAttribute('dir');
+ assert_true(input.matches(':dir(ltr)'));
+ assert_false(input.matches(':dir(rtl)'));
+ }, `input element whose type attribute is in the ${type} state`);
+}
+
+</script>
+</body>
+</html>