summaryrefslogtreecommitdiffstats
path: root/tests/helpers
diff options
context:
space:
mode:
authorKarel Zak2007-01-04 14:53:19 +0100
committerKarel Zak2007-01-04 14:53:19 +0100
commit0f0584addc6c6301836455724d32a98b02cae159 (patch)
treed557058b5d1c83a2467e30f10ca78db4eb336593 /tests/helpers
parentipcs: max total shared memory in kbytes instead pages (diff)
downloadkernel-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.am5
-rw-r--r--tests/helpers/mnt_test_sysinfo.c106
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);
+}
+