summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/svg/text/scripted/getstartpositionofchar-dominant-baseline.html
blob: 7ecfd7848a738a3083e6b0295fa9be0164d01fdd (plain)
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
<meta charset="utf-8">
<title>SVGTextContentElement.getStartPositionOfChar and dominant-baseline</title>
<link rel="help" href="https://svgwg.org/svg2-draft/text.html#__svg__SVGTextContentElement__getStartPositionOfChar">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>

<style>
text {
  font-family: Arial;
  font-size: 60px;
  fill: #ffff00;
}
</style>
<svg>
  <defs>
    <path id="path" d="M20 80h120"></path>
  </defs>
  <g>
    <text>
      <textPath id="textPath1" href="#path">Test</textPath>
      <tspan id="tspan1" x="0" y="100">Test</tspan>
    </text>
  </g>
  <g transform="translate(140 0)">
    <text dominant-baseline="middle">
      <textPath id="textPath2" href="#path">Test</textPath>
      <tspan id="tspan2" x="0" y="100">Test</tspan>
    </text>
  </g>
</svg>

<script>
function $(sel) { return document.querySelector(sel); }

test(() => {
  assert_equals($('#textPath1').getStartPositionOfChar(0).y,
                $('#textPath2').getStartPositionOfChar(0).y);
  assert_equals($('#textPath1').getEndPositionOfChar(0).y,
                $('#textPath2').getEndPositionOfChar(0).y);
}, 'textPath: get*PositionOfChar().y should not depend on dominant-baseline');

test(() => {
  assert_equals($('#tspan1').getStartPositionOfChar(0).y,
                $('#tspan2').getStartPositionOfChar(0).y);
  assert_equals($('#tspan1').getEndPositionOfChar(0).y,
                $('#tspan2').getEndPositionOfChar(0).y);
}, 'tspan: get*PositionOfChar().y should not depend on dominant-baseline');
</script>