File: buildtests.py

package info (click to toggle)
firefox-esr 78.15.0esr-1~deb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 3,301,156 kB
  • sloc: cpp: 5,665,905; javascript: 4,798,386; ansic: 2,878,233; python: 977,004; asm: 270,347; xml: 181,456; java: 111,756; sh: 72,926; makefile: 21,819; perl: 13,380; cs: 4,725; yacc: 4,565; objc: 3,026; pascal: 1,787; lex: 1,720; ada: 1,681; exp: 505; php: 436; lisp: 260; awk: 152; ruby: 103; csh: 80; sed: 53; sql: 45
file content (71 lines) | stat: -rw-r--r-- 2,253 bytes parent folder | download | duplicates (33)
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
#!/usr/bin/python3

import os
import urllib.parse
import hashlib

doctmpl = """\
<!doctype html>
<title>WebVTT cue data parser test %s</title>
<link rel="help" href="https://w3c.github.io/webvtt/#cue-text-parsing-rules">
<style>video { display:none }</style>
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script src=/html/syntax/parsing/template.js></script>
<script src=/html/syntax/parsing/common.js></script>
<script src=../common.js></script>
<div id=log></div>
<script>
runTests([
%s
]);
</script>
"""

testobj = "{name:'%s', input:'%s', expected:'%s'}"

def appendtest(tests, input, expected):
    tests.append(testobj % (hashlib.sha1(input.encode('UTF-8')).hexdigest(), urllib.parse.quote(input[:-1]),  urllib.parse.quote(expected[:-1])))

files = os.listdir('dat/')
for file in files:
    if os.path.isdir('dat/'+file) or file[0] == ".":
        continue

    tests = []
    input = ""
    expected = ""
    state = ""
    with open('dat/'+file, "r") as f:
        while True:
            line = f.readline()
            if not line:
                if state != "":
                    appendtest(tests, input, expected)
                    input = ""
                    expected = ""
                    state = ""
                break

            if line[0] == "#":
                state = line
                if line == "#document-fragment\n":
                    expected += bytes(line, 'UTF-8').decode('unicode-escape')
            elif state == "#data\n":
                input += bytes(line, 'UTF-8').decode('unicode-escape')
            elif state == "#errors\n":
                pass
            elif state == "#document-fragment\n":
                if line == "\n":
                    appendtest(tests, input, expected)
                    input = ""
                    expected = ""
                    state = ""
                else:
                    expected += bytes(line, 'UTF-8').decode('unicode-escape')
            else:
                raise Exception("failed to parse file %s:%s (state: %s)" % (file, line, state))

    name = os.path.splitext(file)[0]
    with open('tests/'+name+".html", "w") as out:
        out.write(doctmpl % (name, ",\n".join(tests)))