blob: 0cfcd44d5196841a678377b41b067656237ce357 [file] [log] [blame]
/* Test of src/bitstring.c
*/
#include <stdlib.h>
#include <src/common/log.h>
#include <src/common/bitstring.h>
#include <sys/time.h>
#include <check.h>
START_TEST(test_basic_vixie_functions)
{
bitstr_t *bs = bit_alloc(16), *bs2, *bs3 = bit_alloc(16);
/*bit_set(bs, 42);*/ /* triggers TEST in bit_set - OK */
bit_set(bs,9);
bit_set(bs,14);
ck_assert_msg(bit_test(bs,9), "bit 9 set");
ck_assert_msg(!bit_test(bs,12), "bit 12 not set" );
ck_assert_msg(bit_test(bs,14), "bit 14 set");
bs2 = bit_copy(bs);
bit_fill_gaps(bs2);
ck_assert_msg(bit_ffs(bs2) == 9, "first bit set = 9 ");
ck_assert_msg(bit_fls(bs2) == 14, "last bit set = 14");
ck_assert_msg(bit_set_count(bs2) == 6, "bitstring");
ck_assert_msg(bit_test(bs2,12), "bitstring");
ck_assert_msg(bit_super_set(bs,bs2) == 1, "bitstring");
ck_assert_msg(bit_super_set(bs2,bs) == 0, "bitstring");
/* bs3 == bit_not(bs) */
bit_unfmt_hexmask(bs3, "0xBDFF");
bit_not(bs3);
ck_assert_msg(bit_super_set(bs,bs3) == 1, "bit_super_set after bit_not");
ck_assert_msg(bit_super_set(bs3,bs) == 1, "bit_super_set after bit_not");
bit_clear(bs,14);
ck_assert_msg(!bit_test(bs,14), "bitstring");
bit_nclear(bs,9,14);
ck_assert_msg(!bit_test(bs,9), "bitstring");
ck_assert_msg(!bit_test(bs,12), "bitstring");
ck_assert_msg(!bit_test(bs,14), "bitstring");
bit_nset(bs,9,14);
ck_assert_msg(bit_test(bs,9), "bitstring");
ck_assert_msg(bit_test(bs,12), "bitstring");
ck_assert_msg(bit_test(bs,14), "bitstring");
ck_assert_msg(bit_ffs(bs) == 9, "ffs");
ck_assert_msg(bit_ffc(bs) == 0, "ffc");
bit_nset(bs,0,8);
ck_assert_msg(bit_ffc(bs) == 15, "ffc");
bit_free(bs);
bit_free(bs2);
bit_free(bs3);
/*bit_set(bs,9); */ /* triggers TEST in bit_set - OK */
}
END_TEST
START_TEST(test_and_or_not)
{
bitstr_t *bs1 = bit_alloc(128);
bitstr_t *bs2 = bit_alloc(128);
bit_set(bs1, 100);
bit_set(bs1, 104);
bit_set(bs2, 100);
bit_and(bs1, bs2);
ck_assert_msg(bit_test(bs1, 100), "and");
ck_assert_msg(!bit_test(bs1, 104), "and");
bit_set(bs2, 110);
bit_set(bs2, 111);
bit_set(bs2, 112);
bit_or(bs1, bs2);
ck_assert_msg(bit_test(bs1, 100), "or");
ck_assert_msg(bit_test(bs1, 110), "or");
ck_assert_msg(bit_test(bs1, 111), "or");
ck_assert_msg(bit_test(bs1, 112), "or");
bit_not(bs1);
ck_assert_msg(!bit_test(bs1, 100), "not");
ck_assert_msg(bit_test(bs1, 12), "not");
bit_free(bs1);
bit_free(bs2);
bs1 = bit_alloc(32);
bs2 = bit_alloc(33);
bit_set_all(bs2);
bit_and(bs2, bs1);
ck_assert_msg(!bit_test(bs2, 31), "diff size and");
ck_assert_msg(bit_test(bs2, 32), "diff size and");
bit_clear(bs2, 32);
bit_not(bs1);
bit_or(bs2, bs1);
ck_assert_msg(!bit_test(bs2, 32), "diff size or");
bit_set_all(bs2);
bit_set_all(bs1);
bit_and_not(bs2, bs1);
ck_assert_msg(!bit_test(bs2, 31), "diff size and_not");
ck_assert_msg(bit_test(bs2, 32), "diff size and_not");
bit_set_all(bs2);
bit_clear(bs2, 32);
bit_not(bs1);
bit_or_not(bs2, bs1);
ck_assert_msg(bit_test(bs2, 31), "diff size and_not");
ck_assert_msg(!bit_test(bs2, 32), "diff size and_not");
bit_free(bs1);
bit_free(bs2);
}
END_TEST
START_TEST(test_bit_selection)
{
bitstr_t *bs1 = bit_alloc(128), *bs2;
bit_set(bs1, 21);
bit_set(bs1, 100);
bit_fill_gaps(bs1);
bs2 = bit_pick_cnt(bs1,20);
if (bs2) {
ck_assert_msg(bit_set_count(bs2) == 20, "pick");
ck_assert_msg(bit_ffs(bs2) == 21, "pick");
ck_assert_msg(bit_fls(bs2) == 40, "pick");
bit_free(bs2);
}
else
ck_assert_msg(0, "alloc fail");
bit_free(bs1);
bs1 = bit_alloc(11);
bit_nset(bs1, 0, 10);
bit_not(bs1);
ck_assert_msg(bit_ffs(bs1) == -1, "pick");
ck_assert_msg(bit_fls(bs1) == -1, "pick");
bit_free(bs1);
}
END_TEST
START_TEST(test_realloc)
{
bitstr_t *bs = bit_alloc(1);
ck_assert_msg(bit_ffs(bs) == -1, "bitstring");
bit_set(bs,0);
/*bit_set(bs, 1000);*/ /* triggers TEST in bit_set - OK */
bs = bit_realloc(bs,1048576);
bit_set(bs,1000);
bit_set(bs,1048575);
ck_assert_msg(bit_test(bs, 0), "bitstring");
ck_assert_msg(bit_test(bs, 1000), "bitstring");
ck_assert_msg(bit_test(bs, 1048575), "bitstring");
ck_assert_msg(bit_set_count(bs) == 3, "bitstring");
bit_clear(bs,0);
bit_clear(bs,1000);
ck_assert_msg(bit_set_count(bs) == 1, "bitstring");
ck_assert_msg(bit_ffs(bs) == 1048575, "bitstring");
bit_free(bs);
}
END_TEST
START_TEST(test_bit_fmt)
{
char tmpstr[1024];
bitstr_t *bs = bit_alloc(1024);
ck_assert_msg(!strcmp(bit_fmt(tmpstr,sizeof(tmpstr),bs), ""), "bitstring");
bit_set(bs,42);
ck_assert_msg(!strcmp(bit_fmt(tmpstr,sizeof(tmpstr),bs), "42"), "bitstring");
bit_set(bs,102);
ck_assert_msg(!strcmp(bit_fmt(tmpstr,sizeof(tmpstr),bs), "42,102"), "bitstring");
bit_nset(bs,9,14);
ck_assert_msg(!strcmp(bit_fmt(tmpstr,sizeof(tmpstr), bs),
"9-14,42,102"), "bitstring");
}
END_TEST
START_TEST(test_bit_nffc_nffs)
{
bitstr_t *bs = bit_alloc(1024);
bit_set(bs, 2);
bit_set(bs, 6);
bit_set(bs, 7);
bit_nset(bs,12,1018);
ck_assert_msg(bit_nffc(bs, 2) == 0, "bitstring");
ck_assert_msg(bit_nffc(bs, 3) == 3, "bitstring");
ck_assert_msg(bit_nffc(bs, 4) == 8, "bitstring");
ck_assert_msg(bit_nffc(bs, 5) == 1019, "bitstring");
ck_assert_msg(bit_nffc(bs, 6) == -1, "bitstring");
ck_assert_msg(bit_nffs(bs, 1) == 2, "bitstring");
ck_assert_msg(bit_nffs(bs, 2) == 6, "bitstring");
ck_assert_msg(bit_nffs(bs, 100) == 12, "bitstring");
ck_assert_msg(bit_nffs(bs, 1023) == -1, "bitstring");
bit_free(bs);
}
END_TEST
START_TEST(test_bit_equal)
{
bitstr_t *bs1 = bit_alloc(32);
bitstr_t *bs2 = bit_alloc(32);
bit_nset(bs1, 0, 31);
bit_not(bs2);
ck_assert_msg(bit_equal(bs1, bs2), "bit_equal");
ck_assert_msg(bit_equal(bs2, bs1), "bit_equal");
bit_not(bs2);
ck_assert_msg(!bit_equal(bs1, bs2), "not bit_equal");
ck_assert_msg(!bit_equal(bs2, bs1), "not bit_equal");
bit_free(bs1);
bit_free(bs2);
bs1 = bit_alloc(10);
bs2 = bit_alloc(10);
bit_set(bs1, 0);
bit_nset(bs1, 3, 9);
bit_nset(bs2, 0, 9);
ck_assert_msg(!bit_equal(bs1, bs2), "not bit_equal");
bit_free(bs1);
bit_free(bs2);
bs1 = bit_alloc(10);
bs2 = bit_alloc(10);
bit_not(bs1);
bit_not(bs2);
ck_assert_msg(bit_equal(bs1, bs2), "bit_equal");
ck_assert_msg(bit_equal(bs2, bs1), "bit_equal");
bit_free(bs1);
bit_free(bs2);
}
END_TEST
START_TEST(test_bit_unfmt)
{
bitstr_t *bs = bit_alloc(1024);
bitstr_t *bs2 = bit_alloc(1024);
char tmpstr[4096];
bit_set(bs,1);
bit_set(bs,3);
bit_set(bs,30);
bit_nset(bs,42,64);
bit_nset(bs,97,1000);
bit_fmt(tmpstr, sizeof(tmpstr), bs);
ck_assert_msg(bit_unfmt(bs2, tmpstr) != -1, "bitstring");
ck_assert_msg(bit_equal(bs, bs2), "bitstring");
bit_free(bs);
bit_free(bs2);
}
END_TEST
START_TEST(test_bit_overlap)
{
bitstr_t *bs = bit_alloc(1000);
bitstr_t *bs2;
bit_set(bs,1);
bit_set(bs,3);
bit_set(bs,64);
bit_set(bs,998);
bit_set(bs,999);
bs2 = bit_copy(bs);
bit_not(bs2);
ck_assert_msg(bit_overlap(bs, bs2) == 0, "bitstring");
ck_assert_msg(bit_overlap_any(bs, bs2) == 0, "bitstring");
bit_set(bs2,3);
bit_set(bs2,64);
bit_set(bs2,999);
ck_assert_msg(bit_overlap(bs, bs2) == 3, "bitstring");
ck_assert_msg(bit_overlap_any(bs, bs2) == 1, "bitstring any");
bit_free(bs);
bit_free(bs2);
}
END_TEST
START_TEST(test_bit_set_count_range)
{
bitstr_t *bs = bit_alloc(16);
bit_nset(bs,0,14);
ck_assert_msg(bit_set_count_range(bs,0,14) == 14, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,2,14) == 12, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,2,15) == 13, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,2,16) == 13, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,0,15) == 15, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,0,16) == 15, "bit_set_count_range");
bit_set(bs,15);
ck_assert_msg(bit_set_count_range(bs,0,16) == 16, "bit_set_count_range");
bs = bit_realloc(bs,128);
bit_nset(bs,0,127);
ck_assert_msg(bit_set_count_range(bs,0,63) == 63, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,0,64) == 64, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,0,65) == 65, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,1,63) == 62, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,1,64) == 63, "bit_set_count_range");
ck_assert_msg(bit_set_count_range(bs,1,65) == 64, "bit_set_count_range");
bit_free(bs);
}
END_TEST
START_TEST(test_bit_ffs_from_bit)
{
bitstr_t *bs = bit_alloc(256);
bit_set(bs,0);
bit_set(bs,2);
bit_set(bs,63);
bit_set(bs,64);
ck_assert_msg(bit_ffs_from_bit(bs,0) == 0, "bit_ffs_from_bit");
ck_assert_msg(bit_ffs_from_bit(bs,1) == 2, "bit_ffs_from_bit");
ck_assert_msg(bit_ffs_from_bit(bs,2) == 2, "bit_ffs_from_bit");
ck_assert_msg(bit_ffs_from_bit(bs,3) == 63, "bit_ffs_from_bit");
ck_assert_msg(bit_ffs_from_bit(bs,63) == 63, "bit_ffs_from_bit");
ck_assert_msg(bit_ffs_from_bit(bs,64) == 64, "bit_ffs_from_bit");
ck_assert_msg(bit_ffs_from_bit(bs,65) == -1, "bit_ffs_from_bit");
bit_clear_all(bs);
bit_set(bs, 130);
ck_assert_msg(bit_ffs_from_bit(bs,1) == 130, "bit_ffs_from_bit");
bit_free(bs);
}
END_TEST
int main(void)
{
int number_failed;
log_options_t log_opts = LOG_OPTS_INITIALIZER;
log_opts.stderr_level = LOG_LEVEL_DEBUG5;
log_init("pack-test", log_opts, 0, NULL);
Suite *s = suite_create("pack");
TCase *tc_core = tcase_create("pack");
tcase_add_test(tc_core, test_basic_vixie_functions);
tcase_add_test(tc_core, test_and_or_not);
tcase_add_test(tc_core, test_bit_selection);
tcase_add_test(tc_core, test_realloc);
tcase_add_test(tc_core, test_bit_fmt);
tcase_add_test(tc_core, test_bit_nffc_nffs);
tcase_add_test(tc_core, test_bit_equal);
tcase_add_test(tc_core, test_bit_unfmt);
tcase_add_test(tc_core, test_bit_overlap);
tcase_add_test(tc_core, test_bit_set_count_range);
tcase_add_test(tc_core, test_bit_ffs_from_bit);
suite_add_tcase(s, tc_core);
SRunner *sr = srunner_create(s);
srunner_run_all(sr, CK_ENV);
number_failed = srunner_ntests_failed(sr);
srunner_free(sr);
return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
}