diff options
Diffstat (limited to 'test/src/ht/test_ft_htset.c')
| -rw-r--r-- | test/src/ht/test_ft_htset.c | 72 |
1 files changed, 58 insertions, 14 deletions
diff --git a/test/src/ht/test_ft_htset.c b/test/src/ht/test_ft_htset.c index aa6bfc5..c4b53b9 100644 --- a/test/src/ht/test_ft_htset.c +++ b/test/src/ht/test_ft_htset.c @@ -16,28 +16,28 @@ TEST_TEAR_DOWN(ft_htset) TEST(ft_htset, segfault) { - TEST_ASSERT_SEGFAULT(ft_htset(NULL, "", strdup(""))); - TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), NULL, strdup(""))); - TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "", NULL)); - TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "", strdup(""))); - TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "hi", strdup(""))); - TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "asdfasdfasdc", strdup(""))); + TEST_ASSERT_SEGFAULT(ft_htset(NULL, "", strdup(""), NULL)); + TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), NULL, strdup(""), NULL)); + TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "", NULL, NULL)); + TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "", strdup(""), NULL)); + TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "hi", strdup(""), NULL)); + TEST_ASSERT_SEGFAULT(ft_htset(ft_htnew(1), "asdfasdfasdc", strdup(""), NULL)); } TEST(ft_htset, error_null) { - TEST_ASSERT_NULL(ft_htset(NULL, "", strdup("1"))); - TEST_ASSERT_NULL(ft_htset(ht, NULL, strdup("2"))); - TEST_ASSERT_NOT_NULL(ft_htset(ht, "", strdup("3"))); - TEST_ASSERT_NOT_NULL(ft_htset(ht, "a", strdup("4"))); - TEST_ASSERT_NOT_NULL(ft_htset(ht, "b", strdup("5"))); - TEST_ASSERT_NOT_NULL(ft_htset(ht, "c", strdup("6"))); - TEST_ASSERT_NOT_NULL(ft_htset(ht, "d", strdup("7"))); + TEST_ASSERT_NULL(ft_htset(NULL, "", strdup("1"), NULL)); + TEST_ASSERT_NULL(ft_htset(ht, NULL, strdup("2"), NULL)); + TEST_ASSERT_NOT_NULL(ft_htset(ht, "", strdup("3"), NULL)); + TEST_ASSERT_NOT_NULL(ft_htset(ht, "a", strdup("4"), NULL)); + TEST_ASSERT_NOT_NULL(ft_htset(ht, "b", strdup("5"), NULL)); + TEST_ASSERT_NOT_NULL(ft_htset(ht, "c", strdup("6"), NULL)); + TEST_ASSERT_NOT_NULL(ft_htset(ht, "d", strdup("7"), NULL)); } TEST(ft_htset, happy_path) { - t_ftht_content *content = ft_htset(ht, "bonjour", strdup("content")); + t_ftht_content *content = ft_htset(ht, "bonjour", strdup("content"), NULL); TEST_ASSERT_NOT_NULL(content); TEST_ASSERT_NOT_NULL(content->key); TEST_ASSERT_NOT_NULL(content->value); @@ -45,7 +45,51 @@ TEST(ft_htset, happy_path) TEST_ASSERT_EQUAL_STRING(content->value, "content"); } +TEST(ft_htset, reset) +{ + t_ftht *small = NULL; + + small = ft_htnew(3); + + t_ftht_content *content = ft_htset(ht, "bonjour", strdup("content"), free); + TEST_ASSERT_NOT_NULL(content); + TEST_ASSERT_NOT_NULL(content->key); + TEST_ASSERT_NOT_NULL(content->value); + TEST_ASSERT_EQUAL_STRING(content->key, "bonjour"); + TEST_ASSERT_EQUAL_STRING(content->value, "content"); + + t_ftht_content *content_re = ft_htset(ht, "bonjour", strdup("yo"), free); + TEST_ASSERT_NOT_NULL(content_re); + TEST_ASSERT_EQUAL_PTR(content, content_re); + TEST_ASSERT_NOT_NULL(content_re->key); + TEST_ASSERT_NOT_NULL(content_re->value); + TEST_ASSERT_EQUAL_STRING(content_re->key, "bonjour"); + TEST_ASSERT_EQUAL_STRING(content_re->value, "yo"); +} + TEST(ft_htset, collision) { + t_ftht *small = NULL; + small = ft_htnew(1); + + t_ftht_content *content1 = ft_htset(ht, "bonjour", strdup("content1"), free); + TEST_ASSERT_NOT_NULL(content1); + TEST_ASSERT_NOT_NULL(content1->key); + TEST_ASSERT_NOT_NULL(content1->value); + TEST_ASSERT_EQUAL_STRING(content1->key, "bonjour"); + TEST_ASSERT_EQUAL_STRING(content1->value, "content1"); + + t_ftht_content *content2 = ft_htset(ht, "aurevoir", strdup("content2"), free); + TEST_ASSERT_NOT_NULL(content2); + TEST_ASSERT_NOT_NULL(content2->key); + TEST_ASSERT_NOT_NULL(content2->value); + TEST_ASSERT_EQUAL_STRING(content2->key, "aurevoir"); + TEST_ASSERT_EQUAL_STRING(content2->value, "content2"); + t_ftht_content *content3 = ft_htset(ht, "aloa", strdup("content3"), free); + TEST_ASSERT_NOT_NULL(content3); + TEST_ASSERT_NOT_NULL(content3->key); + TEST_ASSERT_NOT_NULL(content3->value); + TEST_ASSERT_EQUAL_STRING(content3->key, "aloa"); + TEST_ASSERT_EQUAL_STRING(content3->value, "content3"); } |
