This source file includes following definitions.
- main
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 #include <config.h>
18
19 #include <string.h>
20
21 #include "signature.h"
22 SIGNATURE_CHECK (strerror_r, int, (int, char *, size_t));
23
24 #include <errno.h>
25
26 #include "macros.h"
27
28 int
29 main (void)
30 {
31 char buf[100];
32 int ret;
33
34
35
36 errno = 0;
37 buf[0] = '\0';
38 ASSERT (strerror_r (EACCES, buf, sizeof buf) == 0);
39 ASSERT (buf[0] != '\0');
40 ASSERT (errno == 0);
41 ASSERT (strlen (buf) < sizeof buf);
42
43 errno = 0;
44 buf[0] = '\0';
45 ASSERT (strerror_r (ETIMEDOUT, buf, sizeof buf) == 0);
46 ASSERT (buf[0] != '\0');
47 ASSERT (errno == 0);
48 ASSERT (strlen (buf) < sizeof buf);
49
50 errno = 0;
51 buf[0] = '\0';
52 ASSERT (strerror_r (EOVERFLOW, buf, sizeof buf) == 0);
53 ASSERT (buf[0] != '\0');
54 ASSERT (errno == 0);
55 ASSERT (strlen (buf) < sizeof buf);
56
57
58
59
60
61 errno = 0;
62 buf[0] = '\0';
63 ret = strerror_r (0, buf, sizeof buf);
64 ASSERT (ret == 0);
65 ASSERT (buf[0]);
66 ASSERT (errno == 0);
67 ASSERT (strstr (buf, "nknown") == NULL);
68 ASSERT (strstr (buf, "ndefined") == NULL);
69
70
71
72
73 errno = 0;
74 buf[0] = '^';
75 ret = strerror_r (-3, buf, sizeof buf);
76 ASSERT (ret == 0 || ret == EINVAL);
77 ASSERT (buf[0] != '^');
78 ASSERT (*buf);
79 ASSERT (errno == 0);
80 ASSERT (strlen (buf) < sizeof buf);
81
82
83
84
85
86
87
88
89 {
90 int errs[] = { EACCES, 0, -3, };
91 int j;
92
93 buf[sizeof buf - 1] = '\0';
94 for (j = 0; j < SIZEOF (errs); j++)
95 {
96 int err = errs[j];
97 char buf2[sizeof buf] = "";
98 size_t len;
99 size_t i;
100
101 strerror_r (err, buf2, sizeof buf2);
102 len = strlen (buf2);
103 ASSERT (len < sizeof buf);
104
105 for (i = 0; i <= len; i++)
106 {
107 memset (buf, '^', sizeof buf - 1);
108 errno = 0;
109 ret = strerror_r (err, buf, i);
110 ASSERT (errno == 0);
111 if (j == 2)
112 ASSERT (ret == ERANGE || ret == EINVAL);
113 else
114 ASSERT (ret == ERANGE);
115 if (i)
116 {
117 ASSERT (strncmp (buf, buf2, i - 1) == 0);
118 ASSERT (buf[i - 1] == '\0');
119 }
120 ASSERT (strspn (buf + i, "^") == sizeof buf - 1 - i);
121 }
122
123 strcpy (buf, "BADFACE");
124 errno = 0;
125 ret = strerror_r (err, buf, len + 1);
126 ASSERT (ret != ERANGE);
127 ASSERT (errno == 0);
128 ASSERT (strcmp (buf, buf2) == 0);
129 }
130 }
131
132 #if GNULIB_STRERROR
133
134
135
136 {
137 const char *msg1;
138 const char *msg2;
139 const char *msg3;
140 const char *msg4;
141 char *str1;
142 char *str2;
143 char *str3;
144 char *str4;
145
146 msg1 = strerror (ENOENT);
147 ASSERT (msg1);
148 str1 = strdup (msg1);
149 ASSERT (str1);
150
151 msg2 = strerror (ERANGE);
152 ASSERT (msg2);
153 str2 = strdup (msg2);
154 ASSERT (str2);
155
156 msg3 = strerror (-4);
157 ASSERT (msg3);
158 str3 = strdup (msg3);
159 ASSERT (str3);
160
161 msg4 = strerror (1729576);
162 ASSERT (msg4);
163 str4 = strdup (msg4);
164 ASSERT (str4);
165
166 strerror_r (EACCES, buf, sizeof buf);
167 strerror_r (-5, buf, sizeof buf);
168 ASSERT (STREQ (msg4, str4));
169
170 free (str1);
171 free (str2);
172 free (str3);
173 free (str4);
174 }
175 #endif
176
177 return 0;
178 }