s390x/kvm: always ignore empty vcpu interrupt state
[qemu.git] / tests / qapi-schema / qapi-schema-test.json
blobc7eaa865daff48aa6d1c9481ebcf7d3e356a2a01
1 # *-*- Mode: Python -*-*
3 # for testing enums
4 { 'enum': 'EnumOne',
5   'data': [ 'value1', 'value2', 'value3' ] }
6 { 'struct': 'NestedEnumsOne',
7   'data': { 'enum1': 'EnumOne', '*enum2': 'EnumOne', 'enum3': 'EnumOne', '*enum4': 'EnumOne' } }
9 # for testing nested structs
10 { 'struct': 'UserDefZero',
11   'data': { 'integer': 'int' } }
13 { 'struct': 'UserDefOne',
14   'base': 'UserDefZero',
15   'data': { 'string': 'str', '*enum1': 'EnumOne' } }
17 { 'struct': 'UserDefTwoDictDict',
18   'data': { 'userdef': 'UserDefOne', 'string': 'str' } }
20 { 'struct': 'UserDefTwoDict',
21   'data': { 'string1': 'str',
22             'dict2': 'UserDefTwoDictDict',
23             '*dict3': 'UserDefTwoDictDict' } }
25 { 'struct': 'UserDefTwo',
26   'data': { 'string0': 'str',
27             'dict1': 'UserDefTwoDict' } }
29 # for testing unions
30 { 'struct': 'UserDefA',
31   'data': { 'boolean': 'bool' } }
33 { 'struct': 'UserDefB',
34   'data': { 'integer': 'int' } }
36 { 'struct': 'UserDefC',
37   'data': { 'string1': 'str', 'string2': 'str' } }
39 { 'struct': 'UserDefUnionBase',
40   'data': { 'string': 'str', 'enum1': 'EnumOne' } }
42 { 'union': 'UserDefFlatUnion',
43   'base': 'UserDefUnionBase',
44   'discriminator': 'enum1',
45   'data': { 'value1' : 'UserDefA', 'value2' : 'UserDefB', 'value3' : 'UserDefB' } }
46 # FIXME generated struct UserDefFlatUnion has members for direct base
47 # UserDefOne, but lacks members for indirect base UserDefZero
49 # this variant of UserDefFlatUnion defaults to a union that uses fields with
50 # allocated types to test corner cases in the cleanup/dealloc visitor
51 { 'union': 'UserDefFlatUnion2',
52   'base': 'UserDefUnionBase',
53   'discriminator': 'enum1',
54   'data': { 'value1' : 'UserDefC', 'value2' : 'UserDefB', 'value3' : 'UserDefA' } }
56 { 'alternate': 'UserDefAlternate',
57   'data': { 'uda': 'UserDefA', 's': 'str', 'i': 'int' } }
59 # for testing native lists
60 { 'union': 'UserDefNativeListUnion',
61   'data': { 'integer': ['int'],
62             's8': ['int8'],
63             's16': ['int16'],
64             's32': ['int32'],
65             's64': ['int64'],
66             'u8': ['uint8'],
67             'u16': ['uint16'],
68             'u32': ['uint32'],
69             'u64': ['uint64'],
70             'number': ['number'],
71             'boolean': ['bool'],
72             'string': ['str'],
73             'sizes': ['size'] } }
75 # testing commands
76 { 'command': 'user_def_cmd', 'data': {} }
77 { 'command': 'user_def_cmd1', 'data': {'ud1a': 'UserDefOne'} }
78 { 'command': 'user_def_cmd2',
79   'data': {'ud1a': 'UserDefOne', '*ud1b': 'UserDefOne'},
80   'returns': 'UserDefTwo' }
81 { 'command': 'user_def_cmd3', 'data': {'a': 'int', '*b': 'int' },
82   'returns': 'int' }
84 # For testing integer range flattening in opts-visitor. The following schema
85 # corresponds to the option format:
87 # -userdef i64=3-6,i64=-5--1,u64=2,u16=1,u16=7-12
89 # For simplicity, this example doesn't use [type=]discriminator nor optargs
90 # specific to discriminator values.
91 { 'struct': 'UserDefOptions',
92   'data': {
93     '*i64' : [ 'int'    ],
94     '*u64' : [ 'uint64' ],
95     '*u16' : [ 'uint16' ],
96     '*i64x':   'int'     ,
97     '*u64x':   'uint64'  } }
99 # testing event
100 { 'struct': 'EventStructOne',
101   'data': { 'struct1': 'UserDefOne', 'string': 'str', '*enum2': 'EnumOne' } }
103 { 'event': 'EVENT_A' }
104 { 'event': 'EVENT_B',
105   'data': { } }
106 { 'event': 'EVENT_C',
107   'data': { '*a': 'int', '*b': 'UserDefOne', 'c': 'str' } }
108 { 'event': 'EVENT_D',
109   'data': { 'a' : 'EventStructOne', 'b' : 'str', '*c': 'str', '*enum3': 'EnumOne' } }
111 # test that we correctly compile downstream extensions
112 { 'enum': '__org.qemu_x-Enum', 'data': [ '__org.qemu_x-value' ] }
113 { 'struct': '__org.qemu_x-Base',
114   'data': { '__org.qemu_x-member1': '__org.qemu_x-Enum' } }
115 { 'struct': '__org.qemu_x-Struct', 'base': '__org.qemu_x-Base',
116   'data': { '__org.qemu_x-member2': 'str' } }
117 { 'union': '__org.qemu_x-Union1', 'data': { '__org.qemu_x-branch': 'str' } }
118 { 'struct': '__org.qemu_x-Struct2',
119   'data': { 'array': ['__org.qemu_x-Union1'] } }
120 { 'union': '__org.qemu_x-Union2', 'base': '__org.qemu_x-Base',
121   'discriminator': '__org.qemu_x-member1',
122   'data': { '__org.qemu_x-value': '__org.qemu_x-Struct2' } }
123 { 'alternate': '__org.qemu_x-Alt',
124   'data': { '__org.qemu_x-branch': 'str', 'b': '__org.qemu_x-Base' } }
125 { 'event': '__ORG.QEMU_X-EVENT', 'data': '__org.qemu_x-Struct' }
126 { 'command': '__org.qemu_x-command',
127   'data': { 'a': ['__org.qemu_x-Enum'], 'b': ['__org.qemu_x-Struct'],
128             'c': '__org.qemu_x-Union2', 'd': '__org.qemu_x-Alt' },
129   'returns': '__org.qemu_x-Union1' }