unit-tests: Base attributes get adopted by seg-env/seg-contract
[strongswan.git] / src / libimcv / suites / test_imcv_seg.c
index 7920636..8b51eda 100644 (file)
@@ -19,6 +19,7 @@
 #include <pa_tnc/pa_tnc_attr.h>
 #include <seg/seg_env.h>
 #include <seg/seg_contract.h>
+#include <seg/seg_contract_manager.h>
 #include <ietf/ietf_attr_pa_tnc_error.h>
 #include <ita/ita_attr.h>
 #include <ita/ita_attr_command.h>
@@ -63,10 +64,11 @@ START_TEST(test_imcv_seg_env)
        libimcv_init(FALSE);
        max_seg_size  = seg_env_tests[_i].max_seg_size;
        last_seg_size = seg_env_tests[_i].last_seg_size;
+
        base_attr = ita_attr_command_create(command);
        base_attr->build(base_attr);
-
        seg_env = seg_env_create(id, base_attr, max_seg_size);
+
        if (seg_env_tests[_i].next_segs == 0)
        {
                ck_assert(seg_env == NULL);
@@ -155,7 +157,6 @@ START_TEST(test_imcv_seg_env)
                seg_env1->destroy(seg_env1);
                base_attr1->destroy(base_attr1);
        }
-       base_attr->destroy(base_attr);
        libimcv_deinit();
 }
 END_TEST
@@ -225,7 +226,6 @@ START_TEST(test_imcv_seg_env_special)
        /* cleanup */
        attr->destroy(attr);
        seg_env->destroy(seg_env);
-       base_attr->destroy(base_attr);
 }
 END_TEST
 
@@ -305,7 +305,8 @@ START_TEST(test_imcv_seg_contract)
                                                                         TRUE, issuer_id, FALSE);
        contract_r = seg_contract_create(msg_type, max_attr_size, max_seg_size,
                                                                         FALSE, issuer_id, TRUE);
-       attr = contract_r->first_segment(contract_r, base_attr_r);
+       attr = contract_r->first_segment(contract_r,
+                                                                        base_attr_r->get_ref(base_attr_r));
 
        if (seg_env_tests[_i].next_segs == 0)
        {
@@ -421,8 +422,8 @@ START_TEST(test_imcv_seg_contract_special)
        ck_assert(!oversize);
 
        /* get first segment of each base attribute */
-       attr1_f = contract_r->first_segment(contract_r, base_attr1_r);
-       attr2_f = contract_r->first_segment(contract_r, base_attr2_r);
+       attr1_f = contract_r->first_segment(contract_r, base_attr1_r->get_ref(base_attr1_r));
+       attr2_f = contract_r->first_segment(contract_r, base_attr2_r->get_ref(base_attr2_r));
        ck_assert(attr1_f);
        ck_assert(attr2_f);
        seg_env_attr1 = (tcg_seg_attr_seg_env_t*)attr1_f;
@@ -627,6 +628,75 @@ START_TEST(test_imcv_seg_contract_invalid)
 }
 END_TEST
 
+START_TEST(test_imcv_seg_contract_mgr)
+{
+       char buf[BUF_LEN];
+       uint32_t max_seg_size = 12, max_attr_size = 100;
+       pen_type_t msg_type1 = { PEN_ITA, PA_SUBTYPE_ITA_TEST };
+       pen_type_t msg_type2 = { PEN_IETF, PA_SUBTYPE_IETF_OPERATING_SYSTEM };
+       seg_contract_manager_t *contracts;
+       seg_contract_t *cx, *c1, *c2, *c3, *c4;
+
+       contracts = seg_contract_manager_create();
+
+       /* add contract template as issuer */
+       c1 = seg_contract_create(msg_type1, max_attr_size, max_seg_size, 
+                                                        TRUE, 1, FALSE);
+       c1->get_info_string(c1, buf, BUF_LEN, TRUE);
+
+       contracts->add_contract(contracts, c1);
+               
+       /* received contract request for msg_type1 as responder */
+       cx = contracts->get_contract(contracts, msg_type1, FALSE, 2);
+       ck_assert(cx == NULL);
+
+       /* add directed contract as responder */
+       c2 = seg_contract_create(msg_type1, max_attr_size, max_seg_size, 
+                                                        FALSE, 2, FALSE);
+       c2->set_responder(c2, 1);
+       c2->get_info_string(c2, buf, BUF_LEN, TRUE);
+       contracts->add_contract(contracts, c2);
+
+       /* retrieve this contract */
+       cx = contracts->get_contract(contracts, msg_type1, FALSE, 2);
+       ck_assert(cx == c2);
+
+       /* received directed contract response as issuer */
+       cx = contracts->get_contract(contracts, msg_type1, TRUE, 3);
+       ck_assert(cx == NULL);
+
+       /* get contract template */
+       cx = contracts->get_contract(contracts, msg_type1, TRUE, TNC_IMCID_ANY);
+       ck_assert(cx == c1);
+
+       /* clone the contract template and as it as a directed contract */
+       c3 = cx->clone(cx);
+       c3->set_responder(c3, 3);
+       c3->get_info_string(c3, buf, BUF_LEN, FALSE);
+       contracts->add_contract(contracts, c3);
+
+       /* retrieve this contract */
+       cx = contracts->get_contract(contracts, msg_type1, TRUE, 3);
+       ck_assert(cx == c3);
+
+       /* received contract request for msg_type2 as responder */
+       cx = contracts->get_contract(contracts, msg_type2, FALSE, 2);
+       ck_assert(cx == NULL);
+
+       /* add directed contract as responder */
+       c4 = seg_contract_create(msg_type2, max_attr_size, max_seg_size, 
+                                                        FALSE, 2, FALSE);
+       c4->set_responder(c4, 1);
+       contracts->add_contract(contracts, c4);
+
+       /* retrieve this contract */
+       cx = contracts->get_contract(contracts, msg_type2, FALSE, 2);
+       ck_assert(cx == c4);
+
+       contracts->destroy(contracts);
+}
+END_TEST
+
 Suite *imcv_seg_suite_create()
 {
        Suite *s;
@@ -660,5 +730,9 @@ Suite *imcv_seg_suite_create()
                                                countof(contract_invalid_tests));
        suite_add_tcase(s, tc);
 
+       tc = tcase_create("contract_mgr");
+       tcase_add_test(tc, test_imcv_seg_contract_mgr);
+       suite_add_tcase(s, tc);
+
        return s;
 }