1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
<!DOCTYPE html>
<meta charset="utf-8">
<title>Range.getClientRects should correct indexing into trailing surrogates</title>
<link rel="help" href="https://drafts.csswg.org/cssom-view-1/#dom-range-getclientrects">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id="surrogates">🌠a🌠</div>
<span id="surrogate">🌠a</span><span id="surrogate2">🌠</span>
<script>
test(function () {
const surrogates = document.getElementById("surrogates");
const surrogate = document.getElementById("surrogate");
const surrogate2 = document.getElementById("surrogate2");
// test range with one container
fullrange = document.createRange();
fullrange.setStart(surrogates.firstChild, 0);
fullrange.setEnd(surrogates.firstChild, 5);
range = document.createRange();
range.setStart(surrogates.firstChild, 1);
range.setEnd(surrogates.firstChild, 5);
assert_equals(range.getClientRects()[0].width, fullrange.getClientRects()[0].width);
range.setStart(surrogates.firstChild, 0);
range.setEnd(surrogates.firstChild, 4);
assert_equals(range.getClientRects()[0].width, fullrange.getClientRects()[0].width);
range.setStart(surrogates.firstChild, 1);
range.setEnd(surrogates.firstChild, 4);
assert_equals(range.getClientRects()[0].width, fullrange.getClientRects()[0].width);
// test range with two containers
fullrange.setStart(surrogate.firstChild, 0);
fullrange.setEnd(surrogate2.firstChild, 2);
range.setStart(surrogate.firstChild, 1);
range.setEnd(surrogate2.firstChild, 2);
assert_equals(range.getClientRects()[0].width, fullrange.getClientRects()[0].width);
assert_equals(range.getClientRects()[1].width, fullrange.getClientRects()[1].width);
range.setStart(surrogate.firstChild, 0);
range.setEnd(surrogate2.firstChild, 1);
assert_equals(range.getClientRects()[0].width, fullrange.getClientRects()[0].width);
assert_equals(range.getClientRects()[1].width, fullrange.getClientRects()[1].width);
range.setStart(surrogate.firstChild, 1);
range.setEnd(surrogate2.firstChild, 1);
assert_equals(range.getClientRects()[0].width, fullrange.getClientRects()[0].width);
assert_equals(range.getClientRects()[1].width, fullrange.getClientRects()[1].width);
}, "Range.getClientRects should correct indexing into trailing surrogates")
</script>
|