X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Ftest%2Ftest-env-replace.c;h=0274e97618a71dd9d4064a7b51a1e4aa4a7cf954;hp=2da3845354ae0409f8231198ea0e7dea191bd1dd;hb=b463b81399f0bc0d54107ef819cc0f843473c7d7;hpb=940bd4738b16503d903689e50eeb22645463fc16 diff --git a/src/test/test-env-replace.c b/src/test/test-env-replace.c index 2da384535..0274e9761 100644 --- a/src/test/test-env-replace.c +++ b/src/test/test-env-replace.c @@ -24,67 +24,83 @@ #include "util.h" #include "strv.h" +#include "env-util.h" static void test_strv_env_delete(void) { _cleanup_strv_free_ char **a = NULL, **b = NULL, **c = NULL, **d = NULL; a = strv_new("FOO=BAR", "WALDO=WALDO", "WALDO=", "PIEP", "SCHLUMPF=SMURF", NULL); + assert_se(a); + b = strv_new("PIEP", "FOO", NULL); + assert_se(b); + c = strv_new("SCHLUMPF", NULL); + assert_se(c); d = strv_env_delete(a, 2, b, c); + assert_se(d); - assert(streq(d[0], "WALDO=WALDO")); - assert(streq(d[1], "WALDO=")); - assert(strv_length(d) == 2); + assert_se(streq(d[0], "WALDO=WALDO")); + assert_se(streq(d[1], "WALDO=")); + assert_se(strv_length(d) == 2); } static void test_strv_env_unset(void) { _cleanup_strv_free_ char **l = NULL; l = strv_new("PIEP", "SCHLUMPF=SMURFF", "NANANANA=YES", NULL); + assert_se(l); - strv_env_unset(l, "SCHLUMPF"); + assert_se(strv_env_unset(l, "SCHLUMPF") == l); - assert(streq(l[0], "PIEP")); - assert(streq(l[1], "NANANANA=YES")); - assert(strv_length(l) == 2); + assert_se(streq(l[0], "PIEP")); + assert_se(streq(l[1], "NANANANA=YES")); + assert_se(strv_length(l) == 2); } static void test_strv_env_set(void) { _cleanup_strv_free_ char **l = NULL, **r = NULL; l = strv_new("PIEP", "SCHLUMPF=SMURFF", "NANANANA=YES", NULL); + assert_se(l); r = strv_env_set(l, "WALDO=WALDO"); + assert_se(r); - assert(streq(r[0], "PIEP")); - assert(streq(r[1], "SCHLUMPF=SMURFF")); - assert(streq(r[2], "NANANANA=YES")); - assert(streq(r[3], "WALDO=WALDO")); - assert(strv_length(r) == 4); + assert_se(streq(r[0], "PIEP")); + assert_se(streq(r[1], "SCHLUMPF=SMURFF")); + assert_se(streq(r[2], "NANANANA=YES")); + assert_se(streq(r[3], "WALDO=WALDO")); + assert_se(strv_length(r) == 4); } static void test_strv_env_merge(void) { _cleanup_strv_free_ char **a = NULL, **b = NULL, **r = NULL; a = strv_new("FOO=BAR", "WALDO=WALDO", "WALDO=", "PIEP", "SCHLUMPF=SMURF", NULL); + assert_se(a); + b = strv_new("FOO=KKK", "FOO=", "PIEP=", "SCHLUMPF=SMURFF", "NANANANA=YES", NULL); + assert_se(b); r = strv_env_merge(2, a, b); - assert(streq(r[0], "FOO=")); - assert(streq(r[1], "WALDO=")); - assert(streq(r[2], "PIEP")); - assert(streq(r[3], "SCHLUMPF=SMURFF")); - assert(streq(r[4], "PIEP=")); - assert(streq(r[5], "NANANANA=YES")); - assert(strv_length(r) == 6); - - strv_env_clean(r); - assert(streq(r[0], "PIEP")); - assert(streq(r[1], "SCHLUMPF=SMURFF")); - assert(streq(r[2], "NANANANA=YES")); - assert(strv_length(r) == 3); + assert_se(r); + assert_se(streq(r[0], "FOO=")); + assert_se(streq(r[1], "WALDO=")); + assert_se(streq(r[2], "PIEP")); + assert_se(streq(r[3], "SCHLUMPF=SMURFF")); + assert_se(streq(r[4], "PIEP=")); + assert_se(streq(r[5], "NANANANA=YES")); + assert_se(strv_length(r) == 6); + + assert_se(strv_env_clean(r) == r); + assert_se(streq(r[0], "FOO=")); + assert_se(streq(r[1], "WALDO=")); + assert_se(streq(r[2], "SCHLUMPF=SMURFF")); + assert_se(streq(r[3], "PIEP=")); + assert_se(streq(r[4], "NANANANA=YES")); + assert_se(strv_length(r) == 5); } static void test_replace_env_arg(void) { @@ -108,24 +124,25 @@ static void test_replace_env_arg(void) { _cleanup_strv_free_ char **r = NULL; r = replace_env_argv((char**) line, (char**) env); - assert(streq(r[0], "FOO$FOO")); - assert(streq(r[1], "FOO$FOOFOO")); - assert(streq(r[2], "FOOBAR BAR$FOO")); - assert(streq(r[3], "FOOBAR BAR")); - assert(streq(r[4], "BAR BAR")); - assert(streq(r[5], "BAR")); - assert(streq(r[6], "BAR")); - assert(streq(r[7], "BAR BARwaldo")); - assert(streq(r[8], "${FOO")); - assert(strv_length(r) == 9); + assert_se(r); + assert_se(streq(r[0], "FOO$FOO")); + assert_se(streq(r[1], "FOO$FOOFOO")); + assert_se(streq(r[2], "FOOBAR BAR$FOO")); + assert_se(streq(r[3], "FOOBAR BAR")); + assert_se(streq(r[4], "BAR BAR")); + assert_se(streq(r[5], "BAR")); + assert_se(streq(r[6], "BAR")); + assert_se(streq(r[7], "BAR BARwaldo")); + assert_se(streq(r[8], "${FOO")); + assert_se(strv_length(r) == 9); } -static void test_one_normalize(const char *input, const char *output) -{ +static void test_one_normalize(const char *input, const char *output) { _cleanup_free_ char *t; t = normalize_env_assignment(input); - assert(streq(t, output)); + assert_se(t); + assert_se(streq(t, output)); } static void test_normalize_env_assignment(void) { @@ -145,6 +162,48 @@ static void test_normalize_env_assignment(void) { test_one_normalize(" ' xyz' = 'bar ' ", "' xyz'=bar "); } +static void test_env_clean(void) { + _cleanup_strv_free_ char **e; + + e = strv_new("FOOBAR=WALDO", + "FOOBAR=WALDO", + "FOOBAR", + "F", + "X=", + "F=F", + "=", + "=F", + "", + "0000=000", + "äöüß=abcd", + "abcd=äöüß", + "xyz\n=xyz", + "xyz=xyz\n", + "another=one", + "another=final one", + NULL); + assert_se(e); + assert_se(!strv_env_is_valid(e)); + assert_se(strv_env_clean(e) == e); + assert_se(strv_env_is_valid(e)); + + assert_se(streq(e[0], "FOOBAR=WALDO")); + assert_se(streq(e[1], "X=")); + assert_se(streq(e[2], "F=F")); + assert_se(streq(e[3], "abcd=äöüß")); + assert_se(streq(e[4], "another=final one")); + assert_se(e[5] == NULL); +} + +static void test_env_name_is_valid(void) { + assert_se(env_name_is_valid("test")); + + assert_se(!env_name_is_valid(NULL)); + assert_se(!env_name_is_valid("")); + assert_se(!env_name_is_valid("5_starting_with_a_number_is_wrong")); + assert_se(!env_name_is_valid("#¤%&?_only_numbers_letters_and_underscore_allowed")); +} + int main(int argc, char *argv[]) { test_strv_env_delete(); test_strv_env_unset(); @@ -152,6 +211,8 @@ int main(int argc, char *argv[]) { test_strv_env_merge(); test_replace_env_arg(); test_normalize_env_assignment(); + test_env_clean(); + test_env_name_is_valid(); return 0; }