mirror of
https://gitlab.com/libvirt/libvirt-python.git
synced 2025-12-20 00:23:49 +03:00
sanitytest: move class identification into a helper method
This is a step towards turning the sanitytest.py file into a normal python unittest. Best viewed with the '-b' flag to diff. Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
@@ -79,7 +79,8 @@ for n in tree.xpath('/api/files/file/exports[@type="enum"]/@symbol'):
|
|||||||
continue
|
continue
|
||||||
wantenums.append(n)
|
wantenums.append(n)
|
||||||
|
|
||||||
# Phase 2: Identify all classes and methods in the 'libvirt' python module
|
# Identify all classes and methods in the 'libvirt' python module
|
||||||
|
def identify_class_methods(wantenums, enumvals):
|
||||||
gotenums = [] # type: List[str]
|
gotenums = [] # type: List[str]
|
||||||
gottypes = [] # type: List[str]
|
gottypes = [] # type: List[str]
|
||||||
gotfunctions = {"libvirt": []} # type: Dict[str, List[str]]
|
gotfunctions = {"libvirt": []} # type: Dict[str, List[str]]
|
||||||
@@ -105,7 +106,7 @@ for enum in wantenums:
|
|||||||
fail = True
|
fail = True
|
||||||
for typ, enumval in enumvals.items():
|
for typ, enumval in enumvals.items():
|
||||||
if enum in enumval:
|
if enum in enumval:
|
||||||
print("FAIL Missing exported enum %s of type %s" % (enum, typ))
|
raise Exception("Missing exported enum %s of type %s" % (enum, typ))
|
||||||
|
|
||||||
for klassname in gottypes:
|
for klassname in gottypes:
|
||||||
klassobj = getattr(libvirt, klassname)
|
klassobj = getattr(libvirt, klassname)
|
||||||
@@ -118,6 +119,8 @@ for klassname in gottypes:
|
|||||||
if callable(thing):
|
if callable(thing):
|
||||||
gotfunctions[klassname].append(name)
|
gotfunctions[klassname].append(name)
|
||||||
|
|
||||||
|
return gotfunctions, gottypes
|
||||||
|
|
||||||
|
|
||||||
# First cut at mapping of C APIs to python classes + methods
|
# First cut at mapping of C APIs to python classes + methods
|
||||||
def basic_class_method_mapping(wantfunctions, gottypes):
|
def basic_class_method_mapping(wantfunctions, gottypes):
|
||||||
@@ -379,6 +382,7 @@ def validate_c_api_bindings_present(finalklassmap):
|
|||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
gotfunctions, gottypes = identify_class_methods(wantenums, enumvals)
|
||||||
basicklassmap = basic_class_method_mapping(wantfunctions, gottypes)
|
basicklassmap = basic_class_method_mapping(wantfunctions, gottypes)
|
||||||
finalklassmap = fixup_class_method_mapping(basicklassmap)
|
finalklassmap = fixup_class_method_mapping(basicklassmap)
|
||||||
usedfunctions = validate_c_to_python_api_mappings(finalklassmap, gotfunctions)
|
usedfunctions = validate_c_to_python_api_mappings(finalklassmap, gotfunctions)
|
||||||
|
|||||||
Reference in New Issue
Block a user