summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/conformance-checkers/html-svg/types-dom-05-b-isvalid.html
blob: 22a540f71b80178fc60bf33aa5f8bcf0942164e1 (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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<!DOCTYPE html>
<html lang='en'>
<head>
 <title>types-dom-05-b-manual.svg</title>
 <meta charset='utf-8'>
</head>
<body>
 <h1>Source SVG: types-dom-05-b-manual.svg</h1>
<svg id="svg-root" width="100%" height="100%"
  viewBox="0 0 480 360" xmlns="http://www.w3.org/2000/svg"
  xmlns:xlink="http://www.w3.org/1999/xlink">
  <!--======================================================================-->
  <!--=  Copyright 2008 World Wide Web Consortium, (Massachusetts          =-->
  <!--=  Institute of Technology, European Research Consortium for         =-->
  <!--=  Informatics and Mathematics (ERCIM), Keio University).            =-->
  <!--=  All Rights Reserved.                                              =-->
  <!--=  See http://www.w3.org/Consortium/Legal/.                          =-->
  <!--======================================================================-->
  
  <title id="test-title">$RCSfile: types-dom-05-b.svg,v $</title>
  <defs>
    <font-face
      font-family="SVGFreeSansASCII"
      unicode-range="U+0-7F">
      <font-face-src>
        <font-face-uri xlink:href="../resources/SVGFreeSans.svg#ascii"/>
      </font-face-src>
    </font-face>
  </defs>
  <g id="test-body-content" font-family="SVGFreeSansASCII,sans-serif" font-size="18">

    <text x='10' y='30'>Test side effects of assigning to valueAsString</text>

    <rect id='r1' x='10' y='40' width='30' height='30'/>
    <rect id='r2' x='10' y='80' width='30' height='30'/>
    <rect id='r3' x='10' y='120' width='30' height='30'/>
    <rect id='r4' x='10' y='160' width='30' height='30'/>
    <g font-size='15'>
      <text x='50' y='60'>Valid string on SVGLength</text>
      <text x='50' y='100'>Invalid string on SVGLength</text>
      <text x='50' y='140'>Valid string on SVGAngle</text>
      <text x='50' y='180'>Invalid string on SVGAngle</text>
    </g>

    <circle id='c' r='1em' display='none'/>
    <marker id='m' orient='20rad' display='none'/>
    <script>
      var b,
          c = document.getElementById('c');
          m = document.getElementById('m');
      
      b = false;
      try {
        if (c.r.baseVal.unitType != 3) { /* SVGLength.SVG_LENGTHTYPE_EMS */
          throw 1;
        }
        c.r.baseVal.valueAsString = '2px';
        if (c.r.baseVal.unitType == 5) { /* SVGLength.SVG_LENGTHTYPE_PX */
          b = true;
        }
      } catch (e) {
      }
      document.getElementById('r1').setAttribute('fill', b ? 'green' : 'red');

      b = false;
      try {
        c.r.baseVal.valueAsString = 'rubbish';
      } catch (e) {
        b = e.code == 12; // SYNTAX_ERR
      }
      document.getElementById('r2').setAttribute('fill', b ? 'green' : 'red');

      b = false;
      try {
        if (m.orientAngle.baseVal.unitType != 3) { /* SVGAngle.SVG_ANGLETYPE_RAD */
          throw 1;
        }
        m.orientAngle.baseVal.valueAsString = '2grad';
        if (m.orientAngle.baseVal.unitType == 4) { /* SVGAngle.SVG_ANGLETYPE_GRAD */
          b = true;
        }
      } catch (e) {
      }
      document.getElementById('r3').setAttribute('fill', b ? 'green' : 'red');

      b = false;
      try {
        m.orientAngle.baseVal.valueAsString = 'rubbish';
      } catch (e) {
        b = e.code == 12; // SYNTAX_ERR
      }
      document.getElementById('r4').setAttribute('fill', b ? 'green' : 'red');
    </script>

  </g>
  <g font-family="SVGFreeSansASCII,sans-serif" font-size="32">
    <text id="revision" x="10" y="340" stroke="none"
      fill="black">$Revision: 1.6 $</text>
  </g>
  <rect id="test-frame" x="1" y="1" width="478" height="358" fill="none" stroke="#000"/>
  <!-- comment out this watermark once the test is approved --><!--
  <g id="draft-watermark">
    <rect x="1" y="1" width="478" height="20" fill="red" stroke="black" stroke-width="1"/>
    <text font-family="SVGFreeSansASCII,sans-serif" font-weight="bold" font-size="20" x="240"
      text-anchor="middle" y="18" stroke-width="0.5" stroke="black" fill="white">DRAFT</text>
  </g>-->
</svg>
</body>
</html>