[Libosinfo] [PATCHv4 11/11] test: Add test for param remapping in install scripts

Christophe Fergeau cfergeau at redhat.com
Mon Dec 17 21:07:54 UTC 2012


---
 test/dbdata/datamaps/test-datamap.xml              | 20 ++++++
 .../dbdata/install-scripts/test-install-script.xml | 26 +++++++
 test/test-install-script.c                         | 84 ++++++++++++++++++++++
 3 files changed, 130 insertions(+)
 create mode 100644 test/dbdata/datamaps/test-datamap.xml
 create mode 100644 test/dbdata/install-scripts/test-install-script.xml

diff --git a/test/dbdata/datamaps/test-datamap.xml b/test/dbdata/datamaps/test-datamap.xml
new file mode 100644
index 0000000..16c5116
--- /dev/null
+++ b/test/dbdata/datamaps/test-datamap.xml
@@ -0,0 +1,20 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<libosinfo version="0.0.1">
+
+  <datamap id="http://example.com/libosinfo/test-datamap">
+    <!-- default value for keyboard, mandatory -->
+    <entry inval="us" outval="us"/>
+    <entry inval="val1" outval="foo"/>
+    <entry inval="val2" outval="bar"/>
+    <entry inval="val3" outval="baz"/>
+    <entry inval="VAL1" outval="FOOBAR"/>
+  </datamap>
+
+  <datamap id="http://example.com/libosinfo/test-datamap2">
+    <!-- default value for language, mandatory -->
+    <entry inval="en_EN.UTF-8" outval="English"/>
+    <entry inval="en_EN" outval="English"/>
+    <entry inval="fr_FR" outval="French"/>
+    <entry inval="fi_FI" outval="Finnish"/>
+  </datamap>
+</libosinfo>
diff --git a/test/dbdata/install-scripts/test-install-script.xml b/test/dbdata/install-scripts/test-install-script.xml
new file mode 100644
index 0000000..48469ef
--- /dev/null
+++ b/test/dbdata/install-scripts/test-install-script.xml
@@ -0,0 +1,26 @@
+<libosinfo version="0.0.1">
+  <!-- JEOS PROFILE -->
+  <install-script id="http://example.com/libosinfo/test-install-script">
+    <profile>jeos</profile>
+    <expected-filename>test.ks</expected-filename>
+    <config>
+      <param name="l10n-keyboard" policy="optional" value-map="http://example.com/libosinfo/test-datamap"/>
+      <param name="l10n-language" policy="optional" value-map="http://example.com/libosinfo/test-datamap2"/>
+      <param name="l10n-timezone" policy="optional"/>
+    </config>
+    <template>
+      <xsl:stylesheet
+        xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+        version="1.0">
+
+        <xsl:output method="text"/>
+
+        <xsl:template match="/install-script-config">
+keyboard <xsl:value-of select="config/l10n-keyboard"/>
+lang <xsl:value-of select="config/l10n-language"/>
+timezone --utc <xsl:value-of select="config/l10n-timezone"/>
+        </xsl:template>
+      </xsl:stylesheet>
+    </template>
+  </install-script>
+</libosinfo>
diff --git a/test/test-install-script.c b/test/test-install-script.c
index 6abeeb3..4a3f16a 100644
--- a/test/test-install-script.c
+++ b/test/test-install-script.c
@@ -56,6 +56,12 @@ static const gchar *expectData =                                        \
     "%end\n"                                                            \
     "  ";
 
+static const gchar *expectData2 =                                       \
+    "\n"                                                                \
+    "keyboard FOOBAR\n"                                                 \
+    "lang French\n"                                                     \
+    "timezone --utc Europe/Paris";
+
 static void test_generate_finish(GObject *src,
                                  GAsyncResult *res,
                                  gpointer user_data)
@@ -172,6 +178,83 @@ START_TEST(test_script_data)
 }
 END_TEST
 
