diff options
author | Jan Hutter <jhutter@hsr.ch> | 2005-11-10 17:17:46 +0000 |
---|---|---|
committer | Jan Hutter <jhutter@hsr.ch> | 2005-11-10 17:17:46 +0000 |
commit | 110dc83a3c14ce4e86294257f5788429de068ef3 (patch) | |
tree | 13f18defc219c8567c35e01ed27acb1607128398 /Source/charon/tests/generator_test.c | |
parent | c64d7032fe53a63557d932a7d9817705f540f0d8 (diff) | |
download | strongswan-110dc83a3c14ce4e86294257f5788429de068ef3.tar.bz2 strongswan-110dc83a3c14ce4e86294257f5788429de068ef3.tar.xz |
generator now has its generator_context which is used to generate more
then one payload in sequence...
Diffstat (limited to 'Source/charon/tests/generator_test.c')
-rw-r--r-- | Source/charon/tests/generator_test.c | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/Source/charon/tests/generator_test.c b/Source/charon/tests/generator_test.c index 08da99458..9c1d00e4f 100644 --- a/Source/charon/tests/generator_test.c +++ b/Source/charon/tests/generator_test.c @@ -39,13 +39,19 @@ extern logger_t *global_logger; void test_generator_with_unsupported_payload(tester_t *tester) { generator_t *generator; + generator_context_t *generator_context; void * data_struct; chunk_t generated_data; generator = generator_create(payload_infos); tester->assert_true(tester,(generator != NULL), "generator create check"); - tester->assert_true(tester,(generator->generate_payload(generator,(payload_type_t) -1,data_struct,&generated_data) == NOT_SUPPORTED),"generate_payload call check"); + generator_context = generator->create_context(generator); + + tester->assert_true(tester,(generator->generate_payload(generator,(payload_type_t) -1,data_struct,generator_context) == NOT_SUPPORTED),"generate_payload call check"); + + generator_context->destroy(generator_context); + tester->assert_true(tester,(generator->destroy(generator) == SUCCESS), "generator destroy call check"); } @@ -55,6 +61,7 @@ void test_generator_with_unsupported_payload(tester_t *tester) void test_generator_with_header_payload(tester_t *tester) { generator_t *generator; + generator_context_t *generator_context; ike_header_t header_data; chunk_t generated_data; status_t status; @@ -73,10 +80,15 @@ void test_generator_with_header_payload(tester_t *tester) generator = generator_create(payload_infos); tester->assert_true(tester,(generator != NULL), "generator create check"); + + generator_context = generator->create_context(generator); + tester->assert_true(tester,(generator_context != NULL), "generator_context create check"); - status = generator->generate_payload(generator,HEADER,&header_data,&generated_data); + status = generator->generate_payload(generator,HEADER,&header_data,generator_context); tester->assert_true(tester,(status == SUCCESS),"generate_payload call check"); + tester->assert_true(tester,(generator->write_to_chunk(generator,generator_context,&generated_data) == SUCCESS),"write_to_chunk call check"); + u_int8_t expected_generation[] = { 0x00,0x00,0x00,0x00, 0x00,0x00,0x00,0x01, @@ -92,6 +104,8 @@ void test_generator_with_header_payload(tester_t *tester) tester->assert_true(tester,(memcmp(expected_generation,generated_data.ptr,sizeof(expected_generation)) == 0), "compare generated data 1"); allocator_free_chunk(generated_data); + generator_context->destroy(generator_context); + header_data.initiator_spi = 0x22000054231234; header_data.responder_spi = 0x122398; @@ -105,8 +119,12 @@ void test_generator_with_header_payload(tester_t *tester) header_data.message_id = 0x33AFF3; header_data.length = 0xAA11F; - status = generator->generate_payload(generator,HEADER,&header_data,&generated_data); + generator_context = generator->create_context(generator); + + status = generator->generate_payload(generator,HEADER,&header_data,generator_context); tester->assert_true(tester,(status == SUCCESS),"generate_payload call check"); + + tester->assert_true(tester,(generator->write_to_chunk(generator,generator_context,&generated_data) == SUCCESS),"write_to_chunk call check"); u_int8_t expected_generation2[] = { 0x00,0x22,0x00,0x00, @@ -123,5 +141,6 @@ void test_generator_with_header_payload(tester_t *tester) tester->assert_true(tester,(memcmp(expected_generation2,generated_data.ptr,sizeof(expected_generation2)) == 0), "compare generated data 2"); allocator_free_chunk(generated_data); + generator_context->destroy(generator_context); tester->assert_true(tester,(generator->destroy(generator) == SUCCESS), "generator destroy call check"); } |