The allow_oob parameter was passed in but not used in tests. Now reflect that in the tests, so we need to touch up other command testers with that new change. Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Peter Xu <peterx@redhat.com> Message-Id: <20180326063901.27425-6-peterx@redhat.com> Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com> Signed-off-by: Eric Blake <eblake@redhat.com>
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#
 | 
						|
# QAPI parser test harness
 | 
						|
#
 | 
						|
# Copyright (c) 2013 Red Hat Inc.
 | 
						|
#
 | 
						|
# Authors:
 | 
						|
#  Markus Armbruster <armbru@redhat.com>
 | 
						|
#
 | 
						|
# This work is licensed under the terms of the GNU GPL, version 2 or later.
 | 
						|
# See the COPYING file in the top-level directory.
 | 
						|
#
 | 
						|
 | 
						|
from __future__ import print_function
 | 
						|
import sys
 | 
						|
from qapi.common import QAPIError, QAPISchema, QAPISchemaVisitor
 | 
						|
 | 
						|
 | 
						|
class QAPISchemaTestVisitor(QAPISchemaVisitor):
 | 
						|
 | 
						|
    def visit_module(self, name):
 | 
						|
        print('module %s' % name)
 | 
						|
 | 
						|
    def visit_include(self, name, info):
 | 
						|
        print('include %s' % name)
 | 
						|
 | 
						|
    def visit_enum_type(self, name, info, values, prefix):
 | 
						|
        print('enum %s %s' % (name, values))
 | 
						|
        if prefix:
 | 
						|
            print('    prefix %s' % prefix)
 | 
						|
 | 
						|
    def visit_object_type(self, name, info, base, members, variants):
 | 
						|
        print('object %s' % name)
 | 
						|
        if base:
 | 
						|
            print('    base %s' % base.name)
 | 
						|
        for m in members:
 | 
						|
            print('    member %s: %s optional=%s' % \
 | 
						|
                  (m.name, m.type.name, m.optional))
 | 
						|
        self._print_variants(variants)
 | 
						|
 | 
						|
    def visit_alternate_type(self, name, info, variants):
 | 
						|
        print('alternate %s' % name)
 | 
						|
        self._print_variants(variants)
 | 
						|
 | 
						|
    def visit_command(self, name, info, arg_type, ret_type,
 | 
						|
                      gen, success_response, boxed, allow_oob):
 | 
						|
        print('command %s %s -> %s' % \
 | 
						|
              (name, arg_type and arg_type.name, ret_type and ret_type.name))
 | 
						|
        print('   gen=%s success_response=%s boxed=%s oob=%s' % \
 | 
						|
              (gen, success_response, boxed, allow_oob))
 | 
						|
 | 
						|
    def visit_event(self, name, info, arg_type, boxed):
 | 
						|
        print('event %s %s' % (name, arg_type and arg_type.name))
 | 
						|
        print('   boxed=%s' % boxed)
 | 
						|
 | 
						|
    @staticmethod
 | 
						|
    def _print_variants(variants):
 | 
						|
        if variants:
 | 
						|
            print('    tag %s' % variants.tag_member.name)
 | 
						|
            for v in variants.variants:
 | 
						|
                print('    case %s: %s' % (v.name, v.type.name))
 | 
						|
 | 
						|
 | 
						|
try:
 | 
						|
    schema = QAPISchema(sys.argv[1])
 | 
						|
except QAPIError as err:
 | 
						|
    print(err, file=sys.stderr)
 | 
						|
    exit(1)
 | 
						|
 | 
						|
schema.visit(QAPISchemaTestVisitor())
 | 
						|
 | 
						|
for doc in schema.docs:
 | 
						|
    if doc.symbol:
 | 
						|
        print('doc symbol=%s' % doc.symbol)
 | 
						|
    else:
 | 
						|
        print('doc freeform')
 | 
						|
    print('    body=\n%s' % doc.body.text)
 | 
						|
    for arg, section in doc.args.items():
 | 
						|
        print('    arg=%s\n%s' % (arg, section.text))
 | 
						|
    for section in doc.sections:
 | 
						|
        print('    section=%s\n%s' % (section.name, section.text))
 |