+START_TEST(test_script_datamap)
+{
+    OsinfoLoader *loader = osinfo_loader_new();
+    OsinfoDb *db;
+    OsinfoOs *os;
+    OsinfoInstallScript *script;
+    OsinfoInstallConfig *config;
+    GMainLoop *loop;
+
+    osinfo_loader_process_path(loader, SRCDIR "/test/dbdata", &error);
+    fail_unless(error == NULL, error ? error->message : "none");
+    db = g_object_ref(osinfo_loader_get_db(loader));
+    g_object_unref(loader);
+
+    fail_unless(osinfo_db_get_datamap(db, "http://example.com/libosinfo/test-datamap") != NULL, "Could not find OsinfoDatamap 'test-datamap'");
+    fail_unless(osinfo_db_get_datamap(db, "http://example.com/libosinfo/test-datamap2") != NULL, "Could not find OsinfoDatamap 'test-datamap2'");
+    script = osinfo_db_get_install_script(db, "http://example.com/libosinfo/test-install-script");
+    fail_unless(script != NULL, "Could not find OsinfoInstallScript 'test-install-script'");
+
+    config = osinfo_install_config_new("http://example.com");
+
+    osinfo_install_config_set_l10n_keyboard(config, "unknown");
+    fail_unless(g_strcmp0(osinfo_install_config_get_l10n_keyboard(config), "unknown") == 0,
+                "Got %s instead of 'unknown'", osinfo_install_config_get_l10n_keyboard(config));
+
+    osinfo_install_config_set_l10n_keyboard(config, "val1");
+    fail_unless(g_strcmp0(osinfo_install_config_get_l10n_keyboard(config), "val1") == 0,
+                "Got %s instead of 'val1'", osinfo_install_config_get_l10n_keyboard(config));
+
+    osinfo_install_config_set_l10n_keyboard(config, "val2");
+    fail_unless(g_strcmp0(osinfo_install_config_get_l10n_keyboard(config), "val2") == 0,
+                "Got %s instead of 'val2'", osinfo_install_config_get_l10n_keyboard(config));
+
+    osinfo_install_config_set_l10n_keyboard(config, "val3");
+    fail_unless(g_strcmp0(osinfo_install_config_get_l10n_keyboard(config), "val3") == 0,
+                "Got %s instead of 'val3'", osinfo_install_config_get_l10n_keyboard(config));
+
+    osinfo_install_config_set_l10n_keyboard(config, "VAL1");
+    fail_unless(g_strcmp0(osinfo_install_config_get_l10n_keyboard(config), "VAL1") == 0,
+                "Got %s instead of 'VAL1", osinfo_install_config_get_l10n_keyboard(config));
+
+    osinfo_install_config_set_l10n_language(config, "en_EN");
+    fail_unless(g_strcmp0(osinfo_install_config_get_l10n_language(config), "en_EN") == 0,
+                "Got %s instead of 'en_EN'", osinfo_install_config_get_l10n_language(config));
+    osinfo_install_config_set_l10n_language(config, "fr_FR");
+    osinfo_install_config_set_l10n_timezone(config, "Europe/Paris");
+
+
+    os = osinfo_os_new("http://fedoraproject.org/fedora/16");
+    osinfo_entity_set_param(OSINFO_ENTITY(os),
+                            OSINFO_PRODUCT_PROP_SHORT_ID,
+                            "fedora16");
+
+    loop = g_main_loop_new (g_main_context_get_thread_default (),
+                            TRUE);
+
+    osinfo_install_script_generate_async(script,
+                                         os,
+                                         config,
+                                         NULL,
+                                         test_generate_finish,
+                                         loop);
+
+    if (g_main_loop_is_running(loop))
+        g_main_loop_run(loop);
+
+    unlink(BUILDDIR "/test/install-script-actual.txt");
+    fail_unless(error == NULL, error ? error->message : "none");
+
+    fail_unless(strcmp(actualData, expectData2) == 0, "Actual '%s' match expect '%s'",
+                actualData, expectData2);
+
+    g_object_unref(db);
+    g_object_unref(os);
+    g_object_unref(config);
+}
+END_TEST
 
 
 static Suite *
@@ -183,6 +266,7 @@ list_suite(void)
 
     tcase_add_test(tc, test_script_file);
     tcase_add_test(tc, test_script_data);
+    tcase_add_test(tc, test_script_datamap);
     suite_add_tcase(s, tc);
     return s;
 }
-- 
1.8.0.2




More information about the Libosinfo mailing list