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