Convert observers to C++
[deliverable/binutils-gdb.git] / gdb / testsuite / gdb.base / fileio.c
CommitLineData
6aeb981f
CV
1#include <stdio.h>
2#include <stdlib.h>
3#include <string.h>
4#include <sys/errno.h>
5#include <sys/types.h>
6#include <sys/fcntl.h>
7#include <sys/stat.h>
8#include <sys/time.h>
b257a0d3
AC
9#include <errno.h>
10#include <sys/wait.h>
4d074752 11#include <unistd.h>
a59add0c 12#include <time.h>
b257a0d3 13/* TESTS :
6aeb981f
CV
14 * - open(const char *pathname, int flags, mode_t mode);
151) Attempt to create file that already exists - EEXIST
162) Attempt to open a directory for writing - EISDIR
173) Pathname does not exist - ENOENT
184) Open for write but no write permission - EACCES
19
20read(int fd, void *buf, size_t count);
211) Read using invalid file descriptor - EBADF
22
23write(int fd, const void *buf, size_t count);
241) Write using invalid file descriptor - EBADF
252) Attempt to write to read-only file - EBADF
26
27lseek(int fildes, off_t offset, int whence);
281) Seeking on an invalid file descriptor - EBADF
292) Invalid "whence" (3rd param) value - EINVAL
30
31close(int fd);
321) Attempt to close an invalid file descriptor - EBADF
33
34stat(const char *file_name, struct stat *buf);
351) Pathname is a null string - ENOENT
362) Pathname does not exist - ENOENT
37
38fstat(int filedes, struct stat *buf);
391) Attempt to stat using an invalid file descriptor - EBADF
40
41isatty (int desc);
42Not applicable. We will test that it returns 1 when expected and a case
43where it should return 0.
44
45rename(const char *oldpath, const char *newpath);
461) newpath is an existing directory, but oldpath is not a directory. - EISDIR
472) newpath is a non-empty directory. - ENOTEMPTY or EEXIST
483) newpath is a subdirectory of old path. - EINVAL
494) oldpath does not exist. - ENOENT
50
51unlink(const char *pathname);
521) pathname does not have write access. - EACCES
532) pathname does not exist. - ENOENT
54
55time(time_t *t);
56Not applicable.
57
58system (const char * string);
9f5a4cef
HZ
591) See if shell available - returns 0
602) See if shell available - returns !0
613) Execute simple shell command - returns 0
624) Invalid string/command. - returns 127. */
63
b257a0d3 64static const char *strerrno (int err);
6aeb981f 65
b44b82af 66/* Note that OUTDIR is defined by the test suite. */
6aeb981f
CV
67#define FILENAME "foo.fileio.test"
68#define RENAMED "bar.fileio.test"
69#define NONEXISTANT "nofoo.fileio.test"
70#define NOWRITE "nowrt.fileio.test"
6aeb981f
CV
71#define TESTDIR1 "dir1.fileio.test"
72#define TESTDIR2 "dir2.fileio.test"
73#define TESTSUBDIR "dir1.fileio.test/subdir.fileio.test"
74
75#define STRING "Hello World"
76
c8f6abd1 77static void stop (void) {}
e1c2defa 78
d2a03b77
PA
79/* A NULL string. We pass this to stat below instead of a NULL
80 literal to avoid -Wnonnull warnings. */
81const char *null_str;
82
c8f6abd1
PA
83void
84test_open (void)
6aeb981f
CV
85{
86 int ret;
87
88 /* Test opening */
89 errno = 0;
b44b82af 90 ret = open (OUTDIR FILENAME, O_CREAT | O_TRUNC | O_RDWR, S_IWUSR | S_IRUSR);
6aeb981f
CV
91 printf ("open 1: ret = %d, errno = %d %s\n", ret, errno,
92 ret >= 0 ? "OK" : "");
e1c2defa 93
6aeb981f
CV
94 if (ret >= 0)
95 close (ret);
e1c2defa 96 stop ();
6aeb981f
CV
97 /* Creating an already existing file (created by fileio.exp) */
98 errno = 0;
b44b82af 99 ret = open (OUTDIR FILENAME, O_CREAT | O_EXCL | O_WRONLY, S_IWUSR | S_IRUSR);
6aeb981f 100 printf ("open 2: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 101 strerrno (errno));
6aeb981f
CV
102 if (ret >= 0)
103 close (ret);
e1c2defa 104 stop ();
6aeb981f
CV
105 /* Open directory (for writing) */
106 errno = 0;
107 ret = open (".", O_WRONLY);
108 printf ("open 3: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 109 strerrno (errno));
6aeb981f
CV
110 if (ret >= 0)
111 close (ret);
e1c2defa 112 stop ();
6aeb981f
CV
113 /* Opening nonexistant file */
114 errno = 0;
115 ret = open (NONEXISTANT, O_RDONLY);
116 printf ("open 4: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 117 strerrno (errno));
6aeb981f
CV
118 if (ret >= 0)
119 close (ret);
e1c2defa 120 stop ();
6aeb981f
CV
121 /* Open for write but no write permission */
122 errno = 0;
b44b82af 123 ret = open (OUTDIR NOWRITE, O_CREAT | O_RDONLY, S_IRUSR);
6aeb981f
CV
124 if (ret >= 0)
125 {
126 close (ret);
e1c2defa 127 stop ();
6aeb981f 128 errno = 0;
b44b82af 129 ret = open (OUTDIR NOWRITE, O_WRONLY);
6aeb981f 130 printf ("open 5: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 131 strerrno (errno));
6aeb981f
CV
132 if (ret >= 0)
133 close (ret);
134 }
135 else
e1c2defa
NS
136 {
137 stop ();
138 printf ("open 5: ret = %d, errno = %d\n", ret, errno);
139 }
140 stop ();
6aeb981f
CV
141}
142
c8f6abd1
PA
143void
144test_write (void)
6aeb981f
CV
145{
146 int fd, ret;
147
148 /* Test writing */
149 errno = 0;
b44b82af 150 fd = open (OUTDIR FILENAME, O_WRONLY);
6aeb981f
CV
151 if (fd >= 0)
152 {
153 errno = 0;
154 ret = write (fd, STRING, strlen (STRING));
155 printf ("write 1: ret = %d, errno = %d %s\n", ret, errno,
156 ret == strlen (STRING) ? "OK" : "");
157 close (fd);
158 }
159 else
59cc050d 160 printf ("write 1: errno = %d\n", errno);
e1c2defa 161 stop ();
6aeb981f
CV
162 /* Write using invalid file descriptor */
163 errno = 0;
164 ret = write (999, STRING, strlen (STRING));
165 printf ("write 2: ret = %d, errno = %d, %s\n", ret, errno,
b257a0d3 166 strerrno (errno));
e1c2defa 167 stop ();
6aeb981f
CV
168 /* Write to a read-only file */
169 errno = 0;
b44b82af 170 fd = open (OUTDIR FILENAME, O_RDONLY);
6aeb981f
CV
171 if (fd >= 0)
172 {
173 errno = 0;
174 ret = write (fd, STRING, strlen (STRING));
175 printf ("write 3: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 176 strerrno (errno));
0ea4d52e 177 close (fd);
6aeb981f
CV
178 }
179 else
59cc050d 180 printf ("write 3: errno = %d\n", errno);
e1c2defa 181 stop ();
6aeb981f
CV
182}
183
c8f6abd1
PA
184void
185test_read (void)
6aeb981f
CV
186{
187 int fd, ret;
188 char buf[16];
189
190 /* Test reading */
191 errno = 0;
b44b82af 192 fd = open (OUTDIR FILENAME, O_RDONLY);
6aeb981f
CV
193 if (fd >= 0)
194 {
195 memset (buf, 0, 16);
196 errno = 0;
197 ret = read (fd, buf, 16);
198 buf[15] = '\0'; /* Don't trust anybody... */
199 if (ret == strlen (STRING))
200 printf ("read 1: %s %s\n", buf, !strcmp (buf, STRING) ? "OK" : "");
201 else
202 printf ("read 1: ret = %d, errno = %d\n", ret, errno);
203 close (fd);
204 }
205 else
59cc050d 206 printf ("read 1: errno = %d\n", errno);
e1c2defa 207 stop ();
6aeb981f
CV
208 /* Read using invalid file descriptor */
209 errno = 0;
210 ret = read (999, buf, 16);
211 printf ("read 2: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 212 strerrno (errno));
e1c2defa 213 stop ();
6aeb981f
CV
214}
215
c8f6abd1
PA
216void
217test_lseek (void)
6aeb981f
CV
218{
219 int fd;
b257a0d3 220 off_t ret = 0;
6aeb981f
CV
221
222 /* Test seeking */
223 errno = 0;
b44b82af 224 fd = open (OUTDIR FILENAME, O_RDONLY);
6aeb981f
CV
225 if (fd >= 0)
226 {
227 errno = 0;
228 ret = lseek (fd, 0, SEEK_CUR);
b257a0d3 229 printf ("lseek 1: ret = %ld, errno = %d, %s\n", (long) ret, errno,
6aeb981f 230 ret == 0 ? "OK" : "");
e1c2defa 231 stop ();
6aeb981f
CV
232 errno = 0;
233 ret = lseek (fd, 0, SEEK_END);
b257a0d3 234 printf ("lseek 2: ret = %ld, errno = %d, %s\n", (long) ret, errno,
6aeb981f 235 ret == 11 ? "OK" : "");
e1c2defa 236 stop ();
6aeb981f
CV
237 errno = 0;
238 ret = lseek (fd, 3, SEEK_SET);
b257a0d3 239 printf ("lseek 3: ret = %ld, errno = %d, %s\n", (long) ret, errno,
6aeb981f
CV
240 ret == 3 ? "OK" : "");
241 close (fd);
242 }
243 else
244 {
209f53f5 245 printf ("lseek 1: ret = %ld, errno = %d %s\n", (long) ret, errno,
e1c2defa
NS
246 strerrno (errno));
247 stop ();
209f53f5 248 printf ("lseek 2: ret = %ld, errno = %d %s\n", (long) ret, errno,
e1c2defa
NS
249 strerrno (errno));
250 stop ();
209f53f5 251 printf ("lseek 3: ret = %ld, errno = %d %s\n", (long) ret, errno,
e1c2defa 252 strerrno (errno));
6aeb981f
CV
253 }
254 /* Seeking on an invalid file descriptor */
e1c2defa 255 stop ();
6aeb981f
CV
256}
257
c8f6abd1
PA
258void
259test_close (void)
6aeb981f
CV
260{
261 int fd, ret;
262
263 /* Test close */
264 errno = 0;
b44b82af 265 fd = open (OUTDIR FILENAME, O_RDONLY);
6aeb981f
CV
266 if (fd >= 0)
267 {
268 errno = 0;
269 ret = close (fd);
b257a0d3 270 printf ("close 1: ret = %d, errno = %d, %s\n", ret, errno,
6aeb981f
CV
271 ret == 0 ? "OK" : "");
272 }
273 else
59cc050d 274 printf ("close 1: errno = %d\n", errno);
e1c2defa 275 stop ();
6aeb981f
CV
276 /* Close an invalid file descriptor */
277 errno = 0;
278 ret = close (999);
b257a0d3
AC
279 printf ("close 2: ret = %d, errno = %d, %s\n", ret, errno,
280 strerrno (errno));
e1c2defa 281 stop ();
6aeb981f
CV
282}
283
c8f6abd1
PA
284void
285test_stat (void)
6aeb981f
CV
286{
287 int ret;
288 struct stat st;
289
290 /* Test stat */
291 errno = 0;
b44b82af 292 ret = stat (OUTDIR FILENAME, &st);
6aeb981f
CV
293 if (!ret)
294 printf ("stat 1: ret = %d, errno = %d %s\n", ret, errno,
295 st.st_size == 11 ? "OK" : "");
296 else
297 printf ("stat 1: ret = %d, errno = %d\n", ret, errno);
e1c2defa 298 stop ();
6aeb981f
CV
299 /* NULL pathname */
300 errno = 0;
d2a03b77 301 ret = stat (null_str, &st);
6aeb981f 302 printf ("stat 2: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 303 strerrno (errno));
e1c2defa 304 stop ();
6aeb981f
CV
305 /* Empty pathname */
306 errno = 0;
307 ret = stat ("", &st);
308 printf ("stat 3: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 309 strerrno (errno));
e1c2defa 310 stop ();
6aeb981f
CV
311 /* Nonexistant file */
312 errno = 0;
313 ret = stat (NONEXISTANT, &st);
314 printf ("stat 4: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 315 strerrno (errno));
e1c2defa 316 stop ();
6aeb981f
CV
317}
318
c8f6abd1
PA
319void
320test_fstat (void)
6aeb981f
CV
321{
322 int fd, ret;
323 struct stat st;
324
325 /* Test fstat */
326 errno = 0;
b44b82af 327 fd = open (OUTDIR FILENAME, O_RDONLY);
6aeb981f
CV
328 if (fd >= 0)
329 {
330 errno = 0;
331 ret = fstat (fd, &st);
332 if (!ret)
333 printf ("fstat 1: ret = %d, errno = %d %s\n", ret, errno,
334 st.st_size == 11 ? "OK" : "");
335 else
336 printf ("fstat 1: ret = %d, errno = %d\n", ret, errno);
337 close (fd);
338 }
339 else
59cc050d 340 printf ("fstat 1: errno = %d\n", errno);
e1c2defa 341 stop ();
6aeb981f
CV
342 /* Fstat using invalid file descriptor */
343 errno = 0;
344 ret = fstat (999, &st);
345 printf ("fstat 2: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 346 strerrno (errno));
e1c2defa 347 stop ();
6aeb981f
CV
348}
349
c8f6abd1
PA
350void
351test_isatty (void)
6aeb981f
CV
352{
353 int fd;
354
355 /* Check std I/O */
356 printf ("isatty 1: stdin %s\n", isatty (0) ? "yes OK" : "no");
e1c2defa 357 stop ();
6aeb981f 358 printf ("isatty 2: stdout %s\n", isatty (1) ? "yes OK" : "no");
e1c2defa 359 stop ();
6aeb981f 360 printf ("isatty 3: stderr %s\n", isatty (2) ? "yes OK" : "no");
e1c2defa 361 stop ();
6aeb981f
CV
362 /* Check invalid fd */
363 printf ("isatty 4: invalid %s\n", isatty (999) ? "yes" : "no OK");
e1c2defa 364 stop ();
6aeb981f 365 /* Check open file */
b44b82af 366 fd = open (OUTDIR FILENAME, O_RDONLY);
6aeb981f
CV
367 if (fd >= 0)
368 {
369 printf ("isatty 5: file %s\n", isatty (fd) ? "yes" : "no OK");
370 close (fd);
371 }
372 else
373 printf ("isatty 5: file couldn't open\n");
e1c2defa 374 stop ();
6aeb981f
CV
375}
376
b257a0d3 377
b44b82af
TT
378char sys[1512];
379
c8f6abd1
PA
380void
381test_system (void)
6aeb981f
CV
382{
383 /*
384 * Requires test framework to switch on "set remote system-call-allowed 1"
385 */
386 int ret;
6aeb981f 387
9f5a4cef
HZ
388 /* Test for shell ('set remote system-call-allowed' is disabled
389 by default). */
390 ret = system (NULL);
391 printf ("system 1: ret = %d %s\n", ret, ret == 0 ? "OK" : "");
392 stop ();
393 /* Test for shell again (the testsuite will have enabled it now). */
5600ea19 394 ret = system (NULL);
9f5a4cef 395 printf ("system 2: ret = %d %s\n", ret, ret != 0 ? "OK" : "");
5600ea19 396 stop ();
6aeb981f 397 /* This test prepares the directory for test_rename() */
b44b82af 398 sprintf (sys, "mkdir -p %s/%s %s/%s", OUTDIR, TESTSUBDIR, OUTDIR, TESTDIR2);
6aeb981f
CV
399 ret = system (sys);
400 if (ret == 127)
9f5a4cef 401 printf ("system 3: ret = %d /bin/sh unavailable???\n", ret);
6aeb981f 402 else
9f5a4cef 403 printf ("system 3: ret = %d %s\n", ret, ret == 0 ? "OK" : "");
e1c2defa 404 stop ();
6aeb981f
CV
405 /* Invalid command (just guessing ;-) ) */
406 ret = system ("wrtzlpfrmpft");
9f5a4cef
HZ
407 printf ("system 4: ret = %d %s\n", ret,
408 WEXITSTATUS (ret) == 127 ? "OK" : "");
e1c2defa 409 stop ();
6aeb981f
CV
410}
411
c8f6abd1
PA
412void
413test_rename (void)
6aeb981f
CV
414{
415 int ret;
416 struct stat st;
417
418 /* Test rename */
419 errno = 0;
b44b82af 420 ret = rename (OUTDIR FILENAME, OUTDIR RENAMED);
6aeb981f
CV
421 if (!ret)
422 {
423 errno = 0;
424 ret = stat (FILENAME, &st);
425 if (ret && errno == ENOENT)
426 {
427 errno = 0;
b44b82af 428 ret = stat (OUTDIR RENAMED, &st);
6aeb981f 429 printf ("rename 1: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 430 strerrno (errno));
6aeb981f
CV
431 errno = 0;
432 }
433 else
434 printf ("rename 1: ret = %d, errno = %d\n", ret, errno);
435 }
436 else
437 printf ("rename 1: ret = %d, errno = %d\n", ret, errno);
e1c2defa 438 stop ();
6aeb981f
CV
439 /* newpath is existing directory, oldpath is not a directory */
440 errno = 0;
b44b82af 441 ret = rename (OUTDIR RENAMED, OUTDIR TESTDIR2);
6aeb981f 442 printf ("rename 2: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 443 strerrno (errno));
e1c2defa 444 stop ();
6aeb981f
CV
445 /* newpath is a non-empty directory */
446 errno = 0;
b44b82af 447 ret = rename (OUTDIR TESTDIR2, OUTDIR TESTDIR1);
6aeb981f 448 printf ("rename 3: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 449 strerrno (errno));
e1c2defa 450 stop ();
6aeb981f
CV
451 /* newpath is a subdirectory of old path */
452 errno = 0;
b44b82af 453 ret = rename (OUTDIR TESTDIR1, OUTDIR TESTSUBDIR);
6aeb981f 454 printf ("rename 4: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 455 strerrno (errno));
e1c2defa 456 stop ();
6aeb981f
CV
457 /* oldpath does not exist */
458 errno = 0;
b44b82af 459 ret = rename (OUTDIR NONEXISTANT, OUTDIR FILENAME);
6aeb981f 460 printf ("rename 5: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 461 strerrno (errno));
e1c2defa 462 stop ();
6aeb981f
CV
463}
464
b44b82af
TT
465char name[1256];
466
c8f6abd1
PA
467void
468test_unlink (void)
6aeb981f
CV
469{
470 int ret;
6aeb981f
CV
471
472 /* Test unlink */
473 errno = 0;
b44b82af 474 ret = unlink (OUTDIR RENAMED);
6aeb981f 475 printf ("unlink 1: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 476 strerrno (errno));
e1c2defa 477 stop ();
6aeb981f 478 /* No write access */
b44b82af 479 sprintf (name, "%s/%s/%s", OUTDIR, TESTDIR2, FILENAME);
6aeb981f
CV
480 errno = 0;
481 ret = open (name, O_CREAT | O_RDONLY, S_IRUSR | S_IWUSR);
482 if (ret >= 0)
483 {
b44b82af 484 sprintf (sys, "chmod -w %s/%s", OUTDIR, TESTDIR2);
6aeb981f
CV
485 ret = system (sys);
486 if (!ret)
487 {
488 errno = 0;
489 ret = unlink (name);
490 printf ("unlink 2: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 491 strerrno (errno));
6aeb981f
CV
492 }
493 else
209f53f5 494 printf ("unlink 2: ret = %d chmod failed, errno= %d\n", ret, errno);
6aeb981f
CV
495 }
496 else
497 printf ("unlink 2: ret = %d, errno = %d\n", ret, errno);
e1c2defa 498 stop ();
6aeb981f
CV
499 /* pathname doesn't exist */
500 errno = 0;
b44b82af 501 ret = unlink (OUTDIR NONEXISTANT);
6aeb981f 502 printf ("unlink 3: ret = %d, errno = %d %s\n", ret, errno,
b257a0d3 503 strerrno (errno));
e1c2defa 504 stop ();
6aeb981f
CV
505}
506
c8f6abd1
PA
507void
508test_time (void)
6aeb981f
CV
509{
510 time_t ret, t;
511
512 errno = 0;
513 ret = time (&t);
b257a0d3 514 printf ("time 1: ret = %ld, errno = %d, t = %ld %s\n", (long) ret, errno, (long) t, ret == t ? "OK" : "");
e1c2defa 515 stop ();
6aeb981f
CV
516 errno = 0;
517 ret = time (NULL);
b257a0d3
AC
518 printf ("time 2: ret = %ld, errno = %d, t = %ld %s\n",
519 (long) ret, errno, (long) t, ret >= t && ret < t + 10 ? "OK" : "");
e1c2defa 520 stop ();
b257a0d3
AC
521}
522
523static const char *
524strerrno (int err)
525{
526 switch (err)
527 {
528 case 0: return "OK";
529#ifdef EACCES
530 case EACCES: return "EACCES";
531#endif
532#ifdef EBADF
533 case EBADF: return "EBADF";
534#endif
535#ifdef EEXIST
536 case EEXIST: return "EEXIST";
537#endif
538#ifdef EFAULT
539 case EFAULT: return "EFAULT";
540#endif
541#ifdef EINVAL
542 case EINVAL: return "EINVAL";
543#endif
544#ifdef EISDIR
545 case EISDIR: return "EISDIR";
546#endif
547#ifdef ENOENT
548 case ENOENT: return "ENOENT";
549#endif
550#ifdef ENOTEMPTY
551 case ENOTEMPTY: return "ENOTEMPTY";
60ad077b
AC
552#endif
553#ifdef EBUSY
554 case EBUSY: return "EBUSY";
b257a0d3
AC
555#endif
556 default: return "E??";
557 }
6aeb981f
CV
558}
559
560int
561main ()
562{
563 /* Don't change the order of the calls. They partly depend on each other */
564 test_open ();
565 test_write ();
566 test_read ();
567 test_lseek ();
568 test_close ();
569 test_stat ();
570 test_fstat ();
571 test_isatty ();
572 test_system ();
573 test_rename ();
574 test_unlink ();
575 test_time ();
576 return 0;
577}
This page took 1.67926 seconds and 4 git commands to generate.