test: add test cases for relative_path
Add subcommand "relative_path" in test-path-utils, and add test cases in t0060. Johannes tested an earlier version of this patch on Windows, and found that some relative_path tests should be skipped on Windows. This is because the bash on Windows rewrites arguments of regular Windows programs, such as git and the test helpers, if the arguments look like absolute POSIX paths. As a consequence, the actual tests performed are not what the tests scripts expect. The tests that need *not* be skipped are those where the two paths passed to 'test-path-utils relative_path' have the same prefix and the result is expected to be a relative path. This is because the rewriting changes "/a/b" to "D:/Src/MSysGit/a/b", and when both inputs are extended the same way, this just cancels out in the relative path computation. Signed-off-by: Jiang Xin <worldhello.net@gmail.com> Helped-by: Johannes Sixt <j6t@kdbg.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
0c2b1cf812
commit
203439b284
@ -28,6 +28,19 @@ static int normalize_ceiling_entry(struct string_list_item *item, void *unused)
|
||||
return 1;
|
||||
}
|
||||
|
||||
static void normalize_argv_string(const char **var, const char *input)
|
||||
{
|
||||
if (!strcmp(input, "<null>"))
|
||||
*var = NULL;
|
||||
else if (!strcmp(input, "<empty>"))
|
||||
*var = "";
|
||||
else
|
||||
*var = input;
|
||||
|
||||
if (*var && (**var == '<' || **var == '('))
|
||||
die("Bad value: %s\n", input);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
if (argc == 3 && !strcmp(argv[1], "normalize_path_copy")) {
|
||||
@ -103,6 +116,18 @@ int main(int argc, char **argv)
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (argc == 4 && !strcmp(argv[1], "relative_path")) {
|
||||
const char *in, *prefix, *rel;
|
||||
normalize_argv_string(&in, argv[2]);
|
||||
normalize_argv_string(&prefix, argv[3]);
|
||||
rel = relative_path(in, prefix);
|
||||
if (!rel)
|
||||
puts("(null)");
|
||||
else
|
||||
puts(strlen(rel) > 0 ? rel : "(empty)");
|
||||
return 0;
|
||||
}
|
||||
|
||||
fprintf(stderr, "%s: unknown function name: %s\n", argv[0],
|
||||
argv[1] ? argv[1] : "(there was none)");
|
||||
return 1;
|
||||
|
Reference in New Issue
Block a user