From d42853496fc976ef3d067af421a1a3811660033d Mon Sep 17 00:00:00 2001 From: kartofen Date: Sun, 30 Apr 2023 13:21:44 +0300 Subject: i am getting tired of the makefile --- src/daemon/main.c | 2 ++ src/include/test-util.h | 71 ++++++++++++++++++++++++++++++++++++++++++++++++ src/include/test-util.sh | 53 ++++++++++++++++++++++++++++++++++++ src/initramfs-init.sh | 2 +- src/libs/testing-library | 53 ------------------------------------ src/tests/test1.sh | 4 +-- src/tests/test2.c | 13 +++++++++ 7 files changed, 142 insertions(+), 56 deletions(-) create mode 100644 src/include/test-util.h create mode 100755 src/include/test-util.sh delete mode 100755 src/libs/testing-library create mode 100644 src/tests/test2.c (limited to 'src') diff --git a/src/daemon/main.c b/src/daemon/main.c index 1e562d6..876c004 100644 --- a/src/daemon/main.c +++ b/src/daemon/main.c @@ -1,6 +1,8 @@ #include +#include "test-util.h" int main(void) { + hello(); return 0; } diff --git a/src/include/test-util.h b/src/include/test-util.h new file mode 100644 index 0000000..4ec36fc --- /dev/null +++ b/src/include/test-util.h @@ -0,0 +1,71 @@ +#ifndef TEST_UTIL_H +#define TEST_UTIL_H + +#include +#include + +unsigned int tests = 0, failed = 0, cur_test = 0; + +void description(char *str) +{ + printf("# DESCRIPTION: %s\n", str); +} + +void plan(int n) +{ + tests = n; failed = 0; cur_test = 0; + printf("1..%d\n", tests); +} + +int conclude() +{ + float perc = 100.0f * (1.0f - ((float)failed / tests)); + printf("# CONCLUSION: (%.2f%%) %d out of %d tests failed\n", perc, failed, tests); + + if(tests != cur_test) { + printf("# expected %d, but got %d tests\n", tests, cur_test); + } + + if(failed != 0) { + return 1; + } + + return 0; +} + +void ok(int val, char *desc) +{ + cur_test++; + if(val == 0) { + printf("ok %d - %s\n", cur_test, desc); + } else { + printf("not ok %d - %s\n", cur_test, desc); + printf(" returned \'%d\'\n", val); + failed++; + } +} +void is_i(int val, int exp, char *desc) +{ + cur_test++; + if(val == exp) { + printf("ok %d - %s\n", cur_test, desc); + } else { + printf("not ok %d - %s\n", cur_test, desc); + printf(" expected \'%d\', but got \'%d\'\n", exp, val); + failed++; + } +} + +void is_s(char *val, char *exp, char *desc) +{ + cur_test++; + if(strcmp(val, exp) == 0) { + printf("ok %d - %s\n", cur_test, desc); + } else { + printf("not ok %d - %s\n", cur_test, desc); + printf(" expected \'%s\', but got \'%s\'\n", exp, val); + failed++; + } +} + +#endif diff --git a/src/include/test-util.sh b/src/include/test-util.sh new file mode 100755 index 0000000..8af522f --- /dev/null +++ b/src/include/test-util.sh @@ -0,0 +1,53 @@ +#!/bin/sh + +function description { + echo "# DESCRIPTION: $1" +} + +# $1 is the number of total tests +function plan { + TESTS=$1; FAILED=0; CUR_TEST=0 + echo "1..$TESTS" +} + +function conclude { + PERC=$(echo "scale=2;100 * (1 - ($FAILED / $TESTS))" | bc) + echo "# CONCLUSION: ($PERC%) $FAILED out of $TESTS tests failed" + + if [ $TESTS -ne $CUR_TEST ]; then + echo -e "# expected $TESTS, but got $CUR_TEST tests" + fi + + if [ $FAILED -ne 0 ]; then + exit 1 + fi +} + +# $1 is the value to be tested +# $2 description +function ok { + CUR_TEST=$((CUR_TEST + 1)) + + if [ $1 -eq 0 ]; then + echo "ok $CUR_TEST - $2" + else + echo "not ok $CUR_TEST - $2" + echo -e " returned '$1'" + FAILED=$((FAILED + 1)) + fi +} + +# $1 is the expected value +# $2 is the actual value +# $3 description +function is { + CUR_TEST=$((CUR_TEST + 1)) + + if [ "$1" = "$2" ]; then + echo "ok $CUR_TEST - $3" + else + echo "not ok $CUR_TEST - $3" + echo -e " exptected '$2', but got '$1'" + FAILED=$((FAILED + 1)) + fi +} diff --git a/src/initramfs-init.sh b/src/initramfs-init.sh index 07272c0..a566b57 100644 --- a/src/initramfs-init.sh +++ b/src/initramfs-init.sh @@ -6,7 +6,7 @@ mount -t proc proc /proc insmod /usr/keylogger.ko -# test the module +# run each test echo "$(cd usr; ls -v1 tests | while read line; do tests/$line; echo; done)" exec /bin/sh diff --git a/src/libs/testing-library b/src/libs/testing-library deleted file mode 100755 index a1cf3c1..0000000 --- a/src/libs/testing-library +++ /dev/null @@ -1,53 +0,0 @@ -#!/bin/sh - -function description { - echo "# DESCRIPTION: $1" -} - -# $1 is the number of total tests -function plan { - TESTS=$1; FAILED=0; CUR_TEST=0 - echo "1..$TESTS" -} - -function conclude { - PERC=$(echo "scale=2;100 * $FAILED / $TESTS" | bc) - echo "# CONCLUSION: ($PERC%) $FAILED out of $TESTS tests failed" - - if [ $TESTS -ne $CUR_TEST ]; then - echo -e "# expected $TESTS, but got $CUR_TEST tests" - fi - - if [ $FAILED -ne 0 ]; then - exit 1 - fi -} - -# $1 is the value to be tested -# $2 description -function ok { - CUR_TEST=$((CUR_TEST + 1)) - - if [ $1 -eq 0 ]; then - echo "ok $CUR_TEST - $2" - else - echo "not ok $CUR_TEST - $2" - echo -e " returned '$1'" - FAILED=$((FAILED + 1)) - fi -} - -# $1 is the expected value -# $2 is the actual value -# $3 description -function is { - CUR_TEST=$((CUR_TEST + 1)) - - if [ "$1" = "$2" ]; then - echo "ok $CUR_TEST - $3" - else - echo "not ok $CUR_TEST - $3" - echo -e " exptected '$2', but got '$1'" - FAILED=$((FAILED + 1)) - fi -} diff --git a/src/tests/test1.sh b/src/tests/test1.sh index a432e5f..5ac52d8 100755 --- a/src/tests/test1.sh +++ b/src/tests/test1.sh @@ -1,5 +1,5 @@ #!/bin/sh -. libs/testing-library +. include/test-util.sh description "Test _test_module" plan 5 @@ -7,5 +7,5 @@ is "$(cat /proc/_test_module)" "You have no previous messages" "No message read" ok $(echo kek > /proc/_test_module; echo "$?") "Successful write" is "$(cat /proc/_test_module)" "Your last message was: kek" "Message read" ok $(echo something > /proc/_test_module; echo "$?") "Successful write" -is "$(cat /proc/_test_module)" "Your last message was: kek" "Message read" +is "$(cat /proc/_test_module)" "Your last message was: something" "Message read" conclude diff --git a/src/tests/test2.c b/src/tests/test2.c new file mode 100644 index 0000000..dc24f28 --- /dev/null +++ b/src/tests/test2.c @@ -0,0 +1,13 @@ +#include "test-util.h" + +int main(void) +{ + description("Test _test_module in c"); + plan(3); + + ok(0, "test something"); + is_s("kek", "kek", "test kek"); + is_i(1, 1, "test 1"); + + return conclude(); +} -- cgit v1.2.3