#include #include #include #include "test.h" /* This test is just to be used with valgrind */ RESULT test_strfreev () { gchar **array = g_new (gchar *, 4); array [0] = g_strdup ("one"); array [1] = g_strdup ("two"); array [2] = g_strdup ("three"); array [3] = NULL; g_strfreev (array); g_strfreev (NULL); return OK; } RESULT test_concat () { gchar *x = g_strconcat ("Hello", ", ", "world", NULL); if (strcmp (x, "Hello, world") != 0) return FAILED("concat failed, got: %s", x); g_free (x); return OK; } RESULT test_split () { const gchar *to_split = "Hello world, how are we doing today?"; gint i; gchar **v; v= g_strsplit(to_split, " ", 0); if(v == NULL) { return FAILED("split failed, got NULL vector (1)"); } for(i = 0; v[i] != NULL; i++); if(i != 7) { return FAILED("split failed, expected 7 tokens, got %d", i); } g_strfreev(v); v = g_strsplit(to_split, ":", -1); if(v == NULL) { return FAILED("split failed, got NULL vector (2)"); } for(i = 0; v[i] != NULL; i++); if(i != 1) { return FAILED("split failed, expected 1 token, got %d", i); } if(strcmp(v[0], to_split) != 0) { return FAILED("expected vector[0] to be '%s' but it was '%s'", to_split, v[0]); } g_strfreev(v); return OK; } RESULT test_strreverse () { gchar *a = g_strdup ("onetwothree"); gchar *a_target = "eerhtowteno"; gchar *b = g_strdup ("onetwothre"); gchar *b_target = "erhtowteno"; g_strreverse (a); if (strcmp (a, a_target)) { g_free (b); g_free (a); return FAILED("strreverse failed. Expecting: '%s' and got '%s'\n", a, a_target); } g_strreverse (b); if (strcmp (b, b_target)) { g_free (b); g_free (a); return FAILED("strreverse failed. Expecting: '%s' and got '%s'\n", b, b_target); } g_free (b); g_free (a); return OK; } RESULT test_strjoin () { char *s; s = g_strjoin (NULL, "a", "b", NULL); if (strcmp (s, "ab") != 0) return FAILED ("Join of two strings with no separator fails"); g_free (s); s = g_strjoin ("", "a", "b", NULL); if (strcmp (s, "ab") != 0) return FAILED ("Join of two strings with empty separator fails"); g_free (s); s = g_strjoin ("-", "a", "b", NULL); if (strcmp (s, "a-b") != 0) return FAILED ("Join of two strings with separator fails"); g_free (s); s = g_strjoin ("-", "aaaa", "bbbb", "cccc", "dddd", NULL); if (strcmp (s, "aaaa-bbbb-cccc-dddd") != 0) return FAILED ("Join of multiple strings fails"); g_free (s); s = g_strjoin ("-", NULL); if (s == NULL || (strcmp (s, "") != 0)) return FAILED ("Failed to join empty arguments"); g_free (s); return OK; } RESULT test_strchug () { char *str = g_strdup (" \t\n hola"); g_strchug (str); if (strcmp ("hola", str)) { fprintf (stderr, "%s\n", str); g_free (str); return FAILED ("Failed."); } g_free (str); return OK; } RESULT test_strchomp () { char *str = g_strdup ("hola \t"); g_strchomp (str); if (strcmp ("hola", str)) { fprintf (stderr, "%s\n", str); g_free (str); return FAILED ("Failed."); } g_free (str); return OK; } RESULT test_strstrip () { char *str = g_strdup (" \t hola "); g_strstrip (str); if (strcmp ("hola", str)) { fprintf (stderr, "%s\n", str); g_free (str); return FAILED ("Failed."); } g_free (str); return OK; } #define urit(so,j) do { s = g_filename_to_uri (so, NULL, NULL); if (strcmp (s, j) != 0) return FAILED("Got %s expected %s", s, j); g_free (s); } while (0); #define errit(so) do { s = g_filename_to_uri (so, NULL, NULL); if (s != NULL) return FAILED ("got %s, expected NULL", s); } while (0); RESULT test_filename_to_uri () { char *s; urit ("/a", "file:///a"); urit ("/home/miguel", "file:///home/miguel"); urit ("/home/mig uel", "file:///home/mig%20uel"); urit ("/\303\241", "file:///%C3%A1"); urit ("/\303\241/octal", "file:///%C3%A1/octal"); urit ("/%", "file:///%25"); urit ("/\001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037\040", "file:///%01%02%03%04%05%06%07%08%09%0A%0B%0C%0D%0E%0F%10%11%12%13%14%15%16%17%18%19%1A%1B%1C%1D%1E%1F%20"); urit ("/!$&'()*+,-./", "file:///!$&'()*+,-./"); urit ("/\042\043\045", "file:///%22%23%25"); urit ("/0123456789:=", "file:///0123456789:="); urit ("/\073\074\076\077", "file:///%3B%3C%3E%3F"); urit ("/\133\134\135\136_\140\173\174\175", "file:///%5B%5C%5D%5E_%60%7B%7C%7D"); urit ("/\173\174\175\176\177\200", "file:///%7B%7C%7D~%7F%80"); urit ("/@ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz", "file:///@ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"); errit ("a"); errit ("./hola"); return OK; } #define fileit(so,j) do { s = g_filename_from_uri (so, NULL, NULL); if (strcmp (s, j) != 0) return FAILED("Got %s expected %s", s, j); g_free (s); } while (0); #define ferrit(so) do { s = g_filename_from_uri (so, NULL, NULL); if (s != NULL) return FAILED ("got %s, expected NULL", s); } while (0); RESULT test_filename_from_uri () { char *s; fileit ("file:///a", "/a"); fileit ("file:///%41", "/A"); fileit ("file:///home/miguel", "/home/miguel"); fileit ("file:///home/mig%20uel", "/home/mig uel"); ferrit ("/a"); ferrit ("a"); ferrit ("file://a"); ferrit ("file:a"); ferrit ("file:///%"); ferrit ("file:///%0"); ferrit ("file:///%jj"); return OK; } static Test strutil_tests [] = { {"g_strfreev", test_strfreev}, {"g_strconcat", test_concat}, {"g_strsplit", test_split}, {"g_strreverse", test_strreverse}, {"g_strjoin", test_strjoin}, {"g_strchug", test_strchug}, {"g_strchomp", test_strchomp}, {"g_strstrip", test_strstrip}, {"g_filename_to_uri", test_filename_to_uri}, {"g_filename_from_uri", test_filename_from_uri}, {NULL, NULL} }; DEFINE_TEST_GROUP_INIT(strutil_tests_init, strutil_tests)