diff options
Diffstat (limited to 'test/paths.c')
-rw-r--r-- | test/paths.c | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/test/paths.c b/test/paths.c new file mode 100644 index 0000000000..5ec2eb8859 --- /dev/null +++ b/test/paths.c @@ -0,0 +1,48 @@ +#include "common/common.h" +#include "config.h" +#include "options/path.h" +#include "tests.h" + +static void test_join(char *file, int line, char *a, char *b, char *c) +{ + char *res = mp_path_join(NULL, a, b); + if (strcmp(res, c) != 0) { + printf("%s:%d: '%s' + '%s' = '%s', expected '%s'\n", file, line, + a, b, res, c); + abort(); + } + talloc_free(res); +} + +#define TEST_JOIN(a, b, c) \ + test_join(__FILE__, __LINE__, a, b, c); + +static void run(struct test_ctx *ctx) +{ + TEST_JOIN("", "", ""); + TEST_JOIN("a", "", "a"); + TEST_JOIN("/a", "", "/a"); + TEST_JOIN("", "b", "b"); + TEST_JOIN("", "/b", "/b"); + TEST_JOIN("ab", "cd", "ab/cd"); + TEST_JOIN("ab/", "cd", "ab/cd"); + TEST_JOIN("ab/", "/cd", "/cd"); + // Note: we prefer "/" on win32, but tolerate "\". +#if HAVE_DOS_PATHS + TEST_JOIN("ab\\", "cd", "ab\\cd"); + TEST_JOIN("ab\\", "\\cd", "\\cd"); + TEST_JOIN("c:/", "de", "c:/de"); + TEST_JOIN("c:/a", "de", "c:/a/de"); + TEST_JOIN("c:\\a", "c:\\b", "c:\\b"); + TEST_JOIN("c:/a", "c:/b", "c:/b"); + // Note: drive-relative paths are not always supported "properly" + TEST_JOIN("c:/a", "d:b", "d:b"); + TEST_JOIN("c:a", "b", "c:a/b"); + TEST_JOIN("c:", "b", "c:b"); +#endif +} + +const struct unittest test_paths = { + .name = "paths", + .run = run, +}; |