~ubuntu-branches/ubuntu/natty/curl/natty

« back to all changes in this revision

Viewing changes to tests/libtest/lib557.c

  • Committer: Bazaar Package Importer
  • Author(s): Bhavani Shankar
  • Date: 2010-06-20 13:56:28 UTC
  • mfrom: (3.4.7 sid)
  • Revision ID: james.westby@ubuntu.com-20100620135628-e30tp9jldq6hq985
Tags: 7.21.0-1ubuntu1
* Merge from debian unstable.  Remaining changes: LP: #596334
  - Keep build deps in main:
    - Drop build dependencies: stunnel, libssh2-1-dev
    - Add build-dependency on openssh-server
    - Drop libssh2-1-dev from libcurl4-openssl-dev's Depends.

Show diffs side-by-side

added added

removed removed

Lines of Context:
5
5
 *                            | (__| |_| |  _ <| |___
6
6
 *                             \___|\___/|_| \_\_____|
7
7
 *
8
 
 * $Id: lib557.c,v 1.7 2008-09-21 03:48:25 yangtse Exp $
9
8
 */
10
9
 
11
10
/*
37
36
 
38
37
 
39
38
#define BUFSZ    256
 
39
#define USHORT_TESTS_ARRSZ 1 + 100
 
40
#define SSHORT_TESTS_ARRSZ 1 + 100
40
41
#define UINT_TESTS_ARRSZ   1 + 100
41
42
#define SINT_TESTS_ARRSZ   1 + 100
42
43
#define ULONG_TESTS_ARRSZ  1 + 100
44
45
#define COFFT_TESTS_ARRSZ  1 + 100
45
46
 
46
47
 
 
48
struct unsshort_st {
 
49
  unsigned short num;   /* unsigned short  */
 
50
  const char *expected; /* expected string */
 
51
  char result[BUFSZ];   /* result string   */
 
52
};
 
53
 
 
54
 
 
55
struct sigshort_st {
 
56
  short num;            /* signed short    */
 
57
  const char *expected; /* expected string */
 
58
  char result[BUFSZ];   /* result string   */
 
59
};
 
60
 
 
61
 
47
62
struct unsint_st {
48
63
  unsigned int num;     /* unsigned int    */
49
64
  const char *expected; /* expected string */
79
94
};
80
95
 
81
96
 
82
 
static struct unsint_st  ui_test[UINT_TESTS_ARRSZ];
83
 
static struct sigint_st  si_test[SINT_TESTS_ARRSZ];
84
 
static struct unslong_st ul_test[ULONG_TESTS_ARRSZ];
85
 
static struct siglong_st sl_test[SLONG_TESTS_ARRSZ];
86
 
static struct curloff_st co_test[COFFT_TESTS_ARRSZ];
 
97
static struct unsshort_st us_test[USHORT_TESTS_ARRSZ];
 
98
static struct sigshort_st ss_test[SSHORT_TESTS_ARRSZ];
 
99
static struct unsint_st   ui_test[UINT_TESTS_ARRSZ];
 
100
static struct sigint_st   si_test[SINT_TESTS_ARRSZ];
 
101
static struct unslong_st  ul_test[ULONG_TESTS_ARRSZ];
 
102
static struct siglong_st  sl_test[SLONG_TESTS_ARRSZ];
 
103
static struct curloff_st  co_test[COFFT_TESTS_ARRSZ];
 
104
 
 
105
 
 
106
static int test_unsigned_short_formatting(void)
 
