summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/svg/import/animate-elem-62-t-manual.svg
blob: 43590af4db18d6b7cb7c783270a0c5d7bede9a33 (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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
<svg version="1.1" baseProfile="tiny" 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">
  <!--======================================================================-->
  <!--=  SVG 1.1 2nd Edition Test Case                                     =-->
  <!--======================================================================-->
  <!--=  Copyright 2009 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/.                          =-->
  <!--======================================================================-->
  <d:SVGTestCase xmlns:d="http://www.w3.org/2000/02/svg/testsuite/description/"
    template-version="1.4" reviewer="CN" author="VH" status="accepted"
    version="$Revision: 1.6 $" testname="$RCSfile: animate-elem-62-t.svg,v $">
    <d:testDescription xmlns="http://www.w3.org/1999/xhtml" href="http://www.w3.org/TR/SVG11/animate.html#Animation">
      <p>
        This test performs basic test on the end attribute,
        assuming support for the &lt;set&gt; element and setting the
        fill attribute on a &lt;rect&gt; element.
      </p>
      <p>
        The test validates the various possibilities for the end attribute
        value: no specified value, offset value, event base value, sync base
        value, indefinite value, repeat value, accessKey value and wallclock.
      </p>
      <p>
        There are one or several &lt;set&gt; elements for each of the possible end
        values. For each test, the &lt;set&gt; element(s) has (or have) an indefinite
        duration and no other timing attribute specified other than end
        and dur.
      </p>
      <p>
        There are two sets of vertical markers which help check that the test
        is handled properly by the user agent. The first set, on the left, shows
        markers from 0s to 8s, where the times are offset from the document's load time.
        The rectangles in that area should turn green at the time corresponding
        to the column they are in. From example, the first rectangle (going left to right)
        on the "sync base" line should turn green 2 seconds after the document's load.
        The second set of time vertical markers shows offset from a particular event.
        For example, for the event base, the markers show an offset to the time
        the first event base rectangle (the left-most one) is clicked on. For the
        accessKey line, the times show offsets from the time the 'a' key is pressed
        and the document has focus.
      </p>
      <p>
        The first &lt;set&gt; has no end attribute and an indefinite duration.
        Since there are no constraints on the active duration (no end attribute) the
        active duration is the same as the simple duration (indefinite). This
        means that the animation begins at 0s and has an indefinite end time.
      </p>
      <p>
        The second &lt;set&gt; has its end attribute set to '2s'. So its
        target rectangle should turn green two seconds after the document is
        loaded.
      </p>
      <p>
        The third &lt;set&gt; has its end attribute set to an event base
        value 'click'. The user has to click on the left-most target red rectangle
        to make the &lt;set&gt; target turn green. There are two rectangles
        with associated &lt;set&gt; elements. The left most ones has a simple
        value (no offset) and the second one is offset from the event time by 2 seconds.
      </p>
      <p>
        The fourth &lt;set&gt; elements have their end attributes set to a sync base
        value. The first two rectangles have &lt;set&gt; elements synchronized on their sync base
        end. The left-most one has no offset and the following one has a 2 seconds offset.
        The last two rectangles have &lt;set&gt; elements synchronized on their sync base end.
        The first one (i.e., the third from left to right on that line), has a 2 seconds
        negative offset. The second one (i.e., the last one on the line) has no offset and should
        end at the time its sync base ends.
      </p>
      <p>
        The fifth &lt;set&gt; has its end attribute set to indefinite and
        should not turn red and stay green.
      </p>
      <p>
        The sixth &lt;set&gt;s have their end attributes have their end attributes
        based on the repeat() function. The repeat they are synchronized on happens
        at 3s. The first &lt;set&gt;, which has no offset, should end at 3s. The
        second &lt;set&gt;, which has a 2 seconds offset, should start at 5s.
      </p>
      <p>
        The seventh &lt;set&gt;s have their end attributes set to 'accessKey(a)'.
        The first one has no offset and should become active (and turn the rectangle
        green), as soon as the key 'a' is pressed in the user agent. The second &lt;set&gt;
        has a 2s offset and should become active 2 seconds after the 'a' key is pressed in
        the user agent.
      </p>
      <p>
        The eight's &lt;set&gt; target has its end attribute set to
        'wallclock()'. The result depends on the presentation time.
        If the document is viewed completely before 2200-06-10T12:34:56Z,
        the rectangle has to be always green. begin is not explicitely set, therefore
        it is zero, dur is indefinite and end is in the future.
        If the document is viewed completely after 2200-06-10T12:34:56Z, the only end
        value is before the implicitely given only begin value and therefore the set
        does not start, the rectangle remains red. If the document is viewed in a time interval started before
        2200-06-10T12:34:56Z and ended after this date, the rectangle will start green at the beginning, change to red at
        2200-06-10T12:34:56Z and will remain red until the end of presentation.
      </p>
    </d:testDescription>
    <d:operatorScript xmlns="http://www.w3.org/1999/xhtml">
      <p>Run the test.  Observe the document for at least eight seconds.
      Then, click on the first red square in the "event base" row,
      and observe the document for two seconds.  Then, press "a"
      on the keyboard, and observe the document for another two seconds.</p>
    </d:operatorScript>
    <d:passCriteria xmlns="http://www.w3.org/1999/xhtml">
      <p>The test passes if the following conditions are met:</p>
      <ul>
        <li>In the first eight seconds of the document, the 10 squares
        in the left section of the test must become green at the time
        at the top of the column they are in.  For example, the square in
        the "offset" row must become green at 2s after the document has
        been loaded.</li>
        <li>Immediately once the red square in the "event base" row has been clicked,
        it must become green.  Two seconds after the click, the second square
        must become green.</li>
        <li>Immediately once "a" has been pressed on the keyboard,
        the first square in the "accessKey()" row must become green.
        Two seconds after the keypress, the second square must become green.</li>
        <li>No other changes occur in the document.</li>
      </ul>
    </d:passCriteria>
  </d:SVGTestCase>
  <title id="test-title">$RCSfile: animate-elem-62-t.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 text-anchor="middle" x="240" y="30" font-size="20">end</text>
    <g transform="translate(100, 80)">
      <g transform="translate(80,5)" text-anchor="end" font-size="14">
        <text>unspecified</text>
        <text y="25">offset</text>
        <text y="50">event base</text>
        <text y="75">sync base</text>
        <text y="100">indefinite</text>
        <text y="125">repeat()</text>
        <text y="150">accessKey()</text>
        <text y="175">wallclock()</text>
      </g>
      
      <g id="timeMarkersText" transform="translate(100, -15)" text-anchor="middle" font-size="8">
        <text>0s</text>
        <text x="12">1s</text>
        <text x="24">2s</text>
        <text x="36">3s</text>
        <text x="48">4s</text>
        <text x="60">5s</text>
        <text x="72">6s</text>
        <text x="84">7s</text>
        <text x="96">8s</text>
        <text x="120">0s</text>
        <text x="132">1s</text>
        <text x="144">2s</text>
      </g>

      <g id="timeMarkers" transform="translate(94, -10) scale(1, 8)">
        <rect width="12" height="25" fill="#eee"/>
        <rect x="12" width="12" height="25" fill="#ddd"/>
        <rect x="24" width="12" height="25" fill="#eee"/>
        <rect x="36" width="12" height="25" fill="#ddd"/>
        <rect x="48" width="12" height="25" fill="#eee"/>
        <rect x="60" width="12" height="25" fill="#ddd"/>
        <rect x="72" width="12" height="25" fill="#eee"/>
        <rect x="84" width="12" height="25" fill="#ddd"/>
        <rect x="96" width="12" height="25" fill="#eee"/>
        <rect x="120" width="12" height="25" fill="#eee"/>
        <rect x="132" width="12" height="25" fill="#ddd"/>
        <rect x="144" width="12" height="25" fill="#eee"/>
      </g>

      <g transform="translate(100,0)">
        <g id="setOne">
          <rect x="-6" y="-6" width="12" height="12" fill="#F33">
            <set attributeName="fill" to="#3F3" begin="0s" dur="indefinite"/>
          </rect>
        </g>

        <g id="setTwo" transform="translate(0, 25)">
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(24,0)">
            <set id="secondSet" attributeName="fill" to="#F33" begin="0s" end="2s" dur="indefinite"/>
          </rect>
        </g>

        <g id="setThree" transform="translate(0, 50)">
          <rect id="setThreeTarget" x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(120,0)">
            <set attributeName="fill" id="thirdSet" to="#F33" end="setThreeTarget.click" dur="indefinite"/>
          </rect>
          <rect x="-6" y="-6" width="12" height="12" fill="#F33" transform="translate(144,0)">
            <set attributeName="fill" id="thirdSetOffset" to="#3F3" begin="setThreeTarget.click + 2s" dur="indefinite"/>
          </rect>
        </g>

        <g id="setFour" transform="translate(0, 75)">
          <set id="endBase" attributeName="display" to="inline" begin="7s" dur="1s"/>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(24,0)">
            <set attributeName="fill" to="#F33" end="secondSet.begin + 2s" dur="indefinite"/>
          </rect>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(48,0)">
            <set attributeName="fill" to="#F33" end="secondSet.begin + 4s" dur="indefinite"/>
          </rect>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(72,0)">
            <set attributeName="fill" to="#F33" end="endBase.end - 2s" dur="indefinite"/>
          </rect>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(96,0)">
            <set attributeName="fill" to="#F33" end="endBase.end" dur="indefinite"/>
          </rect>
        </g>

        <g id="setFive" transform="translate(0, 100)">
          <rect x="-6" y="-6" width="12" height="12" fill="#F33">
            <set attributeName="fill" to="#3F3" end="indefinite" dur="indefinite"/>
          </rect>
        </g>

        <g id="setSix" transform="translate(0, 125)">
          <set id="repeatingSet" attributeName="display" to="inline" begin="0s" dur="1s" repeatCount="4"/>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(36,0)">
            <set attributeName="fill" to="#F33" end="repeatingSet.repeat(3)" dur="indefinite"/>
          </rect>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(60,0)">
            <set attributeName="fill" to="#F33" end="repeatingSet.repeat(3) + 2s" dur="indefinite"/>
          </rect>
        </g>

        <g id="setSeven" transform="translate(0, 150)">
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(120,0)">
            <set attributeName="fill" to="#F33" end="accessKey(a)" dur="indefinite"/>
          </rect>
          <rect x="-6" y="-6" width="12" height="12" fill="#3F3" transform="translate(144,0)">
            <set attributeName="fill" to="#F33" end="accessKey(a) + 2s" dur="indefinite"/>
          </rect>
        </g>

        <g id="setEight" transform="translate(0, 175)">
          <rect x="-6" y="-6" width="12" height="12" fill="#F33">
            <set attributeName="fill" to="#3F3" end="wallclock(2200-06-10T12:34:56Z)" dur="indefinite"/>
          </rect>
        </g>
      </g>
    </g>
  </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>