mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/legion/kbd.git
synced 2026-01-29 07:24:14 +00:00
247 lines
4.6 KiB
C
247 lines
4.6 KiB
C
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <check.h>
|
|
#include <keymap.h>
|
|
|
|
#include "modifiers.h"
|
|
|
|
struct modifier {
|
|
const char *name;
|
|
const int bit;
|
|
const char ch;
|
|
};
|
|
|
|
|
|
START_TEST(test_parse_0)
|
|
{
|
|
int c;
|
|
lkfile_t f;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap0.map");
|
|
f.fd = fopen(DATADIR "/keymap0.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
c = lk_get_key(&ctx, 0, 16);
|
|
fail_if(KVAL(c) != 'q', "Unable to get keycode 16");
|
|
|
|
c = lk_get_key(&ctx, 0, 17);
|
|
fail_if(KVAL(c) != 'w', "Unable to get keycode 17");
|
|
|
|
c = lk_get_key(&ctx, 0, 18);
|
|
fail_if(KVAL(c) != 'e', "Unable to get keycode 18");
|
|
|
|
c = lk_get_key(&ctx, 0, 19);
|
|
fail_if(KVAL(c) != 'r', "Unable to get keycode 19");
|
|
|
|
c = lk_get_key(&ctx, 0, 20);
|
|
fail_if(KVAL(c) != 't', "Unable to get keycode 20");
|
|
|
|
c = lk_get_key(&ctx, 0, 21);
|
|
fail_if(KVAL(c) != 'y', "Unable to get keycode 21");
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_parse_1)
|
|
{
|
|
int c;
|
|
lkfile_t f;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap1.map");
|
|
f.fd = fopen(DATADIR "/keymap1.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
c = lk_get_key(&ctx, 0, 16);
|
|
fail_if(KVAL(c) != 'q', "Unable to get keycode");
|
|
|
|
c = lk_get_key(&ctx, 1, 16);
|
|
fail_if(KVAL(c) != 'Q', "Unable to get keycode");
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_parse_2)
|
|
{
|
|
int i = 0;
|
|
lkfile_t f;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap2.map");
|
|
f.fd = fopen(DATADIR "/keymap2.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
while (i < MAX_NR_KEYMAPS) {
|
|
int c = lk_get_key(&ctx, i, 17);
|
|
fail_if(KVAL(c) != 'x', "Unable to get keycode");
|
|
i++;
|
|
}
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_parse_3)
|
|
{
|
|
int i;
|
|
char str[] = "qwertyuiopasdfghjklzxcvbnm";
|
|
lkfile_t f;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap3.map");
|
|
f.fd = fopen(DATADIR "/keymap3.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
for (i = 0; i < 26; i++) {
|
|
int c = lk_get_key(&ctx, i, 17);
|
|
fail_if(KVAL(c) != str[i], "Unable to get keycode");
|
|
}
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_parse_4)
|
|
{
|
|
int c;
|
|
lkfile_t f;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap4.map");
|
|
f.fd = fopen(DATADIR "/keymap4.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
c = lk_get_key(&ctx, 0, 16);
|
|
fail_if(KVAL(c) != 'q', "Unable to get keycode");
|
|
|
|
c = lk_get_key(&ctx, 0, 17);
|
|
fail_if(KVAL(c) != 'w', "Include40.map failed");
|
|
|
|
c = lk_get_key(&ctx, 0, 18);
|
|
fail_if(KVAL(c) != 'e', "Include41.map failed");
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_parse_5)
|
|
{
|
|
int i;
|
|
lkfile_t f;
|
|
struct kbsentry kbs;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap5.map");
|
|
f.fd = fopen(DATADIR "/keymap5.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
for(i = 0; i < MAX_NR_FUNC; i++) {
|
|
kbs.kb_func = i;
|
|
kbs.kb_string[0] = 0;
|
|
fail_if(lk_get_func(&ctx, &kbs) != 0,
|
|
"Unable to get func %d", i);
|
|
}
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
START_TEST(test_parse_6)
|
|
{
|
|
lkfile_t f;
|
|
struct kbsentry kbs;
|
|
struct lk_ctx ctx;
|
|
|
|
lk_init(&ctx);
|
|
ctx.log_fn = NULL;
|
|
|
|
f.pipe = 0;
|
|
strcpy(f.pathname, "keymap6.map");
|
|
f.fd = fopen(DATADIR "/keymap6.map", "r");
|
|
|
|
fail_if(lk_parse_keymap(&ctx, &f) != 0, "Unable to parse keymap");
|
|
|
|
kbs.kb_func = 0;
|
|
kbs.kb_string[0] = 0;
|
|
fail_if(lk_get_func(&ctx, &kbs) != 0, "Unable to get func 0");
|
|
|
|
kbs.kb_func = 1;
|
|
kbs.kb_string[0] = 0;
|
|
fail_if(lk_get_func(&ctx, &kbs) != 0, "Unable to get func 1");
|
|
|
|
kbs.kb_func = 2;
|
|
kbs.kb_string[0] = 0;
|
|
fail_if(lk_get_func(&ctx, &kbs) != -1, "Possible to get not alloced func");
|
|
|
|
lk_free(&ctx);
|
|
}
|
|
END_TEST
|
|
|
|
static Suite *
|
|
libkeymap_suite(void)
|
|
{
|
|
Suite *s = suite_create("libkeymap");
|
|
TCase *tc_core = tcase_create(NULL);
|
|
|
|
setenv("LOADKEYS_INCLUDE_PATH", DATADIR, 1);
|
|
|
|
tcase_add_test(tc_core, test_parse_0);
|
|
tcase_add_test(tc_core, test_parse_1);
|
|
tcase_add_test(tc_core, test_parse_2);
|
|
tcase_add_test(tc_core, test_parse_3);
|
|
tcase_add_test(tc_core, test_parse_4);
|
|
tcase_add_test(tc_core, test_parse_5);
|
|
tcase_add_test(tc_core, test_parse_6);
|
|
|
|
suite_add_tcase(s, tc_core);
|
|
return s;
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
int number_failed;
|
|
|
|
Suite *s = libkeymap_suite();
|
|
SRunner *sr = srunner_create (s);
|
|
|
|
srunner_run_all(sr, CK_NORMAL);
|
|
|
|
number_failed = srunner_ntests_failed(sr);
|
|
srunner_free (sr);
|
|
|
|
return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
}
|