1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
|
#include <check.h>
#include <stdio.h>
#include <stdlib.h>
#include "src/common/slurmdb_pack.h"
#include "src/common/xmalloc.h"
#include "src/common/slurm_protocol_common.h"
#include "src/common/list.h"
#include "src/common/pack.h"
START_TEST(invalid_protocol)
{
int rc;
uint32_t x;
slurmdb_clus_res_rec_t *clus_res_rec = xmalloc(sizeof(slurmdb_clus_res_rec_t));
buf_t *buf = init_buf(1024);
pack32(22, buf);
set_buf_offset(buf, 0);
slurmdb_clus_res_rec_t *acr;
slurmdb_pack_clus_res_rec((void **)&clus_res_rec, 0, buf);
unpack32(&x, buf);
rc = slurmdb_unpack_clus_res_rec((void **)&acr, 0, buf);
ck_assert_int_eq(rc, SLURM_ERROR);
ck_assert(x == 22);
free_buf(buf);
slurmdb_destroy_clus_res_rec(clus_res_rec);
}
END_TEST
START_TEST(pack_1702_null_clus_res_rec)
{
int rc;
buf_t *buf = init_buf(1024);
slurmdb_clus_res_rec_t pack_crr = {0};
slurmdb_pack_clus_res_rec(NULL, SLURM_MIN_PROTOCOL_VERSION, buf);
set_buf_offset(buf, 0);
slurmdb_clus_res_rec_t *unpack_crr;
rc = slurmdb_unpack_clus_res_rec((void **)&unpack_crr, SLURM_MIN_PROTOCOL_VERSION, buf);
ck_assert(rc == SLURM_SUCCESS);
ck_assert(pack_crr.cluster == unpack_crr->cluster);
/* when given a NULL pointer, the pack function sets allowed to
* NO_VAL, not 0. */
ck_assert(NO_VAL == unpack_crr->allowed);
free_buf(buf);
slurmdb_destroy_clus_res_rec(unpack_crr);
}
END_TEST
START_TEST(pack_1702_clus_res_rec)
{
int rc;
slurmdb_clus_res_rec_t *pack_crr = xmalloc(sizeof(slurmdb_clus_res_rec_t));
pack_crr->allowed = 12;
pack_crr->cluster = xstrdup("Diogenes");
buf_t *buf = init_buf(1024);
slurmdb_pack_clus_res_rec(pack_crr, SLURM_MIN_PROTOCOL_VERSION, buf);
set_buf_offset(buf, 0);
slurmdb_clus_res_rec_t *unpack_crr;
rc = slurmdb_unpack_clus_res_rec((void **)&unpack_crr, SLURM_MIN_PROTOCOL_VERSION, buf);
ck_assert(rc == SLURM_SUCCESS);
ck_assert(pack_crr->allowed == unpack_crr->allowed);
ck_assert_str_eq(pack_crr->cluster, unpack_crr->cluster);
free_buf(buf);
slurmdb_destroy_clus_res_rec(pack_crr);
slurmdb_destroy_clus_res_rec(unpack_crr);
}
END_TEST
/*****************************************************************************
* TEST SUITE *
****************************************************************************/
Suite *suite(void)
{
Suite *s = suite_create("Pack slurmdb_clus_res_rec_t");
TCase *tc_core = tcase_create("Pack slurmdb_clus_res_rec_t");
tcase_add_test(tc_core, invalid_protocol);
tcase_add_test(tc_core, pack_1702_clus_res_rec);
tcase_add_test(tc_core, pack_1702_null_clus_res_rec);
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;
}
|