[libvirt] [PATCH v2 1/4] tests: schema: Add possibility to validate individual files

Peter Krempa pkrempa at redhat.com
Wed Mar 29 07:28:13 UTC 2017


Sometimes it may be desired to validate individual files against a
schema. Refactor the data structures to unify them and introduce a new
macro DO_TEST_FILE(schema, xmlfile) which will test the XML file against
the given schema file.
---
 tests/virschematest.c | 75 ++++++++++++++++++++++++++++++++-------------------
 1 file changed, 47 insertions(+), 28 deletions(-)

diff --git a/tests/virschematest.c b/tests/virschematest.c
index faf66d642..b73555da8 100644
--- a/tests/virschematest.c
+++ b/tests/virschematest.c
@@ -35,6 +35,7 @@ VIR_LOG_INIT("tests.schematest");

 struct testSchemaData {
     virXMLValidatorPtr validator;
+    const char *schema;
     const char *xml_path;
 };

@@ -140,15 +141,10 @@ testSchemaDirs(const char *schema, virXMLValidatorPtr validator, ...)
 }


-struct testSchemaFileData {
-    virXMLValidatorPtr validator;
-    const char *schema;
-};
-
 static int
 testSchemaGrammar(const void *opaque)
 {
-    struct testSchemaFileData *data = (struct testSchemaFileData *) opaque;
+    struct testSchemaData *data = (struct testSchemaData *) opaque;
     char *schema_path;
     int ret = -1;

@@ -171,11 +167,11 @@ static int
 mymain(void)
 {
     int ret = 0;
-    struct testSchemaFileData data;
+    struct testSchemaData data;

     memset(&data, 0, sizeof(data));

-#define DO_TEST(sch, ...)                                                      \
+#define DO_TEST_DIR(sch, ...)                                                  \
     do {                                                                       \
         data.schema = sch;                                                     \
         if (virTestRun("test schema grammar file: " sch,                       \
@@ -196,26 +192,49 @@ mymain(void)
         }                                                                      \
     } while (0)

-    DO_TEST("capability.rng", "capabilityschemadata", "xencapsdata");
-    DO_TEST("domain.rng", "domainschemadata", "qemuargv2xmldata",
-            "qemuxml2argvdata", "sexpr2xmldata", "xmconfigdata",
-            "xml2sexprdata", "qemuxml2xmloutdata", "lxcxml2xmldata",
-            "lxcxml2xmloutdata", "bhyvexml2argvdata", "genericxml2xmlindata",
-            "genericxml2xmloutdata", "xlconfigdata",
-            "qemuhotplugtestdomains");
-    DO_TEST("domaincaps.rng", "domaincapsschemadata");
-    DO_TEST("domainsnapshot.rng", "domainsnapshotxml2xmlin",
-            "domainsnapshotxml2xmlout");
-    DO_TEST("interface.rng", "interfaceschemadata");
-    DO_TEST("network.rng", "../src/network", "networkxml2xmlin",
-            "networkxml2xmlout", "networkxml2confdata");
-    DO_TEST("nodedev.rng", "nodedevschemadata");
-    DO_TEST("nwfilter.rng", "nwfilterxml2xmlout");
-    DO_TEST("secret.rng", "secretxml2xmlin");
-    DO_TEST("storagepool.rng", "storagepoolxml2xmlin", "storagepoolxml2xmlout",
-            "storagepoolschemadata");
-    DO_TEST("storagevol.rng", "storagevolxml2xmlin", "storagevolxml2xmlout",
-            "storagevolschemadata");
+#define DO_TEST_FILE(sch, xmlfile)                                             \
+    do {                                                                       \
+        data.schema = sch;                                                     \
+        data.xml_path = abs_srcdir "/" xmlfile;                                \
+        if (virTestRun("test schema grammar file: " sch,                       \
+                       testSchemaGrammar, &data) == 0) {                       \
+            /* initialize the validator even if the schema test                \
+             * was skipped because of VIR_TEST_RANGE */                        \
+            if (!data.validator && testSchemaGrammar(&data) < 0) {             \
+                ret = -1;                                                      \
+                break;                                                         \
+            }                                                                  \
+            if (virTestRun("Checking " xmlfile " against " sch,                \
+                           testSchemaFile, &data) < 0)                         \
+                ret = -1;                                                      \
+                                                                               \
+            virXMLValidatorFree(data.validator);                               \
+            data.validator = NULL;                                             \
+        } else {                                                               \
+            ret = -1;                                                          \
+        }                                                                      \
+    } while (0)
+
+    DO_TEST_DIR("capability.rng", "capabilityschemadata", "xencapsdata");
+    DO_TEST_DIR("domain.rng", "domainschemadata", "qemuargv2xmldata",
+                "qemuxml2argvdata", "sexpr2xmldata", "xmconfigdata",
+                "xml2sexprdata", "qemuxml2xmloutdata", "lxcxml2xmldata",
+                "lxcxml2xmloutdata", "bhyvexml2argvdata", "genericxml2xmlindata",
+                "genericxml2xmloutdata", "xlconfigdata",
+                "qemuhotplugtestdomains");
+    DO_TEST_DIR("domaincaps.rng", "domaincapsschemadata");
+    DO_TEST_DIR("domainsnapshot.rng", "domainsnapshotxml2xmlin",
+                "domainsnapshotxml2xmlout");
+    DO_TEST_DIR("interface.rng", "interfaceschemadata");
+    DO_TEST_DIR("network.rng", "../src/network", "networkxml2xmlin",
+                "networkxml2xmlout", "networkxml2confdata");
+    DO_TEST_DIR("nodedev.rng", "nodedevschemadata");
+    DO_TEST_DIR("nwfilter.rng", "nwfilterxml2xmlout");
+    DO_TEST_DIR("secret.rng", "secretxml2xmlin");
+    DO_TEST_DIR("storagepool.rng", "storagepoolxml2xmlin", "storagepoolxml2xmlout",
+                "storagepoolschemadata");
+    DO_TEST_DIR("storagevol.rng", "storagevolxml2xmlin", "storagevolxml2xmlout",
+                "storagevolschemadata");

     return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
 }
-- 
2.12.1




More information about the libvir-list mailing list