4becf5cc9d4951e320a34df6b1a13ca884cf33ec
[debian/amanda] / common-src / amflock-test.c
1 /*
2  * Amanda, The Advanced Maryland Automatic Network Disk Archiver
3  * Copyright (c) 1991-1998 University of Maryland at College Park
4  * All Rights Reserved.
5  *
6  * Permission to use, copy, modify, distribute, and sell this software and its
7  * documentation for any purpose is hereby granted without fee, provided that
8  * the above copyright notice appear in all copies and that both that
9  * copyright notice and this permission notice appear in supporting
10  * documentation, and that the name of U.M. not be used in advertising or
11  * publicity pertaining to distribution of the software without specific,
12  * written prior permission.  U.M. makes no representations about the
13  * suitability of this software for any purpose.  It is provided "as is"
14  * without express or implied warranty.
15  *
16  * U.M. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL U.M.
18  * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
19  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
20  * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
21  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
22  *
23  * Authors: the Amanda Development Team.  Its members are listed in a
24  * file named AUTHORS, in the root directory of this distribution.
25  */
26
27 #include "amanda.h"
28
29 /* from amflock.c */
30 extern amflock_impl_t *amflock_impls[];
31
32 int
33 main(void)
34 {
35     amflock_impl_t **imp = amflock_impls;
36     char *filename = "./amflocktest.file";
37     char *resource = "rez";
38     int fd;
39     int lock_ro;
40
41     /* set lnlock's lock directory to the current directory */
42     extern char *_lnlock_dir;
43     _lnlock_dir = ".";
44
45     while (*imp) {
46         g_fprintf(stderr, _("Testing amflock-%s\n"), (*imp)->impl_name);
47         alarm(5); /* time out after 5 seconds */
48
49         for (lock_ro = 0; lock_ro < 2; lock_ro++) { /* false (0) or true (1) */
50             if (unlink(filename) == -1 && errno != ENOENT) {
51                 perror("unlink");
52                 return 1;
53             }
54
55             if ((fd = open(filename, O_RDWR | O_CREAT | O_EXCL, 0600)) == -1) {
56                 perror("open");
57                 return 1;
58             }
59
60             if (lock_ro) {
61                 if ((*imp)->amroflock_impl(fd, resource) != 0) {
62                     perror("amroflock");
63                     return 1;
64                 }
65             } else {
66                 if ((*imp)->amflock_impl(fd, resource) != 0) {
67                     perror("amflock");
68                     return 1;
69                 }
70             }
71
72             if ((*imp)->amfunlock_impl(fd, resource) != 0) {
73                 perror("amfunlock");
74                 return 1;
75             }
76
77             close(fd); /* ignore error */
78             unlink(filename); /* ignore error */
79         }
80
81         imp++;
82     }
83
84     return 0;
85 }