kmod/testsuite/test-alias.c

104 lines
2.2 KiB
C
Raw Normal View History

/*
* Copyright (C) 2012 ProFUSION embedded systems
* Copyright (C) 2012 Pedro Pedruzzi
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <libkmod.h>
#include "libkmod-util.h"
#include "testsuite.h"
static int alias_1(const struct test *t)
{
static const char *input[] = {
"test1234",
"test[abcfoobar]2211",
"bar[aaa][bbbb]sss",
"kmod[p.b]lib",
"[az]1234[AZ]",
NULL,
};
char buf[PATH_MAX];
size_t len;
const char **alias;
for (alias = input; *alias != NULL; alias++) {
int ret;
ret = alias_normalize(*alias, buf, &len);
printf("input %s\n", *alias);
printf("return %d\n", ret);
if (ret == 0) {
printf("len %zu\n", len);
printf("output %s\n", buf);
}
printf("\n");
}
return EXIT_SUCCESS;
}
static const struct test salias_1 = {
.name = "alias_1",
.description = "check if alias_normalize does the right thing",
.func = alias_1,
.config = {
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-alias/",
},
.need_spawn = true,
.output = {
.stdout = TESTSUITE_ROOTFS "test-alias/correct.txt",
},
};
static const struct test *tests[] = {
&salias_1,
NULL,
};
int main(int argc, char *argv[])
{
const struct test *t;
int arg;
size_t i;
arg = test_init(argc, argv, tests);
if (arg == 0)
return 0;
if (arg < argc) {
t = test_find(tests, argv[arg]);
if (t == NULL) {
fprintf(stderr, "could not find test %s\n", argv[arg]);
exit(EXIT_FAILURE);
}
return test_run(t);
}
for (i = 0; tests[i] != NULL; i++) {
if (test_run(tests[i]) != 0)
exit(EXIT_FAILURE);
}
exit(EXIT_SUCCESS);
}