]>
Commit | Line | Data |
---|---|---|
3afe7ab0 | 1 | test_env = environment() |
654d6b04 | 2 | test_env.set('PYTHONPATH', meson.project_source_root() / 'scripts') |
3afe7ab0 PB |
3 | test_env.set('PYTHONIOENCODING', 'utf-8') |
4 | ||
5 | schemas = [ | |
6 | 'alternate-any.json', | |
7 | 'alternate-array.json', | |
8 | 'alternate-base.json', | |
9 | 'alternate-branch-if-invalid.json', | |
10 | 'alternate-clash.json', | |
11 | 'alternate-conflict-dict.json', | |
12 | 'alternate-conflict-enum-bool.json', | |
13 | 'alternate-conflict-enum-int.json', | |
b36dc5c2 | 14 | 'alternate-conflict-lists.json', |
3afe7ab0 PB |
15 | 'alternate-conflict-string.json', |
16 | 'alternate-conflict-bool-string.json', | |
17 | 'alternate-conflict-num-string.json', | |
4918bb7d | 18 | 'alternate-data-invalid.json', |
3afe7ab0 PB |
19 | 'alternate-empty.json', |
20 | 'alternate-invalid-dict.json', | |
21 | 'alternate-nested.json', | |
22 | 'alternate-unknown.json', | |
23 | 'args-alternate.json', | |
24 | 'args-any.json', | |
25 | 'args-array-empty.json', | |
26 | 'args-array-unknown.json', | |
27 | 'args-bad-boxed.json', | |
28 | 'args-boxed-anon.json', | |
29 | 'args-boxed-string.json', | |
30 | 'args-int.json', | |
31 | 'args-invalid.json', | |
32 | 'args-member-array-bad.json', | |
33 | 'args-member-case.json', | |
34 | 'args-member-unknown.json', | |
3afe7ab0 PB |
35 | 'args-union.json', |
36 | 'args-unknown.json', | |
37 | 'bad-base.json', | |
38 | 'bad-data.json', | |
39 | 'bad-ident.json', | |
40 | 'bad-if.json', | |
5d83b9a1 | 41 | 'bad-if-all.json', |
3afe7ab0 PB |
42 | 'bad-if-empty.json', |
43 | 'bad-if-empty-list.json', | |
5d83b9a1 MAL |
44 | 'bad-if-key.json', |
45 | 'bad-if-keys.json', | |
3afe7ab0 | 46 | 'bad-if-list.json', |
71f03ef9 | 47 | 'bad-if-not.json', |
3afe7ab0 PB |
48 | 'bad-type-bool.json', |
49 | 'bad-type-dict.json', | |
50 | 'bad-type-int.json', | |
51 | 'base-cycle-direct.json', | |
52 | 'base-cycle-indirect.json', | |
53 | 'command-int.json', | |
54 | 'comments.json', | |
55 | 'doc-bad-alternate-member.json', | |
56 | 'doc-bad-boxed-command-arg.json', | |
57 | 'doc-bad-command-arg.json', | |
58 | 'doc-bad-enum-member.json', | |
59 | 'doc-bad-event-arg.json', | |
60 | 'doc-bad-feature.json', | |
a69a6d4b | 61 | 'doc-bad-indent.json', |
3afe7ab0 PB |
62 | 'doc-bad-section.json', |
63 | 'doc-bad-symbol.json', | |
64 | 'doc-bad-union-member.json', | |
65 | 'doc-before-include.json', | |
66 | 'doc-before-pragma.json', | |
67 | 'doc-duplicated-arg.json', | |
68 | 'doc-duplicated-return.json', | |
69 | 'doc-duplicated-since.json', | |
70 | 'doc-empty-arg.json', | |
71 | 'doc-empty-section.json', | |
72 | 'doc-empty-symbol.json', | |
73 | 'doc-good.json', | |
74 | 'doc-interleaved-section.json', | |
75 | 'doc-invalid-end.json', | |
76 | 'doc-invalid-end2.json', | |
77 | 'doc-invalid-return.json', | |
78 | 'doc-invalid-section.json', | |
79 | 'doc-invalid-start.json', | |
80 | 'doc-missing-colon.json', | |
81 | 'doc-missing-expr.json', | |
82 | 'doc-missing-space.json', | |
83 | 'doc-missing.json', | |
84 | 'doc-no-symbol.json', | |
85 | 'doc-undoc-feature.json', | |
86 | 'double-type.json', | |
87 | 'duplicate-key.json', | |
88 | 'empty.json', | |
89 | 'enum-bad-member.json', | |
90 | 'enum-bad-name.json', | |
91 | 'enum-bad-prefix.json', | |
92 | 'enum-clash-member.json', | |
93 | 'enum-dict-member-unknown.json', | |
94 | 'enum-if-invalid.json', | |
95 | 'enum-int-member.json', | |
96 | 'enum-member-case.json', | |
97 | 'enum-missing-data.json', | |
98 | 'enum-wrong-data.json', | |
99 | 'event-boxed-empty.json', | |
100 | 'event-case.json', | |
101 | 'event-member-invalid-dict.json', | |
102 | 'event-nest-struct.json', | |
103 | 'features-bad-type.json', | |
104 | 'features-deprecated-type.json', | |
105 | 'features-duplicate-name.json', | |
106 | 'features-if-invalid.json', | |
107 | 'features-missing-name.json', | |
108 | 'features-name-bad-type.json', | |
109 | 'features-no-list.json', | |
110 | 'features-unknown-key.json', | |
3afe7ab0 PB |
111 | 'funny-char.json', |
112 | 'funny-word.json', | |
113 | 'ident-with-escape.json', | |
114 | 'include-before-err.json', | |
115 | 'include-cycle.json', | |
116 | 'include-extra-junk.json', | |
117 | 'include-nested-err.json', | |
118 | 'include-no-file.json', | |
119 | 'include-non-file.json', | |
120 | 'include-repetition.json', | |
121 | 'include-self-cycle.json', | |
122 | 'include-simple.json', | |
123 | 'indented-expr.json', | |
124 | 'leading-comma-list.json', | |
125 | 'leading-comma-object.json', | |
c256263f | 126 | 'missing-array-rsqb.json', |
3afe7ab0 PB |
127 | 'missing-colon.json', |
128 | 'missing-comma-list.json', | |
129 | 'missing-comma-object.json', | |
c256263f | 130 | 'missing-object-member-element.json', |
3afe7ab0 PB |
131 | 'missing-type.json', |
132 | 'nested-struct-data.json', | |
133 | 'nested-struct-data-invalid-dict.json', | |
134 | 'non-objects.json', | |
04f22362 | 135 | 'oob-coroutine.json', |
3afe7ab0 PB |
136 | 'oob-test.json', |
137 | 'allow-preconfig-test.json', | |
3afe7ab0 | 138 | 'pragma-extra-junk.json', |
3afe7ab0 PB |
139 | 'pragma-non-dict.json', |
140 | 'pragma-unknown.json', | |
e90a61e3 MA |
141 | 'pragma-value-not-bool.json', |
142 | 'pragma-value-not-list-of-str.json', | |
143 | 'pragma-value-not-list.json', | |
3afe7ab0 PB |
144 | 'qapi-schema-test.json', |
145 | 'quoted-structural-chars.json', | |
3afe7ab0 PB |
146 | 'redefined-command.json', |
147 | 'redefined-event.json', | |
492db12e | 148 | 'redefined-predefined.json', |
3afe7ab0 PB |
149 | 'redefined-type.json', |
150 | 'reserved-command-q.json', | |
151 | 'reserved-enum-q.json', | |
152 | 'reserved-member-has.json', | |
153 | 'reserved-member-q.json', | |
154 | 'reserved-member-u.json', | |
155 | 'reserved-member-underscore.json', | |
3afe7ab0 PB |
156 | 'reserved-type-list.json', |
157 | 'returns-alternate.json', | |
158 | 'returns-array-bad.json', | |
ef8b3829 | 159 | 'returns-bad-type.json', |
3afe7ab0 PB |
160 | 'returns-dict.json', |
161 | 'returns-unknown.json', | |
3afe7ab0 PB |
162 | 'string-code-point-31.json', |
163 | 'string-code-point-127.json', | |
164 | 'struct-base-clash-deep.json', | |
165 | 'struct-base-clash.json', | |
166 | 'struct-data-invalid.json', | |
167 | 'struct-member-if-invalid.json', | |
168 | 'struct-member-invalid-dict.json', | |
169 | 'struct-member-invalid.json', | |
e75d4225 | 170 | 'struct-member-name-clash.json', |
3afe7ab0 PB |
171 | 'trailing-comma-list.json', |
172 | 'trailing-comma-object.json', | |
173 | 'type-bypass-bad-gen.json', | |
3e6c8a63 | 174 | 'type-case.json', |
3afe7ab0 PB |
175 | 'unclosed-list.json', |
176 | 'unclosed-object.json', | |
177 | 'unclosed-string.json', | |
8b3b3a16 MA |
178 | 'union-array-branch.json', |
179 | 'union-bad-base.json', | |
180 | 'union-bad-discriminator.json', | |
181 | 'union-base-any.json', | |
3afe7ab0 PB |
182 | 'union-base-empty.json', |
183 | 'union-base-no-discriminator.json', | |
8b3b3a16 | 184 | 'union-base-union.json', |
3afe7ab0 PB |
185 | 'union-branch-if-invalid.json', |
186 | 'union-branch-invalid-dict.json', | |
8b3b3a16 MA |
187 | 'union-clash-member.json', |
188 | 'union-discriminator-bad-name.json', | |
189 | 'union-empty.json', | |
190 | 'union-inline-invalid-dict.json', | |
191 | 'union-int-branch.json', | |
3afe7ab0 | 192 | 'union-invalid-base.json', |
8b3b3a16 | 193 | 'union-invalid-branch-key.json', |
4918bb7d | 194 | 'union-invalid-data.json', |
8b3b3a16 MA |
195 | 'union-invalid-discriminator.json', |
196 | 'union-invalid-if-discriminator.json', | |
197 | 'union-no-base.json', | |
198 | 'union-optional-discriminator.json', | |
199 | 'union-string-discriminator.json', | |
3afe7ab0 PB |
200 | 'union-unknown.json', |
201 | 'unknown-escape.json', | |
202 | 'unknown-expr-key.json', | |
203 | ] | |
334c3cd5 JS |
204 | schemas = files(schemas) |
205 | ||
206 | # Intentionally missing schema file test -- not passed through files(): | |
207 | schemas += [meson.current_source_dir() / 'missing-schema.json'] | |
3afe7ab0 PB |
208 | |
209 | # Because people may want to use test-qapi.py from the command line, we | |
210 | # are not using the "#! /usr/bin/env python3" trick here. See | |
551bdfa0 | 211 | # docs/devel/build-system.rst |
334c3cd5 JS |
212 | test('QAPI schema regression tests', python, |
213 | args: files('test-qapi.py') + schemas, | |
3afe7ab0 PB |
214 | env: test_env, suite: ['qapi-schema', 'qapi-frontend']) |
215 | ||
216 | diff = find_program('diff') | |
217 | ||
e3af71e9 PB |
218 | custom_target('QAPI doc', |
219 | output: ['doc-good-qapi-commands.c', 'doc-good-qapi-commands.h', | |
220 | 'doc-good-qapi-emit-events.c', 'doc-good-qapi-emit-events.h', | |
221 | 'doc-good-qapi-events.c', 'doc-good-qapi-events.h', | |
222 | 'doc-good-qapi-init-commands.c', 'doc-good-qapi-init-commands.h', | |
223 | 'doc-good-qapi-introspect.c', 'doc-good-qapi-introspect.h', | |
224 | 'doc-good-qapi-types.c', 'doc-good-qapi-types.h', | |
225 | 'doc-good-qapi-visit.c', 'doc-good-qapi-visit.h' ], | |
226 | input: files('doc-good.json'), | |
227 | command: [ qapi_gen, '-o', meson.current_build_dir(), | |
228 | '-p', 'doc-good-', '@INPUT0@' ], | |
229 | depend_files: qapi_gen_depends) | |
3afe7ab0 | 230 | |
9dc6ee3f PB |
231 | if build_docs |
232 | # Test the document-comment document generation code by running a test schema | |
233 | # file through Sphinx's plain-text builder and comparing the result against | |
234 | # a golden reference. This is in theory susceptible to failures if Sphinx | |
235 | # changes its output, but the text output has historically been very stable | |
236 | # (no changes between Sphinx 1.6 and 3.0), so it is a better bet than | |
237 | # texinfo or HTML generation, both of which have had changes. We might | |
238 | # need to add more sophisticated logic here in future for some sort of | |
239 | # fuzzy comparison if future Sphinx versions produce different text, | |
240 | # but for now the simple comparison suffices. | |
241 | qapi_doc_out = custom_target('QAPI rST doc', | |
242 | output: ['doc-good.txt'], | |
243 | input: files('doc-good.json', 'doc-good.rst'), | |
244 | build_by_default: true, | |
706bbad2 | 245 | depfile: 'docs.d', |
9dc6ee3f PB |
246 | # We use -E to suppress Sphinx's caching, because |
247 | # we want it to always really run the QAPI doc | |
248 | # generation code. It also means we don't | |
249 | # clutter up the build dir with the cache. | |
250 | command: [SPHINX_ARGS, | |
251 | '-b', 'text', '-E', | |
654d6b04 | 252 | '-c', meson.project_source_root() / 'docs', |
9dc6ee3f | 253 | '-D', 'master_doc=doc-good', |
706bbad2 MAL |
254 | '-Ddepfile=@DEPFILE@', |
255 | '-Ddepfile_stamp=doc-good.stamp', | |
9dc6ee3f PB |
256 | meson.current_source_dir(), |
257 | meson.current_build_dir()]) | |
ca1145ee | 258 | |
9dc6ee3f PB |
259 | # Fix possible inconsistency in line endings in generated output and |
260 | # in the golden reference (which could otherwise cause test failures | |
261 | # on Windows hosts). Unfortunately diff --strip-trailing-cr | |
262 | # is GNU-diff only. The odd-looking perl is because we must avoid | |
263 | # using an explicit '\' character in the command arguments to | |
264 | # a custom_target(), as Meson will unhelpfully replace it with a '/' | |
265 | # (https://github.com/mesonbuild/meson/issues/1564) | |
266 | qapi_doc_out_nocr = custom_target('QAPI rST doc newline-sanitized', | |
267 | output: ['doc-good.txt.nocr'], | |
268 | input: qapi_doc_out[0], | |
269 | build_by_default: true, | |
270 | command: ['perl', '-pe', '$x = chr 13; s/$x$//', '@INPUT@'], | |
271 | capture: true) | |
ca1145ee | 272 | |
9dc6ee3f PB |
273 | qapi_doc_ref_nocr = custom_target('QAPI rST doc reference newline-sanitized', |
274 | output: ['doc-good.ref.nocr'], | |
275 | input: files('doc-good.txt'), | |
276 | build_by_default: true, | |
277 | command: ['perl', '-pe', '$x = chr 13; s/$x$//', '@INPUT@'], | |
278 | capture: true) | |
ca1145ee | 279 | |
7bef93ff | 280 | test('QAPI rST doc', diff, args: ['-u', qapi_doc_ref_nocr[0], qapi_doc_out_nocr[0]], |
ca1145ee PM |
281 | suite: ['qapi-schema', 'qapi-doc']) |
282 | endif |