aboutsummaryrefslogtreecommitdiffstats
path: root/Source/charon/tests/generator_test.c
diff options
context:
space:
mode:
authorJan Hutter <jhutter@hsr.ch>2005-11-10 17:17:46 +0000
committerJan Hutter <jhutter@hsr.ch>2005-11-10 17:17:46 +0000
commit110dc83a3c14ce4e86294257f5788429de068ef3 (patch)
tree13f18defc219c8567c35e01ed27acb1607128398 /Source/charon/tests/generator_test.c
parentc64d7032fe53a63557d932a7d9817705f540f0d8 (diff)
downloadstrongswan-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.c25
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");
}