-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbenchmark_oracle_test.go
More file actions
118 lines (99 loc) · 3.13 KB
/
benchmark_oracle_test.go
File metadata and controls
118 lines (99 loc) · 3.13 KB
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
package purejson
import (
"io/fs"
"os"
"path/filepath"
"strings"
"testing"
)
const minOracleCaseCount = 300
func TestJSONTestSuiteOracle(t *testing.T) {
manifest := loadOracleManifest(t)
caseFiles := loadOracleCaseFiles(t)
if len(manifest) < minOracleCaseCount {
t.Fatalf("oracle manifest rows = %d, want at least %d", len(manifest), minOracleCaseCount)
}
if len(caseFiles) < minOracleCaseCount {
t.Fatalf("oracle case files = %d, want at least %d", len(caseFiles), minOracleCaseCount)
}
manifestPaths := make(map[string]struct{}, len(manifest))
for _, oracleCase := range manifest {
if _, ok := caseFiles[oracleCase.relativePath]; !ok {
t.Fatalf("oracle manifest references missing case %q", oracleCase.relativePath)
}
manifestPaths[oracleCase.relativePath] = struct{}{}
}
for relativePath := range caseFiles {
if _, ok := manifestPaths[relativePath]; !ok {
t.Fatalf("oracle cases directory contains unlisted file %q", relativePath)
}
}
accepted := 0
rejected := 0
for _, oracleCase := range manifest {
if strings.HasPrefix(filepath.Base(oracleCase.relativePath), "i_") && strings.TrimSpace(oracleCase.note) == "" {
t.Fatalf("oracle manifest i_* case %q must document its implementation-defined expectation", oracleCase.relativePath)
}
data, err := os.ReadFile(caseFiles[oracleCase.relativePath])
if err != nil {
t.Fatalf("ReadFile(%q): %v", oracleCase.relativePath, err)
}
parser, err := NewParser()
if err != nil {
t.Fatalf("NewParser() for %q: %v", oracleCase.relativePath, err)
}
doc, parseErr := parser.Parse(data)
closeOracleResources(t, oracleCase.relativePath, doc, parser)
switch oracleCase.expect {
case oracleExpectAccept:
if parseErr != nil {
t.Fatalf("Parse(%q) error = %v, want success (%s)", oracleCase.relativePath, parseErr, oracleCase.note)
}
accepted++
case oracleExpectReject:
if parseErr == nil {
t.Fatalf("Parse(%q) unexpectedly succeeded, want reject (%s)", oracleCase.relativePath, oracleCase.note)
}
rejected++
default:
t.Fatalf("oracle manifest expect = %q for %q, want %q or %q", oracleCase.expect, oracleCase.relativePath, oracleExpectAccept, oracleExpectReject)
}
}
t.Logf("accepted=%d rejected=%d", accepted, rejected)
}
func loadOracleCaseFiles(tb testing.TB) map[string]string {
tb.Helper()
files := make(map[string]string)
err := filepath.WalkDir(oracleCasesDir, func(filePath string, entry fs.DirEntry, walkErr error) error {
if walkErr != nil {
return walkErr
}
if entry.IsDir() {
return nil
}
relativePath, err := filepath.Rel(oracleCasesDir, filePath)
if err != nil {
return err
}
manifestPath := filepath.ToSlash(relativePath)
files[manifestPath] = filePath
return nil
})
if err != nil {
tb.Fatalf("loadOracleCaseFiles: %v", err)
}
return files
}
func closeOracleResources(tb testing.TB, relativePath string, doc *Doc, parser *Parser) {
tb.Helper()
if doc != nil {
if err := doc.Close(); err != nil {
tb.Fatalf("doc.Close() for %q: %v", relativePath, err)
}
}
if parser != nil {
if err := parser.Close(); err != nil {
tb.Fatalf("parser.Close() for %q: %v", relativePath, err)
}
}
}