Whamcloud - gitweb
Branch HEAD
[fs/lustre-release.git] / lustre / tests / unlinkmany.c
1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2  * vim:expandtab:shiftwidth=8:tabstop=8:
3  *
4  * GPL HEADER START
5  *
6  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License version 2 only,
10  * as published by the Free Software Foundation.
11  *
12  * This program is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * General Public License version 2 for more details (a copy is included
16  * in the LICENSE file that accompanied this code).
17  *
18  * You should have received a copy of the GNU General Public License
19  * version 2 along with this program; If not, see
20  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
21  *
22  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
23  * CA 95054 USA or visit www.sun.com if you need additional information or
24  * have any questions.
25  *
26  * GPL HEADER END
27  */
28 /*
29  * Copyright  2008 Sun Microsystems, Inc. All rights reserved
30  * Use is subject to license terms.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  */
36
37 #include <stdio.h>
38 #include <sys/types.h>
39 #include <sys/stat.h>
40 #include <time.h>
41 #include <errno.h>
42 #include <string.h>
43 #include <fcntl.h>
44 #include <unistd.h>
45 #include <stdlib.h>
46
47 void usage(char *prog)
48 {
49         printf("usage: %s filenamefmt count\n", prog);
50         printf("       %s filenamefmt start count\n", prog);
51 }
52
53 int main(int argc, char ** argv)
54 {
55         int i, rc = 0, do_rmdir = 0;
56         char format[4096], *fmt;
57         char filename[4096];
58         long start, last;
59         long begin = 0, count;
60
61         if (argc < 3 || argc > 5) {
62                 usage(argv[0]);
63                 return 1;
64         }
65
66         if (strcmp(argv[1], "-d") == 0) {
67                 do_rmdir = 1;
68                 argv++;
69                 argc--;
70         }
71
72         if (strlen(argv[1]) > 4080) {
73                 printf("name too long\n");
74                 return 1;
75         }
76
77         start = last = time(0);
78
79         if (argc == 3) {
80                 count = strtol(argv[2], NULL, 0);
81                 if (count < 1) {
82                         printf("count must be at least one\n");
83                         return 1;
84                 }
85         } else {
86                 begin = strtol(argv[2], NULL, 0);
87                 count = strtol(argv[3], NULL, 0);
88         }
89
90         if (strchr(argv[1], '%')) {
91                 fmt = argv[1];
92         } else {
93                 sprintf(format, "%s%%d", argv[1]);
94                 fmt = format;
95         }
96         for (i = 0; i < count; i++, begin++) {
97                 sprintf(filename, fmt, begin);
98                 if (do_rmdir)
99                         rc = rmdir(filename);
100                 else
101                         rc = unlink(filename);
102                 if (rc) {
103                         printf("%s(%s) error: %s\n",
104                                do_rmdir ? "rmdir" : "unlink",
105                                filename, strerror(errno));
106                         rc = errno;
107                         break;
108                 }
109                 if ((i % 10000) == 0) {
110                         printf(" - unlinked %d (time %ld ; total %ld ; last "
111                                "%ld)\n", i, time(0), time(0) - start,
112                                time(0) - last);
113                         last = time(0);
114                 }
115         }
116         printf("total: %d unlinks in %ld seconds: %f unlinks/second\n", i,
117                time(0) - start, ((float)i / (time(0) - start)));
118
119         return rc;
120 }