doc: Fix a debug hint on the keybox format.
[gnupg.git] / common / t-percent.c
1 /* t-percent.c - Module test for percent.c
2  *      Copyright (C) 2008 Free Software Foundation, Inc.
3  *
4  * This file is part of GnuPG.
5  *
6  * GnuPG is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * GnuPG is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, see <https://www.gnu.org/licenses/>.
18  */
19
20 #include <config.h>
21 #include <stdio.h>
22 #include <stdlib.h>
23 #include <assert.h>
24
25 #include "util.h"
26
27 #define pass()  do { ; } while(0)
28 #define fail(a)  do { fprintf (stderr, "%s:%d: test %d failed\n",\
29                                __FILE__,__LINE__, (a));          \
30                      exit (1);                                   \
31                    } while(0)
32
33 static void
34 test_percent_plus_escape (void)
35 {
36   static struct {
37     const char *string;
38     const char *expect;
39   } tbl[] = {
40     {
41       "",
42       ""
43     }, {
44       "a",
45       "a",
46     }, {
47       " ",
48       "+",
49     }, {
50       "  ",
51       "++"
52     }, {
53       "+ +",
54       "%2B+%2B"
55     }, {
56       "\" \"",
57       "%22+%22"
58     }, {
59       "%22",
60       "%2522"
61     }, {
62       "%% ",
63       "%25%25+"
64     }, {
65       "\n ABC\t",
66       "%0A+ABC%09"
67     }, { NULL, NULL }
68   };
69   char *buf, *buf2;
70   int i;
71   size_t len;
72
73   for (i=0; tbl[i].string; i++)
74     {
75       buf = percent_plus_escape (tbl[i].string);
76       if (!buf)
77         {
78           fprintf (stderr, "out of core: %s\n", strerror (errno));
79           exit (2);
80         }
81       if (strcmp (buf, tbl[i].expect))
82         fail (i);
83       buf2 = percent_plus_unescape (buf, 0);
84       if (!buf2)
85         {
86           fprintf (stderr, "out of core: %s\n", strerror (errno));
87           exit (2);
88         }
89       if (strcmp (buf2, tbl[i].string))
90         fail (i);
91       xfree (buf2);
92       /* Now test the inplace conversion.  */
93       len = percent_plus_unescape_inplace (buf, 0);
94       buf[len] = 0;
95       if (strcmp (buf, tbl[i].string))
96         fail (i);
97       xfree (buf);
98     }
99 }
100
101
102 static void
103 test_percent_data_escape (void)
104 {
105   static struct {
106     const char *prefix;
107     const char *data;
108     size_t datalen;
109     const char *expect;
110   } tbl[] = {
111     {
112       NULL,
113       "", 0,
114       ""
115     }, {
116       NULL,
117       "a", 1,
118       "a",
119     }, {
120       NULL,
121       "%22", 3,
122       "%2522"
123     }, {
124       NULL,
125       "%%", 3,
126       "%25%25%00"
127     }, {
128       NULL,
129       "\n \0BC\t", 6,
130       "\n %00BC\t"
131     }, {
132       "",
133       "", 0,
134       ""
135     }, {
136       "",
137       "a", 1,
138       "a",
139     }, {
140       "",
141       "%22", 3,
142       "%2522"
143     }, {
144       "",
145       "%%", 3,
146       "%25%25%00"
147     }, {
148       "",
149       "\n \0BC\t", 6,
150       "\n %00BC\t"
151     }, {
152       "a",
153       "", 0,
154       "a"
155     }, {
156       "a",
157       "a", 1,
158       "aa",
159     }, {
160       "a",
161       "%22", 3,
162       "a%2522"
163     }, {
164       "a",
165       "%%", 3,
166       "a%25%25%00"
167     }, {
168       "a",
169       "\n \0BC\t", 6,
170       "a\n %00BC\t"
171     }, {
172       " ",
173       "%%", 3,
174       " %25%25%00"
175     }, {
176       "+",
177       "%%", 3,
178       "+%25%25%00"
179     }, {
180       "%",
181       "%%", 3,
182       "%25%25%25%00"
183     }, {
184       "a b",
185       "%%", 3,
186       "a b%25%25%00"
187     }, {
188       "a%2Bb",
189       "%%", 3,
190       "a%252Bb%25%25%00"
191     }, {
192       "\n",
193       "%%", 3,
194       "%0A%25%25%00"
195     }, {
196       NULL,
197       NULL, 0,
198       NULL }
199   };
200   char *buf;
201   int i;
202   size_t len, prefixlen;
203
204   for (i=0; tbl[i].data; i++)
205     {
206       buf = percent_data_escape (0, tbl[i].prefix, tbl[i].data, tbl[i].datalen);
207       if (!buf)
208         {
209           fprintf (stderr, "out of core: %s\n", strerror (errno));
210           exit (2);
211         }
212       if (strcmp (buf, tbl[i].expect))
213         {
214           fail (i);
215         }
216       len = percent_plus_unescape_inplace (buf, 0);
217       prefixlen = tbl[i].prefix? strlen (tbl[i].prefix) : 0;
218       if (len != tbl[i].datalen + prefixlen)
219         fail (i);
220       else if (tbl[i].prefix && memcmp (buf, tbl[i].prefix, prefixlen)
221                && !(prefixlen == 1 && *tbl[i].prefix == '+' && *buf == ' '))
222         {
223           /* Note extra condition above handles the one test case
224            * which reverts a plus to a space due to the use of the
225            * plus-unescape fucntion also for the prefix part.  */
226           fail (i);
227         }
228       else if (memcmp (buf+prefixlen, tbl[i].data, tbl[i].datalen))
229         {
230           fail (i);
231         }
232       xfree (buf);
233     }
234 }
235
236
237
238 static void
239 test_percent_data_escape_plus (void)
240 {
241   static struct {
242     const char *data;
243     size_t datalen;
244     const char *expect;
245   } tbl[] = {
246     {
247       "", 0,
248       ""
249     }, {
250       "a", 1,
251       "a",
252     }, {
253       "%22", 3,
254       "%2522"
255     }, {
256       "%%", 3,
257       "%25%25%00"
258     }, {
259       "\n \0BC\t", 6,
260       "%0A+%00BC%09"
261     }, {
262       " ", 1,
263       "+"
264     }, {
265       "  ", 2,
266       "++"
267     }, {
268       "+ +", 3,
269       "%2B+%2B"
270     }, {
271       "\" \"", 3,  /* Note: This function does not escape quotes.  */
272       "\"+\""
273     }, {
274       "%22", 3,
275       "%2522"
276     }, {
277       "%% ", 3,
278       "%25%25+"
279     }, {
280       "\n ABC\t", 6,
281       "%0A+ABC%09"
282     }, { NULL, 0, NULL }
283   };
284   char *buf;
285   int i;
286   size_t len;
287
288   for (i=0; tbl[i].data; i++)
289     {
290       buf = percent_data_escape (1, NULL, tbl[i].data, tbl[i].datalen);
291       if (!buf)
292         {
293           fprintf (stderr, "out of core: %s\n", strerror (errno));
294           exit (2);
295         }
296       if (strcmp (buf, tbl[i].expect))
297         {
298           fail (i);
299         }
300       len = percent_plus_unescape_inplace (buf, 0);
301       if (len != tbl[i].datalen)
302         fail (i);
303       else if (memcmp (buf, tbl[i].data, tbl[i].datalen))
304         fail (i);
305       xfree (buf);
306     }
307 }
308
309
310 int
311 main (int argc, char **argv)
312 {
313   (void)argc;
314   (void)argv;
315
316   /* FIXME: escape_unescape is not tested - only percent_plus_unescape.  */
317   test_percent_plus_escape ();
318   test_percent_data_escape ();
319   test_percent_data_escape_plus ();
320   return 0;
321 }