|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From 59ae3a957388bb057c3388ee288c8fc96c2b0098 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From: Thomas Hindoe Paaboel Andersen <phomes@gmail.com>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Date: Tue, 30 Sep 2014 22:18:18 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Subject: [PATCH] test-path-util: fix a mem leak and avoid confusing coverity
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Found with coverity. Fixes CID#1237754 and #1237790
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/test/test-path-util.c | 37 ++++++++++++++++++++++---------------
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
1 file changed, 22 insertions(+), 15 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/test/test-path-util.c b/src/test/test-path-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 01afb3e6fe..63d64b28b0 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/test/test-path-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/test/test-path-util.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -163,17 +163,24 @@ static void test_prefixes(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
static void test_path_join(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join("/root", "/a/b", "/c"), "/root/a/b/c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join("/root", "a/b", "c"), "/root/a/b/c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join("/root", "/a/b", "c"), "/root/a/b/c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join("/root", "/", "c"), "/root//c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join("/root", "/", NULL), "/root/"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join(NULL, "/a/b", "/c"), "/a/b/c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join(NULL, "a/b", "c"), "a/b/c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join(NULL, "/a/b", "c"), "/a/b/c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join(NULL, "/", "c"), "//c"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(path_join(NULL, "/", NULL), "/"));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+#define test_join(root, path, rest, expected) { \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ _cleanup_free_ char *z = NULL; \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ z = path_join(root, path, rest); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert_se(streq(z, expected)); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join("/root", "/a/b", "/c", "/root/a/b/c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join("/root", "a/b", "c", "/root/a/b/c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join("/root", "/a/b", "c", "/root/a/b/c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join("/root", "/", "c", "/root//c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join("/root", "/", NULL, "/root/");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join(NULL, "/a/b", "/c", "/a/b/c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join(NULL, "a/b", "c", "a/b/c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join(NULL, "/a/b", "c", "/a/b/c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join(NULL, "/", "c", "//c");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ test_join(NULL, "/", NULL, "/");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
static void test_fsck_exists(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -192,10 +199,10 @@ static void test_make_relative(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert_se(path_make_relative("some/relative/path", "/some/path", &result) < 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert_se(path_make_relative("/some/path", "some/relative/path", &result) < 0);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
-#define test(from_dir, to_path, expected) { \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- path_make_relative(from_dir, to_path, &result); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- assert_se(streq(result, expected)); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- free(result); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+#define test(from_dir, to_path, expected) { \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ _cleanup_free_ char *z = NULL; \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ path_make_relative(from_dir, to_path, &z); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert_se(streq(z, expected)); \
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
test("/", "/", ".");
|