1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
/* Test of concatenation of two arbitrary file names.
Copyright (C) 1996-2007, 2009-2022 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>. */
/* Written by Jim Meyering. */
#include <config.h>
#include "filenamecat.h"
#include "idx.h"
#include <stdbool.h>
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int
main (_GL_UNUSED int argc, char *argv[])
{
static char const *const tests[][3] =
{
{"a", "b", "a/b"},
{"a/", "b", "a/b"},
{"a/", "/b", "a/b"},
{"a", "/b", "a/b"},
{"/", "b", "/b"},
{"/", "/b", "/./b"}, /* This result could be shorter. */
{"/", "/", "/./"}, /* This result could be shorter. */
{"a", "/", "a/"}, /* this might deserve a diagnostic */
{"/a", "/", "/a/"}, /* this might deserve a diagnostic */
{"a", "//b", "a//b"},
{"", "a", "a"}, /* this might deserve a diagnostic */
};
unsigned int i;
bool fail = false;
for (i = 0; i < sizeof tests / sizeof tests[0]; i++)
{
char *base_in_result;
char const *const *t = tests[i];
char *res = file_name_concat (t[0], t[1], &base_in_result);
idx_t prefixlen = base_in_result - res;
size_t t0len = strlen (t[0]);
size_t reslen = strlen (res);
if (strcmp (res, t[2]) != 0)
{
fprintf (stderr, "test #%u: got %s, expected %s\n", i, res, t[2]);
fail = true;
}
if (strcmp (t[1], base_in_result) != 0)
{
fprintf (stderr, "test #%u: base %s != base_in_result %s\n",
i, t[1], base_in_result);
fail = true;
}
if (! (0 <= prefixlen && prefixlen <= reslen))
{
fprintf (stderr, "test #%u: base_in_result is not in result\n", i);
fail = true;
}
if (reslen < t0len || memcmp (res, t[0], t0len) != 0)
{
fprintf (stderr, "test #%u: %s is not a prefix of %s\n",
i, t[0], res);
fail = true;
}
free (res);
}
exit (fail ? EXIT_FAILURE : EXIT_SUCCESS);
}
|