| #include <check.h> |
| #include <stdio.h> |
| #include <stdlib.h> |
| |
| #include "src/common/slurmdb_pack.h" |
| #include "src/common/list.h" |
| #include "src/common/persist_conn.h" |
| #include "src/common/slurm_protocol_common.h" |
| #include "src/common/slurm_protocol_defs.h" |
| #include "src/common/xmalloc.h" |
| |
| |
| START_TEST(invalid_protocol) |
| { |
| int rc; |
| slurmdb_cluster_rec_t *rec = NULL; |
| |
| rc = slurmdb_unpack_cluster_rec((void **)&rec, 0, NULL); |
| ck_assert_int_eq(rc, SLURM_ERROR); |
| } |
| END_TEST |
| |
| START_TEST(pack_back2_null_rec) |
| { |
| int rc; |
| slurmdb_cluster_rec_t pack_rec; |
| slurmdb_cluster_rec_t *unpack_rec; |
| buf_t *buf = init_buf(1024); |
| |
| slurmdb_init_cluster_rec(&pack_rec, false); |
| pack_rec.fed.state = 0; |
| pack_rec.dimensions = 1; |
| |
| slurmdb_pack_cluster_rec(NULL, SLURM_MIN_PROTOCOL_VERSION, buf); |
| |
| set_buf_offset(buf, 0); |
| |
| rc = slurmdb_unpack_cluster_rec((void **)&unpack_rec, SLURM_MIN_PROTOCOL_VERSION, buf); |
| ck_assert_int_eq(rc, SLURM_SUCCESS); |
| ck_assert(pack_rec.accounting_list == unpack_rec->accounting_list); |
| ck_assert(pack_rec.control_host == unpack_rec->control_host); |
| ck_assert(pack_rec.fed.name == unpack_rec->fed.name); |
| ck_assert(pack_rec.name == unpack_rec->name); |
| ck_assert(pack_rec.nodes == unpack_rec->nodes); |
| ck_assert(pack_rec.fed.recv == unpack_rec->fed.recv); |
| ck_assert(pack_rec.fed.send == unpack_rec->fed.send); |
| /* 17.11 */ |
| ck_assert(pack_rec.fed.feature_list == unpack_rec->fed.feature_list); |
| |
| /* root_assoc gets unpacked into a empty structure */ |
| ck_assert(unpack_rec->root_assoc != NULL); |
| |
| ck_assert(pack_rec.classification == unpack_rec->classification); |
| ck_assert(pack_rec.dimensions == unpack_rec->dimensions); |
| ck_assert(pack_rec.fed.id == unpack_rec->fed.id); |
| ck_assert(pack_rec.fed.state == unpack_rec->fed.state); |
| ck_assert(pack_rec.flags == unpack_rec->flags); |
| ck_assert(pack_rec.rpc_version == unpack_rec->rpc_version); |
| |
| free_buf(buf); |
| slurmdb_destroy_cluster_rec(unpack_rec); |
| } |
| END_TEST |
| |
| START_TEST(pack_back2_rec) |
| { |
| int rc; |
| buf_t *buf = init_buf(1024); |
| slurmdb_cluster_rec_t *unpack_rec; |
| slurmdb_cluster_rec_t pack_rec = {0}; |
| |
| slurmdb_cluster_accounting_rec_t acct_rec = {0}; |
| pack_rec.accounting_list = list_create(NULL);; |
| list_append(pack_rec.accounting_list, &acct_rec); |
| |
| pack_rec.classification = 2; |
| pack_rec.control_host = xstrdup("control_host"); |
| pack_rec.dimensions = 3; |
| pack_rec.fed.name = xstrdup("fed_name"); |
| pack_rec.fed.id = 4; |
| pack_rec.fed.state = 5; |
| pack_rec.flags = 7; |
| pack_rec.name = xstrdup("name"); |
| pack_rec.nodes = xstrdup("nodes"); |
| pack_rec.fed.feature_list = list_create(xfree_ptr); |
| slurm_addto_mode_char_list(pack_rec.fed.feature_list, "a,b,c", 0); |
| ck_assert_int_eq(list_count(pack_rec.fed.feature_list), 3); |
| |
| /* will be tested separately. */ |
| pack_rec.root_assoc = NULL; |
| pack_rec.rpc_version = 9; |
| |
| persist_conn_t p_recv = {0}; |
| p_recv.tls_conn = (void *) 1; |
| pack_rec.fed.recv = &p_recv; |
| |
| persist_conn_t p_send = {0}; |
| p_send.tls_conn = (void *) 1; |
| pack_rec.fed.send = &p_send; |
| |
| |
| slurmdb_pack_cluster_rec(&pack_rec, SLURM_MIN_PROTOCOL_VERSION, buf); |
| |
| set_buf_offset(buf, 0); |
| |
| rc = slurmdb_unpack_cluster_rec((void **)&unpack_rec, SLURM_MIN_PROTOCOL_VERSION, buf); |
| ck_assert_int_eq(rc, SLURM_SUCCESS); |
| ck_assert(list_count(pack_rec.accounting_list) == list_count(unpack_rec->accounting_list)); |
| ck_assert(pack_rec.classification == unpack_rec->classification); |
| ck_assert(pack_rec.dimensions == unpack_rec->dimensions); |
| ck_assert(pack_rec.fed.id == unpack_rec->fed.id); |
| ck_assert(pack_rec.fed.state == unpack_rec->fed.state); |
| ck_assert(pack_rec.flags == unpack_rec->flags); |
| ck_assert(pack_rec.rpc_version == unpack_rec->rpc_version); |
| |
| ck_assert(unpack_rec->root_assoc != NULL); |
| |
| ck_assert(unpack_rec->fed.recv != NULL); |
| ck_assert(unpack_rec->fed.send != NULL); |
| |
| ck_assert_str_eq(pack_rec.control_host, unpack_rec->control_host); |
| ck_assert_str_eq(pack_rec.fed.name, unpack_rec->fed.name); |
| ck_assert_str_eq(pack_rec.name, unpack_rec->name); |
| ck_assert_str_eq(pack_rec.nodes, unpack_rec->nodes); |
| |
| char *feature; |
| ck_assert_int_eq(list_count(pack_rec.fed.feature_list), list_count(unpack_rec->fed.feature_list)); |
| list_itr_t *itr = list_iterator_create(pack_rec.fed.feature_list); |
| while ((feature = list_next(itr))) { |
| if (!list_find_first(unpack_rec->fed.feature_list, slurm_find_char_in_list, feature)) |
| ck_abort_msg("Didn't find feature %s in unpacked list", |
| feature); |
| } |
| |
| FREE_NULL_LIST(pack_rec.accounting_list); |
| xfree(pack_rec.control_host); |
| xfree(pack_rec.fed.name); |
| xfree(pack_rec.name); |
| xfree(pack_rec.nodes); |
| free_buf(buf); |
| slurmdb_destroy_cluster_rec(unpack_rec); |
| } |
| END_TEST |
| |
| START_TEST(pack_back2_rec_null_ptrs) |
| { |
| buf_t *buf = init_buf(1024); |
| slurmdb_cluster_rec_t pack_rec = {0}; |
| pack_rec.accounting_list = NULL; |
| pack_rec.classification = 2; |
| pack_rec.control_host = NULL; |
| pack_rec.dimensions = 3; |
| pack_rec.fed.name = NULL; |
| pack_rec.fed.id = 4; |
| pack_rec.fed.state = 5; |
| pack_rec.flags = 7; |
| pack_rec.name = NULL; |
| pack_rec.nodes = NULL; |
| pack_rec.root_assoc = NULL; |
| pack_rec.rpc_version = 9; |
| pack_rec.fed.recv = NULL; |
| pack_rec.fed.send = NULL; |
| |
| slurmdb_pack_cluster_rec(&pack_rec, SLURM_MIN_PROTOCOL_VERSION, buf); |
| |
| set_buf_offset(buf, 0); |
| |
| slurmdb_cluster_rec_t *unpack_rec; |
| int rc = slurmdb_unpack_cluster_rec((void **)&unpack_rec, SLURM_MIN_PROTOCOL_VERSION, buf); |
| |
| ck_assert_int_eq(rc, SLURM_SUCCESS); |
| ck_assert(pack_rec.accounting_list == unpack_rec->accounting_list); |
| ck_assert(pack_rec.classification == unpack_rec->classification); |
| ck_assert(pack_rec.control_host == unpack_rec->control_host); |
| ck_assert(pack_rec.dimensions == unpack_rec->dimensions); |
| ck_assert(pack_rec.fed.name == unpack_rec->fed.name); |
| ck_assert(pack_rec.fed.id == unpack_rec->fed.id); |
| ck_assert(pack_rec.fed.state == unpack_rec->fed.state); |
| ck_assert(pack_rec.flags == unpack_rec->flags); |
| ck_assert(pack_rec.name == unpack_rec->name); |
| ck_assert(pack_rec.nodes == unpack_rec->nodes); |
| |
| /* root_assoc gets unpacked into a empty structure */ |
| ck_assert(unpack_rec->root_assoc != NULL); |
| ck_assert(pack_rec.rpc_version == unpack_rec->rpc_version); |
| ck_assert(pack_rec.fed.recv == unpack_rec->fed.recv); |
| ck_assert(pack_rec.fed.send == unpack_rec->fed.send); |
| ck_assert(pack_rec.fed.feature_list == unpack_rec->fed.feature_list); |
| |
| free_buf(buf); |
| slurmdb_destroy_cluster_rec(unpack_rec); |
| } |
| END_TEST |
| |
| START_TEST(pack_back1_null_rec) |
| { |
| int rc; |
| slurmdb_cluster_rec_t *unpack_rec; |
| buf_t *buf = init_buf(1024); |
| |
| slurmdb_pack_cluster_rec(NULL, SLURM_ONE_BACK_PROTOCOL_VERSION, buf); |
| |
| set_buf_offset(buf, 0); |
| |
| rc = slurmdb_unpack_cluster_rec((void **)&unpack_rec, SLURM_ONE_BACK_PROTOCOL_VERSION, buf); |
| ck_assert_int_eq(rc, SLURM_SUCCESS); |
| /* |
| * cluster_rec should be what slurmdb_init_cluster_rec() sets as an |
| * unpack of a NULL is only an unpack of a bool and we skip the rest. |
| */ |
| ck_assert(!unpack_rec->accounting_list); |
| ck_assert(!unpack_rec->control_host); |
| ck_assert(!unpack_rec->fed.name); |
| ck_assert(!unpack_rec->name); |
| ck_assert(!unpack_rec->nodes); |
| ck_assert(!unpack_rec->fed.recv); |
| ck_assert(!unpack_rec->fed.send); |
| ck_assert(!unpack_rec->fed.feature_list); |
| |
| ck_assert(!unpack_rec->root_assoc); |
| |
| ck_assert(!unpack_rec->classification); |
| ck_assert(!unpack_rec->dimensions); |
| ck_assert(!unpack_rec->fed.id); |
| ck_assert(unpack_rec->fed.state == NO_VAL); |
| ck_assert(unpack_rec->flags == NO_VAL); |
| ck_assert(!unpack_rec->rpc_version); |
| |
| free_buf(buf); |
| slurmdb_destroy_cluster_rec(unpack_rec); |
| } |
| END_TEST |
| |
| START_TEST(pack_back1_rec) |
| { |
| int rc; |
| buf_t *buf = init_buf(1024); |
| slurmdb_cluster_rec_t *unpack_rec; |
| slurmdb_cluster_rec_t pack_rec = {0}; |
| |
| slurmdb_cluster_accounting_rec_t acct_rec = {0}; |
| pack_rec.accounting_list = list_create(NULL);; |
| list_append(pack_rec.accounting_list, &acct_rec); |
| |
| pack_rec.classification = 2; |
| pack_rec.control_host = xstrdup("control_host"); |
| pack_rec.dimensions = 3; |
| pack_rec.fed.name = xstrdup("fed_name"); |
| pack_rec.fed.id = 4; |
| pack_rec.fed.state = 5; |
| pack_rec.flags = 7; |
| pack_rec.name = xstrdup("name"); |
| pack_rec.nodes = xstrdup("nodes"); |
| pack_rec.fed.feature_list = list_create(xfree_ptr); |
| slurm_addto_mode_char_list(pack_rec.fed.feature_list, "a,b,c", 0); |
| ck_assert_int_eq(list_count(pack_rec.fed.feature_list), 3); |
| |
| /* will be tested separately. */ |
| pack_rec.root_assoc = NULL; |
| pack_rec.rpc_version = 9; |
| |
| persist_conn_t p_recv = {0}; |
| p_recv.tls_conn = (void *) 1; |
| pack_rec.fed.recv = &p_recv; |
| |
| persist_conn_t p_send = {0}; |
| p_send.tls_conn = (void *) 1; |
| pack_rec.fed.send = &p_send; |
| |
| |
| slurmdb_pack_cluster_rec(&pack_rec, SLURM_ONE_BACK_PROTOCOL_VERSION, buf); |
| |
| set_buf_offset(buf, 0); |
| |
| rc = slurmdb_unpack_cluster_rec((void **)&unpack_rec, SLURM_ONE_BACK_PROTOCOL_VERSION, buf); |
| ck_assert_int_eq(rc, SLURM_SUCCESS); |
| ck_assert(list_count(pack_rec.accounting_list) == list_count(unpack_rec->accounting_list)); |
| ck_assert(pack_rec.classification == unpack_rec->classification); |
| ck_assert(pack_rec.dimensions == unpack_rec->dimensions); |
| ck_assert(pack_rec.fed.id == unpack_rec->fed.id); |
| ck_assert(pack_rec.fed.state == unpack_rec->fed.state); |
| ck_assert(pack_rec.flags == unpack_rec->flags); |
| ck_assert(pack_rec.rpc_version == unpack_rec->rpc_version); |
| |
| ck_assert(unpack_rec->root_assoc != NULL); |
| |
| ck_assert(unpack_rec->fed.recv != NULL); |
| ck_assert(unpack_rec->fed.send != NULL); |
| |
| ck_assert_str_eq(pack_rec.control_host, unpack_rec->control_host); |
| ck_assert_str_eq(pack_rec.fed.name, unpack_rec->fed.name); |
| ck_assert_str_eq(pack_rec.name, unpack_rec->name); |
| ck_assert_str_eq(pack_rec.nodes, unpack_rec->nodes); |
| |
| char *feature; |
| ck_assert_int_eq(list_count(pack_rec.fed.feature_list), list_count(unpack_rec->fed.feature_list)); |
| list_itr_t *itr = list_iterator_create(pack_rec.fed.feature_list); |
| while ((feature = list_next(itr))) { |
| if (!list_find_first(unpack_rec->fed.feature_list, slurm_find_char_in_list, feature)) |
| ck_abort_msg("Didn't find feature %s in unpacked list", |
| feature); |
| } |
| |
| FREE_NULL_LIST(pack_rec.accounting_list); |
| xfree(pack_rec.control_host); |
| xfree(pack_rec.fed.name); |
| xfree(pack_rec.name); |
| xfree(pack_rec.nodes); |
| free_buf(buf); |
| slurmdb_destroy_cluster_rec(unpack_rec); |
| } |
| END_TEST |
| |
| START_TEST(pack_back1_rec_null_ptrs) |
| { |
| buf_t *buf = init_buf(1024); |
| slurmdb_cluster_rec_t pack_rec = {0}; |
| pack_rec.accounting_list = NULL; |
| pack_rec.classification = 2; |
| pack_rec.control_host = NULL; |
| pack_rec.dimensions = 3; |
| pack_rec.fed.name = NULL; |
| pack_rec.fed.id = 4; |
| pack_rec.fed.state = 5; |
| pack_rec.flags = 7; |
| pack_rec.name = NULL; |
| pack_rec.nodes = NULL; |
| pack_rec.root_assoc = NULL; |
| pack_rec.rpc_version = 9; |
| pack_rec.fed.recv = NULL; |
| pack_rec.fed.send = NULL; |
| |
| slurmdb_pack_cluster_rec(&pack_rec, SLURM_ONE_BACK_PROTOCOL_VERSION, buf); |
| |
| set_buf_offset(buf, 0); |
| |
| slurmdb_cluster_rec_t *unpack_rec; |
| int rc = slurmdb_unpack_cluster_rec((void **)&unpack_rec, SLURM_ONE_BACK_PROTOCOL_VERSION, buf); |
| |
| ck_assert_int_eq(rc, SLURM_SUCCESS); |
| ck_assert(pack_rec.accounting_list == unpack_rec->accounting_list); |
| ck_assert(pack_rec.classification == unpack_rec->classification); |
| ck_assert(pack_rec.control_host == unpack_rec->control_host); |
| ck_assert(pack_rec.dimensions == unpack_rec->dimensions); |
| ck_assert(pack_rec.fed.name == unpack_rec->fed.name); |
| ck_assert(pack_rec.fed.id == unpack_rec->fed.id); |
| ck_assert(pack_rec.fed.state == unpack_rec->fed.state); |
| ck_assert(pack_rec.flags == unpack_rec->flags); |
| ck_assert(pack_rec.name == unpack_rec->name); |
| ck_assert(pack_rec.nodes == unpack_rec->nodes); |
| |
| /* root_assoc gets unpacked into a empty structure */ |
| ck_assert(unpack_rec->root_assoc != NULL); |
| ck_assert(pack_rec.rpc_version == unpack_rec->rpc_version); |
| ck_assert(pack_rec.fed.recv == unpack_rec->fed.recv); |
| ck_assert(pack_rec.fed.send == unpack_rec->fed.send); |
| ck_assert(pack_rec.fed.feature_list == unpack_rec->fed.feature_list); |
| |
| free_buf(buf); |
| slurmdb_destroy_cluster_rec(unpack_rec); |
| } |
| END_TEST |
| |
| /***************************************************************************** |
| * TEST SUITE * |
| ****************************************************************************/ |
| |
| Suite *suite(void) |
| { |
| Suite *s = suite_create("Pack slurmdb_cluster_rec_t"); |
| TCase *tc_core = tcase_create("Pack slurmdb_cluster_rec_t"); |
| tcase_add_test(tc_core, invalid_protocol); |
| |
| tcase_add_test(tc_core, pack_back1_null_rec); |
| tcase_add_test(tc_core, pack_back1_rec); |
| tcase_add_test(tc_core, pack_back1_rec_null_ptrs); |
| |
| tcase_add_test(tc_core, pack_back2_null_rec); |
| tcase_add_test(tc_core, pack_back2_rec); |
| tcase_add_test(tc_core, pack_back2_rec_null_ptrs); |
| |
| suite_add_tcase(s, tc_core); |
| return s; |
| } |
| |
| /***************************************************************************** |
| * TEST RUNNER * |
| ****************************************************************************/ |
| |
| int main(void) |
| { |
| int number_failed; |
| SRunner *sr = srunner_create(suite()); |
| |
| //srunner_set_fork_status(sr, CK_NOFORK); |
| |
| srunner_run_all(sr, CK_VERBOSE); |
| srunner_run_all(sr, CK_NORMAL); |
| number_failed = srunner_ntests_failed(sr); |
| srunner_free(sr); |
| |
| return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE; |
| } |