From cd1df65dc36ac35d526de195284d5ebf18e1f92b Mon Sep 17 00:00:00 2001 From: Marc Date: Fri, 17 Dec 2021 18:52:36 +0000 Subject: test: Add ctests for generation functions. This commit also enforces error code checking on functions inside of the generation functions, such as for `libwifi_quick_add_tag`. --- test/src/reassoc_resp_tests.c | 91 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 91 insertions(+) create mode 100644 test/src/reassoc_resp_tests.c (limited to 'test/src/reassoc_resp_tests.c') diff --git a/test/src/reassoc_resp_tests.c b/test/src/reassoc_resp_tests.c new file mode 100644 index 0000000..8167916 --- /dev/null +++ b/test/src/reassoc_resp_tests.c @@ -0,0 +1,91 @@ +#include "../../src/libwifi.h" + +#include +#include +#include + +#define BCAST_MAC "\xff\xff\xff\xff\xff\xff" +#define TO_MAC "\x00\x20\x91\xAA\xBB\xCC" +const unsigned char to[] = TO_MAC; +const unsigned char bcast[] = BCAST_MAC; + +int test_reassoc_resp_gen_full() { + struct libwifi_reassoc_resp reassoc_resp = {0}; + + int ret = libwifi_create_reassoc_resp(&reassoc_resp, bcast, to, 11); + if (ret != 0) { + fprintf(stderr, "Failed to create reassoc_resp: %s\n", strerror(ret)); + return ret; + } + + int reassoc_resp_len = libwifi_get_reassoc_resp_length(&reassoc_resp); + if (reassoc_resp_len <= 0) { + fprintf(stderr, "Invalid reassoc_resp length: %d\n", reassoc_resp_len); + return reassoc_resp_len; + } + + unsigned char *buf = malloc(reassoc_resp_len); + if (buf == NULL) { + fprintf(stderr, "Failed to allocate buffer\n"); + return -1; + } + + int dump_len = libwifi_dump_reassoc_resp(&reassoc_resp, buf, reassoc_resp_len); + if (dump_len <= 0) { + fprintf(stderr, "Failed to dump reassoc_resp\n"); + return ret; + } + + return 0; +} + +int test_reassoc_resp_add_tag() { + struct libwifi_reassoc_resp reassoc_resp = {0}; + + int ret = libwifi_create_reassoc_resp(&reassoc_resp, bcast, to, 11); + if (ret != 0) { + fprintf(stderr, "Failed to create reassoc_resp: %s\n", strerror(ret)); + return ret; + } + + ret = libwifi_quick_add_tag(&reassoc_resp.tags, TAG_VENDOR_SPECIFIC, (const unsigned char *) "\x00\x11\x22\xAAHello World", 15); + if (ret != 0) { + fprintf(stderr, "Failed to add reassoc_resp tagged parameter: %s\n", strerror(ret)); + return ret; + } + + int reassoc_resp_len = libwifi_get_reassoc_resp_length(&reassoc_resp); + if (reassoc_resp_len <= 0) { + fprintf(stderr, "Invalid reassoc_resp length: %d\n", reassoc_resp_len); + return reassoc_resp_len; + } + + unsigned char *buf = malloc(reassoc_resp_len); + if (buf == NULL) { + fprintf(stderr, "Failed to allocate buffer\n"); + return -1; + } + + int dump_len = libwifi_dump_reassoc_resp(&reassoc_resp, buf, reassoc_resp_len); + if (dump_len <= 0) { + fprintf(stderr, "Failed to dump reassoc_resp\n"); + return ret; + } + + return 0; +} + +int main(int argc, char **argv) { + if (argc < 2) { + printf("Specify test\n"); + return -1; + } + + if (strcmp(argv[1], "--reassoc_resp-gen-full") == 0) { + return test_reassoc_resp_gen_full(); + } else if (strcmp(argv[1], "--reassoc_resp-gen-tags") == 0) { + return test_reassoc_resp_add_tag(); + } + + return -1; +} -- cgit 1.4.1