107
{
 
108
  int i, j;
 
109
  int num_ushort_tests;
 
110
  int failed = 0;
 
111
 
 
112
#if (SIZEOF_SHORT == 1)
 
113
 
 
114
  i=1; us_test[i].num = 0xFFU; us_test[i].expected = "256";
 
115
  i++; us_test[i].num = 0xF0U; us_test[i].expected = "240";
 
116
  i++; us_test[i].num = 0x0FU; us_test[i].expected = "15";
 
117
 
 
118
  i++; us_test[i].num = 0xE0U; us_test[i].expected = "224";
 
119
  i++; us_test[i].num = 0x0EU; us_test[i].expected = "14";
 
120
 
 
121
  i++; us_test[i].num = 0xC0U; us_test[i].expected = "192";
 
122
  i++; us_test[i].num = 0x0CU; us_test[i].expected = "12";
 
123
 
 
124
  i++; us_test[i].num = 0x01U; us_test[i].expected = "1";
 
125
  i++; us_test[i].num = 0x00U; us_test[i].expected = "0";
 
126
 
 
127
  num_ushort_tests = i;
 
128
 
 
129
#elif (SIZEOF_SHORT == 2)
 
130
 
 
131
  i=1; us_test[i].num = 0xFFFFU; us_test[i].expected = "65535";
 
132
  i++; us_test[i].num = 0xFF00U; us_test[i].expected = "65280";
 
133
  i++; us_test[i].num = 0x00FFU; us_test[i].expected = "255";
 
134
 
 
135
  i++; us_test[i].num = 0xF000U; us_test[i].expected = "61440";
 
136
  i++; us_test[i].num = 0x0F00U; us_test[i].expected = "3840";
 
137
  i++; us_test[i].num = 0x00F0U; us_test[i].expected = "240";
 
138
  i++; us_test[i].num = 0x000FU; us_test[i].expected = "15";
 
139
 
 
140
  i++; us_test[i].num = 0xC000U; us_test[i].expected = "49152";
 
141
  i++; us_test[i].num = 0x0C00U; us_test[i].expected = "3072";
 
142
  i++; us_test[i].num = 0x00C0U; us_test[i].expected = "192";
 
143
  i++; us_test[i].num = 0x000CU; us_test[i].expected = "12";
 
144
 
 
145
  i++; us_test[i].num = 0x0001U; us_test[i].expected = "1";
 
146
  i++; us_test[i].num = 0x0000U; us_test[i].expected = "0";
 
147
 
 
148
  num_ushort_tests = i;
 
149
 
 
150
#elif (SIZEOF_SHORT == 4)
 
151
 
 
152
  i=1; us_test[i].num = 0xFFFFFFFFU; us_test[i].expected = "4294967295";
 
153
  i++; us_test[i].num = 0xFFFF0000U; us_test[i].expected = "4294901760";
 
154
  i++; us_test[i].num = 0x0000FFFFU; us_test[i].expected = "65535";
 
155
 
 
156
  i++; us_test[i].num = 0xFF000000U; us_test[i].expected = "4278190080";
 
157
  i++; us_test[i].num = 0x00FF0000U; us_test[i].expected = "16711680";
 
158
  i++; us_test[i].num = 0x0000FF00U; us_test[i].expected = "65280";
 
159
  i++; us_test[i].num = 0x000000FFU; us_test[i].expected = "255";
 
160
 
 
161
  i++; us_test[i].num = 0xF0000000U; us_test[i].expected = "4026531840";
 
162
  i++; us_test[i].num = 0x0F000000U; us_test[i].expected = "251658240";
 
163
  i++; us_test[i].num = 0x00F00000U; us_test[i].expected = "15728640";
 
164
  i++; us_test[i].num = 0x000F0000U; us_test[i].expected = "983040";
 
165
  i++; us_test[i].num = 0x0000F000U; us_test[i].expected = "61440";
 
166
  i++; us_test[i].num = 0x00000F00U; us_test[i].expected = "3840";
 
167
  i++; us_test[i].num = 0x000000F0U; us_test[i].expected = "240";
 
168
  i++; us_test[i].num = 0x0000000FU; us_test[i].expected = "15";
 
169
 
 
170
  i++; us_test[i].num = 0xC0000000U; us_test[i].expected = "3221225472";
 
171
  i++; us_test[i].num = 0x0C000000U; us_test[i].expected = "201326592";
 
172
  i++; us_test[i].num = 0x00C00000U; us_test[i].expected = "12582912";
 
173
  i++; us_test[i].num = 0x000C0000U; us_test[i].expected = "786432";
 
174
  i++; us_test[i].num = 0x0000C000U; us_test[i].expected = "49152";
 
175
  i++; us_test[i].num = 0x00000C00U; us_test[i].expected = "3072";
 
176
  i++; us_test[i].num = 0x000000C0U; us_test[i].expected = "192";
 
177
  i++; us_test[i].num = 0x0000000CU; us_test[i].expected = "12";
 
178
 
 
179
  i++; us_test[i].num = 0x00000001U; us_test[i].expected = "1";
 
180
  i++; us_test[i].num = 0x00000000U; us_test[i].expected = "0";
 
181
 
 
182
  num_ushort_tests = i;
 
183
 
 
184
#endif
 
185
 
 
186
  for(i=1; i<=num_ushort_tests; i++) {
 
187
 
 
188
    for(j=0; j<BUFSZ; j++)
 
189
      us_test[i].result[j] = 'X';
 
190
    us_test[i].result[BUFSZ-1] = '\0';
 
191
 
 
192
    (void)curl_msprintf(us_test[i].result, "%hu", us_test[i].num);
 
193
 
 
194
    if(memcmp(us_test[i].result,
 
195
               us_test[i].expected,
 
196
               strlen(us_test[i].expected))) {
 
197
      printf("unsigned short test #%.2d: Failed (Expected: %s Got: %s)\n",
 
198
             i, us_test[i].expected, us_test[i].result);
 
199
      failed++;
 
200
    }
 
201
 
 
202
  }
 
203
 
 
204
  if(!failed)
 
205
    printf("All curl_mprintf() unsigned short tests OK!\n");
 
206
  else
 
207
    printf("Some curl_mprintf() unsigned short tests Failed!\n");
 
208
 
 
209
  return failed;
 
210
}
 
