diff options
author | dzwdz | 2021-10-15 19:09:32 +0200 |
---|---|---|
committer | dzwdz | 2021-10-15 19:09:32 +0200 |
commit | 4fca75ee901e5e8fdee0a8e12ebd18d51fff811f (patch) | |
tree | 822e381fbf16640a6dd6040c1e17d7f2b69342b8 /src/init | |
parent | e9ae64908cb116174d2d18be3d727d988e96108b (diff) |
init/tests: implement a run_forked wrapper
Diffstat (limited to 'src/init')
-rw-r--r-- | src/init/tests/main.c | 80 |
1 files changed, 38 insertions, 42 deletions
diff --git a/src/init/tests/main.c b/src/init/tests/main.c index 3b2d2ce..f759e33 100644 --- a/src/init/tests/main.c +++ b/src/init/tests/main.c @@ -4,6 +4,13 @@ #define argify(str) str, sizeof(str) - 1 +static void run_forked(void (*fn)()) { + if (!_syscall_fork()) { + fn(); + _syscall_exit(0); + } else _syscall_await(); +} + static void read_file(const char *path, size_t len) { int fd = _syscall_open(path, len); static char buf[64]; @@ -23,58 +30,47 @@ static void read_file(const char *path, size_t len) { } void test_all(void) { - test_fs(); - test_await(); + run_forked(test_fs); + run_forked(test_await); } void test_fs(void) { - if (!_syscall_fork()) { - /* run the "test" in a child process to not affect the fs view of the - * main process */ - read_file(argify("/init/fake.txt")); - read_file(argify("/init/1.txt")); - read_file(argify("/init/2.txt")); - read_file(argify("/init/dir/3.txt")); + // TODO this test is shit + read_file(argify("/init/fake.txt")); + read_file(argify("/init/1.txt")); + read_file(argify("/init/2.txt")); + read_file(argify("/init/dir/3.txt")); - printf("\nshadowing /init/dir...\n"); - _syscall_mount(-1, argify("/init/dir")); - read_file(argify("/init/fake.txt")); - read_file(argify("/init/1.txt")); - read_file(argify("/init/2.txt")); - read_file(argify("/init/dir/3.txt")); + printf("\nshadowing /init/dir...\n"); + _syscall_mount(-1, argify("/init/dir")); + read_file(argify("/init/fake.txt")); + read_file(argify("/init/1.txt")); + read_file(argify("/init/2.txt")); + read_file(argify("/init/dir/3.txt")); - printf("\n"); - _syscall_exit(0); - } else _syscall_await(); + printf("\n"); } void test_await(void) { int ret; - if (!_syscall_fork()) { - /* this "test" runs in a child process, because otherwise it would be - * stuck waiting for e.g. the tar_driver process to exit */ - - // regular exit()s - if (!_syscall_fork()) _syscall_exit(69); - if (!_syscall_fork()) _syscall_exit(420); + // regular exit()s + if (!_syscall_fork()) _syscall_exit(69); + if (!_syscall_fork()) _syscall_exit(420); - // faults - if (!_syscall_fork()) { // invalid memory access - asm volatile("movb $69, 0" ::: "memory"); - printf("this shouldn't happen"); - _syscall_exit(-1); - } - if (!_syscall_fork()) { // #GP - asm volatile("hlt" ::: "memory"); - printf("this shouldn't happen"); - _syscall_exit(-1); - } - - while ((ret = _syscall_await()) != ~0) - printf("await returned: %x\n", ret); - printf("await: no more children\n"); + // faults + if (!_syscall_fork()) { // invalid memory access + asm volatile("movb $69, 0" ::: "memory"); + printf("this shouldn't happen"); + _syscall_exit(-1); + } + if (!_syscall_fork()) { // #GP + asm volatile("hlt" ::: "memory"); + printf("this shouldn't happen"); + _syscall_exit(-1); + } - _syscall_exit(0); - } else _syscall_await(); + while ((ret = _syscall_await()) != ~0) + printf("await returned: %x\n", ret); + printf("await: no more children\n"); } |