X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fstruct%2Fbitarray_test.c;h=b917d0f4d60ec89fbf51c576b2b0d020db674843;hb=f248bd5d8be37c741ef62386d82e4975723e09c3;hp=81bcd8abbb80d5429e9f35211ee5cdb24ac33379;hpb=9c426a0e423177adc591eb7bd43a2d07b49ed39f;p=bertos.git diff --git a/bertos/struct/bitarray_test.c b/bertos/struct/bitarray_test.c index 81bcd8ab..b917d0f4 100644 --- a/bertos/struct/bitarray_test.c +++ b/bertos/struct/bitarray_test.c @@ -43,68 +43,85 @@ #include -ALLOC_BITARRAY(test1, 31); -BitArray ctx; +#define TEST1_LEN 31 +#define TEST2_LEN 17 + +BITARRAY_ALLOC(test1, TEST1_LEN); +BITARRAY_ALLOC(test2, TEST2_LEN); + +BitArray bitx1; +BitArray bitx2; int bitarray_testSetup(void) { kdbg_init(); - init_bitarray(&ctx, test1, sizeof(test1)); + bitarray_init(&bitx1, TEST1_LEN, test1, sizeof(test1)); + bitarray_init(&bitx2, TEST2_LEN, test2, sizeof(test2)); return 0; } int bitarray_testRun(void) { memset(test1, 0xaa, sizeof(test1)); - bitarray_dump(&ctx); - for (size_t i = 0; i < bitarray_size(&ctx); i++) + bitarray_dump(&bitx1); + for (size_t i = 0; i < TEST1_LEN; i++) { - if (!((bool)(i % 2) == bitarray_check(&ctx, i))) - { - kprintf("Error!\n"); - return -1; - } + if (!((bool)(i % 2) == bitarray_test(&bitx1,i))) + goto error; } memset(test1, 0, sizeof(test1)); - for (size_t i = 0; i < bitarray_size(&ctx); i++) + for (size_t i = 0; i < TEST1_LEN; i++) { if ((i % 2) == 0) - bitarray_clear(&ctx, i); + bitarray_clear(&bitx1,i); else - bitarray_set(&ctx, i); + bitarray_set(&bitx1, i); } - bitarray_dump(&ctx); - for (size_t i = 0; i < bitarray_size(&ctx); i++) + bitarray_dump(&bitx1); + for (size_t i = 0; i < TEST1_LEN; i++) { - if (!((bool)(i % 2) == bitarray_check(&ctx, i))) - { - kprintf("Error!\n"); - return -1; - } + if (!((bool)(i % 2) == bitarray_test(&bitx1, i))) + goto error; } memset(test1, 0, sizeof(test1)); - bitarray_set(&ctx, 0); - bitarray_dump(&ctx); - if (!bitarray_check(&ctx, 0)) - { - kprintf("Error!\n"); - return -1; - } + bitarray_set(&bitx1, 0); + bitarray_dump(&bitx1); + if (!bitarray_test(&bitx1, 0)) + goto error; memset(test1, 0, sizeof(test1)); - bitarray_set(&ctx, bitarray_size(&ctx)); - bitarray_dump(&ctx); - if (!bitarray_check(&ctx, bitarray_size(&ctx))) - { - kprintf("Error!\n"); - return -1; - } + bitarray_set(&bitx1, TEST1_LEN); + bitarray_dump(&bitx1); + if (!bitarray_test(&bitx1, TEST1_LEN)) + goto error; + + kprintf("Test 2\n"); + memset(test2, 0xFF, sizeof(test2)); + bitarray_dump(&bitx2); + if (!bitarray_isFull(&bitx2)) + goto error; + + memset(test2, 0xFF, sizeof(test2)); + bitarray_clear(&bitx2, 5); + bitarray_dump(&bitx2); + if (bitarray_isFull(&bitx2)) + goto error; + + memset(test2, 0xFF, sizeof(test2)); + bitarray_clear(&bitx2, 13); + bitarray_dump(&bitx2); + if (bitarray_isFull(&bitx2)) + goto error; return 0; + +error: + kprintf("Error!\n"); + return -1; } int bitarray_testTearDown(void)