211
 
 
212
 
 
213
static int test_signed_short_formatting(void)
 
214
{
 
215
  int i, j;
 
216
  int num_sshort_tests;
 
217
  int failed = 0;
 
218
 
 
219
#if (SIZEOF_SHORT == 1)
 
220
 
 
221
  i=1; ss_test[i].num = 0x7F; ss_test[i].expected = "127";
 
222
 
 
223
  i++; ss_test[i].num = 0x70; ss_test[i].expected = "112";
 
224
  i++; ss_test[i].num = 0x07; ss_test[i].expected = "7";
 
225
 
 
226
  i++; ss_test[i].num = 0x50; ss_test[i].expected = "80";
 
227
  i++; ss_test[i].num = 0x05; ss_test[i].expected = "5";
 
228
 
 
229
  i++; ss_test[i].num = 0x01; ss_test[i].expected = "1";
 
230
  i++; ss_test[i].num = 0x00; ss_test[i].expected = "0";
 
231
 
 
232
  i++; ss_test[i].num = -0x7F -1; ss_test[i].expected = "-128";
 
233
 
 
234
  i++; ss_test[i].num = -0x70 -1; ss_test[i].expected = "-113";
 
235
  i++; ss_test[i].num = -0x07 -1; ss_test[i].expected = "-8";
 
236
 
 
237
  i++; ss_test[i].num = -0x50 -1; ss_test[i].expected = "-81";
 
238
  i++; ss_test[i].num = -0x05 -1; ss_test[i].expected = "-6";
 
239
 
 
240
  i++; ss_test[i].num =  0x00 -1; ss_test[i].expected = "-1";
 
241
 
 
242
  num_sshort_tests = i;
 
243
 
 
244
#elif (SIZEOF_SHORT == 2)
 
245
 
 
246
  i=1; ss_test[i].num = 0x7FFF; ss_test[i].expected = "32767";
 
247
  i++; ss_test[i].num = 0x7FFE; ss_test[i].expected = "32766";
 
248
  i++; ss_test[i].num = 0x7FFD; ss_test[i].expected = "32765";
 
249
  i++; ss_test[i].num = 0x7F00; ss_test[i].expected = "32512";
 
250
  i++; ss_test[i].num = 0x07F0; ss_test[i].expected = "2032";
 
251
  i++; ss_test[i].num = 0x007F; ss_test[i].expected = "127";
 
252
 
 
253
  i++; ss_test[i].num = 0x7000; ss_test[i].expected = "28672";
 
254
  i++; ss_test[i].num = 0x0700; ss_test[i].expected = "1792";
 
255
  i++; ss_test[i].num = 0x0070; ss_test[i].expected = "112";
 
256
  i++; ss_test[i].num = 0x0007; ss_test[i].expected = "7";
 
257
 
 
258
  i++; ss_test[i].num = 0x5000; ss_test[i].expected = "20480";
 
259
  i++; ss_test[i].num = 0x0500; ss_test[i].expected = "1280";
 
260
  i++; ss_test[i].num = 0x0050; ss_test[i].expected = "80";
 
261
  i++; ss_test[i].num = 0x0005; ss_test[i].expected = "5";
 
262
 
 
263
  i++; ss_test[i].num = 0x0001; ss_test[i].expected = "1";
 
264
  i++; ss_test[i].num = 0x0000; ss_test[i].expected = "0";
 
265
 
 
266
  i++; ss_test[i].num = -0x7FFF -1; ss_test[i].expected = "-32768";
 
267
  i++; ss_test[i].num = -0x7FFE -1; ss_test[i].expected = "-32767";
 
268
  i++; ss_test[i].num = -0x7FFD -1; ss_test[i].expected = "-32766";
 
269
  i++; ss_test[i].num = -0x7F00 -1; ss_test[i].expected = "-32513";
 
270
  i++; ss_test[i].num = -0x07F0 -1; ss_test[i].expected = "-2033";
 
271
  i++; ss_test[i].num = -0x007F -1; ss_test[i].expected = "-128";
 
272
 
 
273
  i++; ss_test[i].num = -0x7000 -1; ss_test[i].expected = "-28673";
 
274
  i++; ss_test[i].num = -0x0700 -1; ss_test[i].expected = "-1793";
 
275
  i++; ss_test[i].num = -0x0070 -1; ss_test[i].expected = "-113";
 
276
  i++; ss_test[i].num = -0x0007 -1; ss_test[i].expected = "-8";
 
277
 
 
278
  i++; ss_test[i].num = -0x5000 -1; ss_test[i].expected = "-20481";
 
279
  i++; ss_test[i].num = -0x0500 -1; ss_test[i].expected = "-1281";
 
280
  i++; ss_test[i].num = -0x0050 -1; ss_test[i].expected = "-81";
 
281
  i++; ss_test[i].num = -0x0005 -1; ss_test[i].expected = "-6";
 
282
 
 
283
  i++; ss_test[i].num =  0x0000 -1; ss_test[i].expected = "-1";
 
284
 
 
285
  num_sshort_tests = i;
 
286
 
 
287
#elif (SIZEOF_SHORT == 4)
 
288
 
 
289
  i=1; ss_test[i].num = 0x7FFFFFFF; ss_test[i].expected = "2147483647";
 
290
  i++; ss_test[i].num = 0x7FFFFFFE; ss_test[i].expected = "2147483646";
 
291
  i++; ss_test[i].num = 0x7FFFFFFD; ss_test[i].expected = "2147483645";
 
292
  i++; ss_test[i].num = 0x7FFF0000; ss_test[i].expected = "2147418112";
 
293
  i++; ss_test[i].num = 0x00007FFF; ss_test[i].expected = "32767";
 
294
 
 
295
  i++; ss_test[i].num = 0x7F000000; ss_test[i].expected = "2130706432";
 
296
  i++; ss_test[i].num = 0x007F0000; ss_test[i].expected = "8323072";
 
297
  i++; ss_test[i].num = 0x00007F00; ss_test[i].expected = "32512";
 
298
  i++; ss_test[i].num = 0x0000007F; ss_test[i].expected = "127";
 
299
 
 
300
  i++; ss_test[i].num = 0x70000000; ss_test[i].expected = "1879048192";
 
301
  i++; ss_test[i].num = 0x07000000; ss_test[i].expected = "117440512";
 
302
  i++; ss_test[i].num = 0x00700000; ss_test[i].expected = "7340032";
 
303
  i++; ss_test[i].num = 0x00070000; ss_test[i].expected = "458752";
 
304
  i++; ss_test[i].num = 0x00007000; ss_test[i].expected = "28672";
 
305
  i++; ss_test[i].num = 0x00000700; ss_test[i].expected = "1792";
 
306
  i++; ss_test[i].num = 0x00000070; ss_test[i].expected = "112";
 
307
  i++; ss_test[i].num = 0x00000007; ss_test[i].expected = "7";
 
308
 
 
309
  i++; ss_test[i].num = 0x50000000; ss_test[i].expected = "1342177280";
 
310
  i++; ss_test[i].num = 0x05000000; ss_test[i].expected = "83886080";
 
311
  i++; ss_test[i].num = 0x00500000; ss_test[i].expected = "5242880";
 
312
  i++; ss_test[i].num = 0x00050000; ss_test[i].expected = "327680";
 
313
  i++; ss_test[i].num = 0x00005000; ss_test[i].expected = "20480";
 
314
  i++; ss_test[i].num = 0x00000500; ss_test[i].expected = "1280";
 
315
  i++; ss_test[i].num = 0x00000050; ss_test[i].expected = "80";
 
316
  i++; ss_test[i].num = 0x00000005; ss_test[i].expected = "5";
 
317
 
 
318
  i++; ss_test[i].num = 0x00000001; ss_test[i].expected = "1";
 
319
  i++; ss_test[i].num = 0x00000000; ss_test[i].expected = "0";
 
320
 
 
321
  i++; ss_test[i].num = -0x7FFFFFFF -1; ss_test[i].expected = "-2147483648";
 
322
  i++; ss_test[i].num = -0x7FFFFFFE -1; ss_test[i].expected = "-2147483647";
 
323
  i++; ss_test[i].num = -0x7FFFFFFD -1; ss_test[i].expected = "-2147483646";
 
324
  i++; ss_test[i].num = -0x7FFF0000 -1; ss_test[i].expected = "-2147418113";
 
325
  i++; ss_test[i].num = -0x00007FFF -1; ss_test[i].expected = "-32768";
 
326
 
 
327
  i++; ss_test[i].num = -0x7F000000 -1; ss_test[i].expected = "-2130706433";
 
328
  i++; ss_test[i].num = -0x007F0000 -1; ss_test[i].expected = "-8323073";
 
329
  i++; ss_test[i].num = -0x00007F00 -1; ss_test[i].expected = "-32513";
 
330
  i++; ss_test[i].num = -0x0000007F -1; ss_test[i].expected = "-128";
 
331
 
 
332
  i++; ss_test[i].num = -0x70000000 -1; ss_test[i].expected = "-1879048193";
 
333
  i++; ss_test[i].num = -0x07000000 -1; ss_test[i].expected = "-117440513";
 
334
  i++; ss_test[i].num = -0x00700000 -1; ss_test[i].expected = "-7340033";
 
335
  i++; ss_test[i].num = -0x00070000 -1; ss_test[i].expected = "-458753";
 
336
  i++; ss_test[i].num = -0x00007000 -1; ss_test[i].expected = "-28673";
 
337
  i++; ss_test[i].num = -0x00000700 -1; ss_test[i].expected = "-1793";
 
338
  i++; ss_test[i].num = -0x00000070 -1; ss_test[i].expected = "-113";
 
339
  i++; ss_test[i].num = -0x00000007 -1; ss_test[i].expected = "-8";
 
340
 
 
341
  i++; ss_test[i].num = -0x50000000 -1; ss_test[i].expected = "-1342177281";
 
342
  i++; ss_test[i].num = -0x05000000 -1; ss_test[i].expected = "-83886081";
 
343
  i++; ss_test[i].num = -0x00500000 -1; ss_test[i].expected = "-5242881";
 
344
  i++; ss_test[i].num = -0x00050000 -1; ss_test[i].expected = "-327681";
 
345
  i++; ss_test[i].num = -0x00005000 -1; ss_test[i].expected = "-20481";
 
346
  i++; ss_test[i].num = -0x00000500 -1; ss_test[i].expected = "-1281";
 
347
  i++; ss_test[i].num = -0x00000050 -1; ss_test[i].expected = "-81";
 
348
  i++; ss_test[i].num = -0x00000005 -1; ss_test[i].expected = "-6";
 
349
 
 
350
  i++; ss_test[i].num =  0x00000000 -1; ss_test[i].expected = "-1";
 
351
 
 
352
  num_sshort_tests = i;
 
353
 
 
354
#endif
 
355
 
 
356
  for(i=1; i<=num_sshort_tests; i++) {
 
357
 
 
358
    for(j=0; j<BUFSZ; j++)
 
359
      ss_test[i].result[j] = 'X';
 
360
    ss_test[i].result[BUFSZ-1] = '\0';
 
361
 
 
362
    (void)curl_msprintf(ss_test[i].result, "%hd", ss_test[i].num);
 
363
 
 
364
    if(memcmp(ss_test[i].result,
 
365
              ss_test[i].expected,
 
366
              strlen(ss_test[i].expected))) {
 
367
      printf("signed short test #%.2d: Failed (Expected: %s Got: %s)\n",
 
368
             i, ss_test[i].expected, ss_test[i].result);
 
369
      failed++;
 
370
    }
 
371
 
 
372
  }
 
373
 
 
374
  if(!failed)
 
375
    printf("All curl_mprintf() signed short tests OK!\n");
 
376
  else
 
377
    printf("Some curl_mprintf() signed short tests Failed!\n");
 
378
 
 
379
  return failed;
 
380
}
87
381
 
88
382
 
89
383
static int test_unsigned_int_formatting(void)
1073
1367
  int errors = 0;
1074
1368
  (void)URL; /* not used */
1075
1369
 
 
1370
  errors += test_unsigned_short_formatting();
 
1371
 
 
1372
  errors += test_signed_short_formatting();
 
1373
 
1076
1374
  errors += test_unsigned_int_formatting();
1077
1375
 
1078
1376
  errors += test_signed_int_formatting();