summaryrefslogtreecommitdiffstats
path: root/basic/test9.c
diff options
context:
space:
mode:
Diffstat (limited to 'basic/test9.c')
-rw-r--r--basic/test9.c182
1 files changed, 182 insertions, 0 deletions
diff --git a/basic/test9.c b/basic/test9.c
new file mode 100644
index 0000000..ef68fc2
--- /dev/null
+++ b/basic/test9.c
@@ -0,0 +1,182 @@
+/*
+ * @(#)test9.c 1.7 2001/08/25 Connectathon Testsuite
+ * 1.4 Lachman ONC Test Suite source
+ *
+#ifdef SVR4
+ * Test statvfs
+#else
+ * Test statfs
+#endif
+ *
+ * Uses the following important system calls against the server:
+ *
+ * chdir()
+ * mkdir() (for initial directory creation if not -m)
+#ifdef SVR4
+ * statvfs()
+#else
+ * statfs()
+#endif
+ */
+
+#if defined (DOS) || defined (WIN32)
+/* If Dos, Windows or Win32 */
+#define DOSorWIN32
+#endif
+
+#ifndef DOSorWIN32
+#include <sys/param.h>
+#include <unistd.h>
+#ifdef SVR4
+#include <sys/statvfs.h>
+#else
+#if defined (OSF1) || defined (BSD)
+#include <sys/mount.h>
+#else
+#include <sys/vfs.h>
+#endif /* OSF1 || BSD */
+#endif /* SVR4 */
+#endif /* DOSorWIN32 */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#ifdef DOSorWIN32
+#include <time.h>
+#else
+#include <sys/time.h>
+#endif
+
+#include "../tests.h"
+
+static int Tflag = 0; /* print timing */
+static int Fflag = 0; /* test function only; set count to 1, negate -t */
+static int Nflag = 0; /* Suppress directory operations */
+
+static void
+usage()
+{
+ fprintf(stdout, "usage: %s [-htfn] [count]\n", Myname);
+ fprintf(stdout, " Flags: h Help - print this usage info\n");
+ fprintf(stdout, " t Print execution time statistics\n");
+ fprintf(stdout, " f Test function only (negate -t)\n");
+ fprintf(stdout, " n Suppress test directory create operations\n");
+}
+
+main(argc, argv)
+ int argc;
+ char *argv[];
+{
+#ifdef SVR4
+ int count = 1500; /* times to do statvfs call */
+#else
+ int count = 1500; /* times to do statfs call */
+#endif
+ int ct;
+ struct timeval time;
+#ifdef SVR4
+ struct statvfs sfsb;
+#else
+ struct statfs sfsb;
+#endif
+ char *opts;
+
+ umask(0);
+ setbuf(stdout, NULL);
+ Myname = *argv++;
+ argc--;
+ while (argc && **argv == '-') {
+ for (opts = &argv[0][1]; *opts; opts++) {
+ switch (*opts) {
+ case 'h': /* help */
+ usage();
+ exit(1);
+ break;
+
+ case 't': /* time */
+ Tflag++;
+ break;
+
+ case 'f': /* funtionality */
+ Fflag++;
+ break;
+
+ case 'n': /* No Test Directory create */
+ Nflag++;
+ break;
+
+ default:
+ error("unknown option '%c'", *opts);
+ usage();
+ exit(1);
+ }
+ }
+ argc--;
+ argv++;
+ }
+
+ if (argc) {
+ count = getparm(*argv, 1, "count");
+ argv++;
+ argc--;
+ }
+ if (argc) {
+ usage();
+ exit(1);
+ }
+
+ if (Fflag) {
+ Tflag = 0;
+ count = 1;
+ }
+
+ if (!Nflag)
+ testdir(NULL);
+ else
+ mtestdir(NULL);
+
+#ifdef SVR4
+ fprintf(stdout, "%s: statvfs\n", Myname);
+#else
+ fprintf(stdout, "%s: statfs\n", Myname);
+#endif
+
+ if (Tflag) {
+ starttime();
+ }
+
+ for (ct = 0; ct < count; ct++) {
+#ifdef SVR4
+ if (statvfs(".", &sfsb) < 0) {
+ error("can't do statvfs on \".\"");
+ exit(1);
+ }
+#else
+#ifdef SVR3
+ if (statfs(".", &sfsb, sizeof(sfsb), 0) < 0) {
+#else
+ if (statfs(".", &sfsb) < 0) {
+#endif
+ error("can't do statfs on \".\"");
+ exit(1);
+ }
+#endif
+ }
+
+ if (Tflag) {
+ endtime(&time);
+ }
+#ifdef SVR4
+ fprintf(stdout, "\t%d statvfs calls", count);
+#else
+ fprintf(stdout, "\t%d statfs calls", count);
+#endif
+ if (Tflag) {
+ fprintf(stdout, " in %ld.%-2ld seconds",
+ (long)time.tv_sec, (long)time.tv_usec / 10000);
+ }
+ fprintf(stdout, "\n");
+ complete();
+}