summaryrefslogtreecommitdiffstats
path: root/testsuite/test-new-module.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--testsuite/test-new-module.c118
1 files changed, 118 insertions, 0 deletions
diff --git a/testsuite/test-new-module.c b/testsuite/test-new-module.c
new file mode 100644
index 0000000..9872b78
--- /dev/null
+++ b/testsuite/test-new-module.c
@@ -0,0 +1,118 @@
+/*
+ * Copyright (C) 2012-2013 ProFUSION embedded systems
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <errno.h>
+#include <inttypes.h>
+#include <stddef.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+
+#include <libkmod/libkmod.h>
+
+#include "testsuite.h"
+
+static int from_name(const struct test *t)
+{
+ static const char *const modnames[] = {
+ "ext4",
+ "balbalbalbbalbalbalbalbalbalbal",
+ "snd-hda-intel",
+ "snd-timer",
+ "iTCO_wdt",
+ NULL,
+ };
+ const char *const *p;
+ struct kmod_ctx *ctx;
+ struct kmod_module *mod;
+ const char *null_config = NULL;
+ int err;
+
+ ctx = kmod_new(NULL, &null_config);
+ if (ctx == NULL)
+ exit(EXIT_FAILURE);
+
+ for (p = modnames; p != NULL; p++) {
+ err = kmod_module_new_from_name(ctx, *p, &mod);
+ if (err < 0)
+ exit(EXIT_SUCCESS);
+
+ printf("modname: %s\n", kmod_module_get_name(mod));
+ kmod_module_unref(mod);
+ }
+
+ kmod_unref(ctx);
+
+ return EXIT_SUCCESS;
+}
+DEFINE_TEST(from_name,
+ .description = "check if module names are parsed correctly",
+ .config = {
+ [TC_ROOTFS] = TESTSUITE_ROOTFS "test-new-module/from_name/",
+ },
+ .need_spawn = true,
+ .output = {
+ .out = TESTSUITE_ROOTFS "test-new-module/from_name/correct.txt",
+ });
+
+static int from_alias(const struct test *t)
+{
+ static const char *const modnames[] = {
+ "ext4.*",
+ NULL,
+ };
+ const char *const *p;
+ struct kmod_ctx *ctx;
+ int err;
+
+ ctx = kmod_new(NULL, NULL);
+ if (ctx == NULL)
+ exit(EXIT_FAILURE);
+
+ for (p = modnames; p != NULL; p++) {
+ struct kmod_list *l, *list = NULL;
+
+ err = kmod_module_new_from_lookup(ctx, *p, &list);
+ if (err < 0)
+ exit(EXIT_SUCCESS);
+
+ kmod_list_foreach(l, list) {
+ struct kmod_module *m;
+ m = kmod_module_get_module(l);
+
+ printf("modname: %s\n", kmod_module_get_name(m));
+ kmod_module_unref(m);
+ }
+ kmod_module_unref_list(list);
+ }
+
+ kmod_unref(ctx);
+
+ return EXIT_SUCCESS;
+}
+DEFINE_TEST(from_alias,
+ .description = "check if aliases are parsed correctly",
+ .config = {
+ [TC_ROOTFS] = TESTSUITE_ROOTFS "test-new-module/from_alias/",
+ },
+ .need_spawn = true,
+ .output = {
+ .out = TESTSUITE_ROOTFS "test-new-module/from_alias/correct.txt",
+ });
+
+TESTSUITE_MAIN();