Whamcloud - gitweb
LU-8275 tests: add flag to enable secret shared key for tests
[fs/lustre-release.git] / lustre / tests / statone.c
1 /*
2  * GPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 only,
8  * as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License version 2 for more details (a copy is included
14  * in the LICENSE file that accompanied this code).
15  *
16  * You should have received a copy of the GNU General Public License
17  * version 2 along with this program; If not, see
18  * http://www.gnu.org/licenses/gpl-2.0.html
19  *
20  * GPL HEADER END
21  */
22 /*
23  * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
24  * Use is subject to license terms.
25  *
26  * Copyright (c) 2014, Intel Corporation.
27  */
28 /*
29  * This file is part of Lustre, http://www.lustre.org/
30  * Lustre is a trademark of Sun Microsystems, Inc.
31  */
32
33 #include <errno.h>
34 #include <limits.h>
35 #include <stdio.h>
36 #include <stdlib.h>
37 #include <string.h>
38 #include <sys/types.h>
39 #include <sys/stat.h>
40 #include <fcntl.h>
41
42 #include <lustre/lustreapi.h>
43
44 int main(int argc, char **argv)
45 {
46     char parent[4096], *base, *name, *t;
47     int fd, offset, rc;
48
49     if (argc != 2) {
50         printf("usage: %s filename\n", argv[0]);
51         return 1;
52     }
53
54     base = argv[1];
55     t = strrchr(base, '/');
56     if (!t) {
57         strcpy(parent, ".");
58         offset = -1;
59     } else {
60         strncpy(parent, base, t - base);
61         offset = t - base - 1;
62     }
63
64     fd = open(parent, O_RDONLY);
65     if (fd < 0) {
66         printf("open(%s) error: %s\n", parent, strerror(errno));
67         exit(errno);
68     }
69
70     name = base;
71     if (offset >= 0)
72         name += offset + 2;
73
74     rc = llapi_file_lookup(fd, name);
75     if (rc < 0) {
76         printf("llapi_file_lookup (%s/%s) error: %s\n", parent,
77                name, strerror(errno));
78         exit(errno);
79     }
80
81     return 0;
82 }