Added tests for getdns_dict_get_names()

This commit is contained in:
Craig E. Despeaux 2014-01-06 15:51:11 -05:00
parent db507121cf
commit 02ebe85773
2 changed files with 113 additions and 0 deletions

View File

@ -16,6 +16,7 @@
#include "check_getdns_address_sync.h"
#include "check_getdns_list_get_length.h"
#include "check_getdns_list_get_data_type.h"
#include "check_getdns_dict_get_names.h"
int
main (void)
@ -31,6 +32,7 @@ main (void)
Suite *getdns_cancel_callback_suite(void);
Suite *getdns_list_get_length_suite(void);
Suite *getdns_list_get_data_type_suite(void);
Suite *getdns_dict_get_names_suite(void);
sr = srunner_create(getdns_general_suite());
srunner_add_suite(sr, getdns_general_sync_suite());
@ -40,6 +42,7 @@ main (void)
srunner_add_suite(sr, getdns_cancel_callback_suite());
srunner_add_suite(sr, getdns_list_get_length_suite());
srunner_add_suite(sr, getdns_list_get_data_type_suite());
srunner_add_suite(sr, getdns_dict_get_names_suite());
srunner_set_log(sr, "check_getdns.log");
srunner_run_all(sr, CK_NORMAL);

View File

@ -0,0 +1,110 @@
#ifndef _check_getdns_dict_get_names_h_
#define _check_getdns_dict_get_names_h_
/*
**************************************************************************
* *
* T E S T S F O R G E T D N S _ D I C T _ G E T _ N A M E S *
* *
**************************************************************************
*/
START_TEST (getdns_dict_get_names_1)
{
/*
* this_dict = NULL
* expect = GETDNS_RETURN_NO_SUCH_DICT_NAME
*/
struct getdns_dict *this_dict = NULL;
struct getdns_list *answer = NULL;
ASSERT_RC(getdns_dict_get_names(this_dict, &answer),
GETDNS_RETURN_NO_SUCH_DICT_NAME, "Return code from getdns_dict_get_names()");
}
END_TEST
START_TEST (getdns_dict_get_names_2)
{
/*
* answer = NULL
* expect: GETDNS_RETURN_NO_SUCH_LIST_ITEM
*/
struct getdns_dict *this_dict = NULL;
DICT_CREATE(this_dict);
ASSERT_RC(getdns_dict_get_names(this_dict, NULL),
GETDNS_RETURN_NO_SUCH_DICT_NAME, "Return code from getdns_dict_get_names()");
DICT_DESTROY(this_dict);
}
END_TEST
START_TEST (getdns_dict_get_names_3)
{
/*
* Create a dict with three keys ("ten" = 10, "eleven" = 11, "twelve" = 12)
* Call getdns_dict_get_names()
* Iterate through list and append names together in a single string
* expect: string == "teneleventwelve"
*/
struct getdns_dict *this_dict = NULL;
struct getdns_list *answer = NULL;
char *keys[3] = { "ten", "eleven", "twelve" };
uint32_t values[3] = { 10, 11, 12 };
int i;
size_t length;
struct getdns_bindata *key = NULL;
char string_buffer[20];
DICT_CREATE(this_dict);
for(i = 0; i < 3; i++)
{
ASSERT_RC(getdns_dict_set_int(this_dict, keys[i], values[i]),
GETDNS_RETURN_GOOD, "Return code from getdns_dict_set_int()");
}
ASSERT_RC(getdns_dict_get_names(this_dict, &answer),
GETDNS_RETURN_GOOD, "Return code from getdns_dict_get_names()");
ASSERT_RC(getdns_list_get_length(answer, &length),
GETDNS_RETURN_GOOD, "Return code from getdns_list_get_length()");
ck_assert_msg(length == 3, "Expected length == 3, got %d", length);
for(i = 0; i < length; i++)
{
ASSERT_RC(getdns_list_get_bindata(answer, i, &key),
GETDNS_RETURN_GOOD, "Return code from getdns_list_get_bindata()");
strcat(string_buffer, (char *)key->data);
}
ck_assert_msg(strcmp(string_buffer, "elevententwelve") == 0,
"Expected concatenated names to be \"elevententwelve\", got \"%s\"", string_buffer);
DICT_DESTROY(this_dict);
}
END_TEST
Suite *
getdns_dict_get_names_suite (void)
{
Suite *s = suite_create ("getdns_dict_get_names()");
/* Negative test caseis */
TCase *tc_neg = tcase_create("Negative");
tcase_add_test(tc_neg, getdns_dict_get_names_1);
tcase_add_test(tc_neg, getdns_dict_get_names_2);
suite_add_tcase(s, tc_neg);
/* Positive test cases */
TCase *tc_pos = tcase_create("Positive");
tcase_add_test(tc_pos, getdns_dict_get_names_3);
suite_add_tcase(s, tc_pos);
return s;
}
#endif