diff options
author | Karel Zak | 2007-01-04 14:53:19 +0100 |
---|---|---|
committer | Karel Zak | 2007-01-04 14:53:19 +0100 |
commit | 0f0584addc6c6301836455724d32a98b02cae159 (patch) | |
tree | d557058b5d1c83a2467e30f10ca78db4eb336593 /tests/helpers | |
parent | ipcs: max total shared memory in kbytes instead pages (diff) | |
download | kernel-qcow2-util-linux-0f0584addc6c6301836455724d32a98b02cae159.tar.gz kernel-qcow2-util-linux-0f0584addc6c6301836455724d32a98b02cae159.tar.xz kernel-qcow2-util-linux-0f0584addc6c6301836455724d32a98b02cae159.zip |
tests: add simple helper that returns info about system
usage: tests/helpers/mnt_test_sysinfo <infoname>
Signed-off-by: Karel Zak <kzak@redhat.com>
Diffstat (limited to 'tests/helpers')
-rw-r--r-- | tests/helpers/Makefile.am | 5 | ||||
-rw-r--r-- | tests/helpers/mnt_test_sysinfo.c | 106 |
2 files changed, 111 insertions, 0 deletions
diff --git a/tests/helpers/Makefile.am b/tests/helpers/Makefile.am new file mode 100644 index 000000000..13eaae1e9 --- /dev/null +++ b/tests/helpers/Makefile.am @@ -0,0 +1,5 @@ +include $(top_srcdir)/config/include-Makefile.am + +noinst_PROGRAMS = mnt_test_sysinfo + +mnt_test_sysinfo_SOURCES = mnt_test_sysinfo.c diff --git a/tests/helpers/mnt_test_sysinfo.c b/tests/helpers/mnt_test_sysinfo.c new file mode 100644 index 000000000..0acb130b0 --- /dev/null +++ b/tests/helpers/mnt_test_sysinfo.c @@ -0,0 +1,106 @@ + +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> + +#include <limits.h> + +typedef struct { + const char *name; + int (*fnc)(void); +} mntHlpfnc; + +int +hlp_wordsize(void) +{ + printf("%d\n", __WORDSIZE); + return 0; +} + +int +hlp_pagesize(void) +{ + printf("%d\n", getpagesize()); + return 0; +} + +int +hlp_int_max(void) +{ + printf("%d\n", INT_MAX); + return 0; +} + +int +hlp_uint_max(void) +{ + printf("%u\n", UINT_MAX); + return 0; +} + +int +hlp_long_max(void) +{ + printf("%ld\n", LONG_MAX); + return 0; +} + +int +hlp_ulong_max(void) +{ + printf("%lu\n", ULONG_MAX); + return 0; +} + +int +hlp_ulong_max32(void) +{ + printf("%lu\n", ULONG_MAX >> 32); + return 0; +} + +mntHlpfnc hlps[] = +{ + { "WORDSIZE", hlp_wordsize }, + { "pagesize", hlp_pagesize }, + { "INT_MAX", hlp_int_max }, + { "UINT_MAX", hlp_uint_max }, + { "LONG_MAX", hlp_long_max }, + { "ULONG_MAX", hlp_ulong_max }, + { "ULONG_MAX32",hlp_ulong_max32 }, + { NULL, NULL } +}; + +int +main(int argc, char **argv) +{ + int re = 0; + mntHlpfnc *fn; + + if (argc == 1) { + for (fn = hlps; fn->name; fn++) { + printf("%15s: ", fn->name); + re += fn->fnc(); + } + } else { + int i; + + if (strcmp(argv[0], "--help") == 0 || strcmp(argv[0], "-h") == 0) { + printf("%s <option>\n", argv[0]); + fputs("options:\n", stdout); + for (fn = hlps; fn->name; fn++) + printf("\t%s\n", fn->name); + exit(EXIT_SUCCESS); + } + + for (i=1; i < argc; i++) { + for (fn = hlps; fn->name; fn++) { + if (strcmp(fn->name, argv[i]) == 0) + re += fn->fnc(); + } + } + } + + exit(re ? EXIT_FAILURE : EXIT_SUCCESS); +} + |