summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorStef Walter <stefw@collabora.co.uk>2011-06-08 21:21:54 +0200
committerStef Walter <stefw@collabora.co.uk>2011-06-08 21:21:54 +0200
commit21333019a5afceb5f07637fb50b784a4ecd9f9ff (patch)
tree41a8c5ea0a8e06ea7fb1411a3fd856d72b9596bb /tests
parent7c1edab7e6c1c6939ecdeaefc5f006772298f9eb (diff)
Refactor configuration
* Move configuration loading into conf.c * Have user modules with same name merge/override modules in system.
Diffstat (limited to 'tests')
-rw-r--r--tests/conf-test.c40
1 files changed, 31 insertions, 9 deletions
diff --git a/tests/conf-test.c b/tests/conf-test.c
index d9929aa..2ef4e5c 100644
--- a/tests/conf-test.c
+++ b/tests/conf-test.c
@@ -44,18 +44,12 @@
static int n_errors = 0;
static void
-error_func (const char *buffer)
-{
- ++n_errors;
-}
-
-static void
test_parse_conf_1 (CuTest *tc)
{
hash_t *ht;
const char *value;
- ht = conf_parse_file (SRCDIR "/files/test-1.conf", 0, error_func);
+ ht = _p11_conf_parse_file (SRCDIR "/files/test-1.conf", 0);
CuAssertPtrNotNull (tc, ht);
value = hash_get (ht, "key1");
@@ -79,7 +73,7 @@ test_parse_ignore_missing (CuTest *tc)
hash_t *ht;
n_errors = 0;
- ht = conf_parse_file (SRCDIR "/files/non-existant.conf", CONF_IGNORE_MISSING, error_func);
+ ht = _p11_conf_parse_file (SRCDIR "/files/non-existant.conf", CONF_IGNORE_MISSING);
CuAssertPtrNotNull (tc, ht);
CuAssertIntEquals (tc, 0, hash_count (ht));
@@ -93,11 +87,38 @@ test_parse_fail_missing (CuTest *tc)
hash_t *ht;
n_errors = 0;
- ht = conf_parse_file (SRCDIR "/files/non-existant.conf", 0, error_func);
+ ht = _p11_conf_parse_file (SRCDIR "/files/non-existant.conf", 0);
CuAssertPtrEquals (tc, ht, NULL);
CuAssertIntEquals (tc, 1, n_errors);
}
+static void
+test_merge_defaults (CuTest *tc)
+{
+ hash_t *values;
+ hash_t *defaults;
+
+ values = hash_create (hash_string_hash, hash_string_equal, free, free);
+ defaults = hash_create (hash_string_hash, hash_string_equal, free, free);
+
+ hash_set (values, strdup ("one"), strdup ("real1"));
+ hash_set (values, strdup ("two"), strdup ("real2"));
+
+ hash_set (defaults, strdup ("two"), strdup ("default2"));
+ hash_set (defaults, strdup ("three"), strdup ("default3"));
+
+ if (!_p11_conf_merge_defaults (values, defaults))
+ CuFail (tc, "should not be reached");
+
+ hash_free (defaults);
+
+ CuAssertStrEquals (tc, hash_get (values, "one"), "real1");
+ CuAssertStrEquals (tc, hash_get (values, "two"), "real2");
+ CuAssertStrEquals (tc, hash_get (values, "three"), "default3");
+
+ hash_free (values);
+}
+
int
main (void)
{
@@ -108,6 +129,7 @@ main (void)
SUITE_ADD_TEST (suite, test_parse_conf_1);
SUITE_ADD_TEST (suite, test_parse_ignore_missing);
SUITE_ADD_TEST (suite, test_parse_fail_missing);
+ SUITE_ADD_TEST (suite, test_merge_defaults);
CuSuiteRun (suite);
CuSuiteSummary (suite, output);