X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fstruct%2Fbitarray_test.c;h=0dad3a270ef9796c87bb8b92f305beb9591120fd;hb=705e92ca3e6a5bd0223f21a8fd9ac714f3253a5f;hp=e65aa146a1e6b7ba4d372e1b2ae0fa346eca4608;hpb=f56cf80247f6fbe18ddd34357ee306107fffeca0;p=bertos.git diff --git a/bertos/struct/bitarray_test.c b/bertos/struct/bitarray_test.c index e65aa146..0dad3a27 100644 --- a/bertos/struct/bitarray_test.c +++ b/bertos/struct/bitarray_test.c @@ -45,18 +45,30 @@ #define TEST1_LEN 31 #define TEST2_LEN 17 +#define TEST3_LEN 16 +#define TEST4_LEN 23 +#define TEST5_LEN 72 -ALLOC_BITARRAY(test1, TEST1_LEN); -ALLOC_BITARRAY(test2, TEST2_LEN); +BITARRAY_ALLOC(test1, TEST1_LEN); +BITARRAY_ALLOC(test2, TEST2_LEN); +BITARRAY_ALLOC(test3, TEST3_LEN); +BITARRAY_ALLOC(test4, TEST4_LEN); +BITARRAY_ALLOC(test5, TEST5_LEN); BitArray bitx1; BitArray bitx2; +BitArray bitx3; +BitArray bitx4; +BitArray bitx5; int bitarray_testSetup(void) { kdbg_init(); - init_bitarray(&bitx1, TEST1_LEN, test1, sizeof(test1)); - init_bitarray(&bitx2, TEST2_LEN, test2, sizeof(test2)); + bitarray_init(&bitx1, TEST1_LEN, test1, sizeof(test1)); + bitarray_init(&bitx2, TEST2_LEN, test2, sizeof(test2)); + bitarray_init(&bitx3, TEST3_LEN, test3, sizeof(test3)); + bitarray_init(&bitx4, TEST4_LEN, test4, sizeof(test4)); + bitarray_init(&bitx5, TEST5_LEN, test5, sizeof(test5)); return 0; } @@ -67,7 +79,7 @@ int bitarray_testRun(void) bitarray_dump(&bitx1); for (size_t i = 0; i < TEST1_LEN; i++) { - if (!((bool)(i % 2) == bitarray_check(&bitx1,i))) + if (!((bool)(i % 2) == bitarray_test(&bitx1,i))) goto error; } @@ -83,38 +95,72 @@ int bitarray_testRun(void) bitarray_dump(&bitx1); for (size_t i = 0; i < TEST1_LEN; i++) { - if (!((bool)(i % 2) == bitarray_check(&bitx1, i))) + if (!((bool)(i % 2) == bitarray_test(&bitx1, i))) goto error; } memset(test1, 0, sizeof(test1)); bitarray_set(&bitx1, 0); bitarray_dump(&bitx1); - if (!bitarray_check(&bitx1, 0)) + if (!bitarray_test(&bitx1, 0)) goto error; memset(test1, 0, sizeof(test1)); bitarray_set(&bitx1, TEST1_LEN); bitarray_dump(&bitx1); - if (!bitarray_check(&bitx1, TEST1_LEN)) + if (!bitarray_test(&bitx1, TEST1_LEN)) goto error; kprintf("Test 2\n"); memset(test2, 0xFF, sizeof(test2)); bitarray_dump(&bitx2); - if (!bitarray_full(&bitx2)) + if (!bitarray_isFull(&bitx2)) goto error; memset(test2, 0xFF, sizeof(test2)); bitarray_clear(&bitx2, 5); bitarray_dump(&bitx2); - if (bitarray_full(&bitx2)) + if (bitarray_isFull(&bitx2)) goto error; memset(test2, 0xFF, sizeof(test2)); bitarray_clear(&bitx2, 13); bitarray_dump(&bitx2); - if (bitarray_full(&bitx2)) + if (bitarray_isFull(&bitx2)) + goto error; + + kprintf("Test 3\n"); + bitarray_set(&bitx3, 12); + bitarray_dump(&bitx3); + int pos = 0; + pos = bitarray_firstSetBit(&bitx3); + if (pos != 12) + goto error; + + kprintf("Test 4\n"); + bitarray_set(&bitx4, TEST4_LEN); + bitarray_dump(&bitx4); + pos = 0; + pos = bitarray_firstSetBit(&bitx4); + if (pos != 23) + goto error; + + kprintf("Test 5\n"); + bitarray_set(&bitx5, 71); + bitarray_dump(&bitx5); + pos = 0; + pos = bitarray_firstSetBit(&bitx5); + kprintf("pos %d\n", pos); + if (pos != 71) + goto error; + + kprintf("Test 6\n"); + bitarray_clear(&bitx5, 71); + bitarray_set(&bitx5, 5); + bitarray_dump(&bitx5); + pos = 0; + pos = bitarray_firstSetBit(&bitx5); + if (pos != 5) goto error; return 0;