diff options
Diffstat (limited to 'testing/web-platform/tests/css/css-pseudo/support')
-rw-r--r-- | testing/web-platform/tests/css/css-pseudo/support/100x100-red.png | bin | 0 -> 510 bytes | |||
-rw-r--r-- | testing/web-platform/tests/css/css-pseudo/support/60x60-red.png | bin | 0 -> 217 bytes | |||
-rw-r--r-- | testing/web-platform/tests/css/css-pseudo/support/highlights.css | 68 | ||||
-rw-r--r-- | testing/web-platform/tests/css/css-pseudo/support/selections.js | 72 |
4 files changed, 140 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/css-pseudo/support/100x100-red.png b/testing/web-platform/tests/css/css-pseudo/support/100x100-red.png Binary files differnew file mode 100644 index 0000000000..57bf3ddc52 --- /dev/null +++ b/testing/web-platform/tests/css/css-pseudo/support/100x100-red.png diff --git a/testing/web-platform/tests/css/css-pseudo/support/60x60-red.png b/testing/web-platform/tests/css/css-pseudo/support/60x60-red.png Binary files differnew file mode 100644 index 0000000000..823f125b8e --- /dev/null +++ b/testing/web-platform/tests/css/css-pseudo/support/60x60-red.png diff --git a/testing/web-platform/tests/css/css-pseudo/support/highlights.css b/testing/web-platform/tests/css/css-pseudo/support/highlights.css new file mode 100644 index 0000000000..3ec7e0dd31 --- /dev/null +++ b/testing/web-platform/tests/css/css-pseudo/support/highlights.css @@ -0,0 +1,68 @@ +/** + * Container for the interesting part of a highlight reftest, to be + * used on both the test page and any reference pages. + */ +.highlight_reftest { + /* + https://drafts.csswg.org/css-pseudo-4/#highlight-bounds + For text, the corresponding overlay must cover at least + the entire em box and may extend further above/below the + em box to the line box edges. + */ + line-height: 1; +} + +/** + * Container for layers. All text is transparent by default, and each direct + * child creates a layer that overlaps any text content. + */ +.hrt_layers, +.hrt_layers * { + color: transparent; +} +.hrt_layers { + position: relative; +} +.hrt_layers > * { + position: absolute; +} + +/** + * Cover to clip text from the right. Usage: + * + * <div class="hrt_layers"> + * <div><!-- content to clip to “foo” from right --></div> + * <div><span class="hrt_cover">bar</span>foobar</div> + * foobar + * </div> + */ +.hrt_cover { + background: white; + position: absolute; + padding: 0.5em 0; + top: -0.5em; + right: 0; +} + +/** + * Hider to clip text from the left. Usage: + * + * <div class="hrt_layers"> + * <div>foo<span class="hrt_hider"> + * <div><!-- content to clip to “bar” from left --></div> + * bar + * </span></div> + * foobar + * </div> + */ +.hrt_hider { + display: inline-block; + overflow: hidden; + position: relative; + padding: 0.5em 0; + top: -0.5em; +} +.hrt_hider > * { + position: absolute; + right: 0; +} diff --git a/testing/web-platform/tests/css/css-pseudo/support/selections.js b/testing/web-platform/tests/css/css-pseudo/support/selections.js new file mode 100644 index 0000000000..d0cd3409a7 --- /dev/null +++ b/testing/web-platform/tests/css/css-pseudo/support/selections.js @@ -0,0 +1,72 @@ +/** + * Replaces the current selection (if any) with a new range, after + * it’s configured by the given function. + * + * See also: selectNodeContents + * Example: + * + * selectRangeWith(range => { + * range.selectNodeContents(foo); + * range.setStart(foo.childNodes[0], 3); + * range.setEnd(foo.childNodes[0], 5); + * }); + */ +function selectRangeWith(fun) { + const selection = getSelection(); + + // Deselect any ranges that happen to be selected, to prevent the + // Selection#addRange call from ignoring our new range (see + // <https://www.chromestatus.com/feature/6680566019653632> for + // more details). + selection.removeAllRanges(); + + // Create and configure a range. + const range = document.createRange(); + fun(range); + + // Select our new range. + selection.addRange(range); +} + +/** + * Replaces the current selection (if any) with a new range, spanning + * the contents of the given node. + */ +function selectNodeContents(node) { + const previousActive = document.activeElement; + + selectRangeWith(range => range.selectNodeContents(node)); + + // If the selection update causes the node or an ancestor to be + // focused (Chromium 80+), unfocus it, to avoid any focus-related + // styling such as outlines. + if (document.activeElement != previousActive) { + document.activeElement.blur(); + } +} + +/** + * Tries to convince a UA with lazy spellcheck to check and highlight + * the contents of the given nodes (form fields or @contenteditables). + * + * Each node is focused then immediately unfocused. Both focus and + * selection can be used for this purpose, but only focus works for + * @contenteditables. + */ +function trySpellcheck(...nodes) { + // This is inherently a flaky test risk, but Chromium (as of 87) + // seems to cancel spellcheck on a node if it wasn’t the last one + // focused for “long enough” (though immediate unfocus is ok). + // Using requestAnimationFrame or setInterval(0) are usually not + // long enough (see <https://bucket.daz.cat/work/igalia/0/0.html> + // under “trySpellcheck strategy” for an example). + const interval = setInterval(() => { + if (nodes.length > 0) { + const node = nodes.shift(); + node.focus(); + node.blur(); + } else { + clearInterval(interval); + } + }, 250); +} |