59
72
/* Default implementation of a serf_connection_setup_t callback. */
60
static apr_status_t default_conn_setup(apr_socket_t *skt,
61
serf_bucket_t **input_bkt,
62
serf_bucket_t **output_bkt,
66
test_baton_t *ctx = setup_baton;
68
*input_bkt = serf_bucket_socket_create(skt, ctx->bkt_alloc);
73
static apr_status_t default_http_conn_setup(apr_socket_t *skt,
74
serf_bucket_t **input_bkt,
75
serf_bucket_t **output_bkt,
79
test_baton_t *tb = setup_baton;
81
*input_bkt = serf_bucket_socket_create(skt, tb->bkt_alloc);
85
/* This function makes serf use SSL on the connection. */
86
apr_status_t default_https_conn_setup(apr_socket_t *skt,
87
serf_bucket_t **input_bkt,
88
serf_bucket_t **output_bkt,
92
test_baton_t *tb = setup_baton;
94
*input_bkt = serf_bucket_socket_create(skt, tb->bkt_alloc);
95
*input_bkt = serf_bucket_ssl_decrypt_create(*input_bkt, NULL,
97
tb->ssl_context = serf_bucket_ssl_encrypt_context_get(*input_bkt);
100
*output_bkt = serf_bucket_ssl_encrypt_create(*output_bkt,
105
if (tb->server_cert_cb)
106
serf_ssl_server_cert_callback_set(tb->ssl_context,
110
serf_ssl_set_hostname(tb->ssl_context, "localhost");
115
apr_status_t use_new_connection(test_baton_t *tb,
122
cleanup_conn(tb->connection);
123
tb->connection = NULL;
125
status = apr_uri_parse(pool, tb->serv_url, &url);
126
if (status != APR_SUCCESS)
129
status = serf_connection_create2(&tb->connection, tb->context,
133
default_closed_connection,
136
apr_pool_cleanup_register(pool, tb->connection, cleanup_conn,
137
apr_pool_cleanup_null);
142
/* Setup the client context, ready to connect and send requests to a
73
144
static apr_status_t setup(test_baton_t **tb_p,
74
145
serf_connection_setup_t conn_setup,
146
const char *serv_url,
148
apr_size_t message_count,
78
152
apr_status_t status;
82
154
tb = apr_pcalloc(pool, sizeof(*tb));
99
178
serf_config_proxy(tb->context, tb->proxy_addr);
102
status = apr_uri_parse(pool, SERV_URL, &url);
103
if (status != APR_SUCCESS)
106
status = serf_connection_create2(&tb->connection, tb->context,
108
conn_setup ? conn_setup :
111
default_closed_connection,
120
apr_status_t test_server_setup(test_baton_t **tb_p,
121
test_server_message_t *message_list,
122
apr_size_t message_count,
123
test_server_action_t *action_list,
124
apr_size_t action_count,
126
serf_connection_setup_t conn_setup,
136
if (status != APR_SUCCESS)
141
/* Prepare a server. */
142
status = test_start_server(&tb->serv_ctx, tb->serv_addr,
143
message_list, message_count,
144
action_list, action_count, options, pool);
181
status = use_new_connection(tb, pool);
186
/* Setup an https server and the client context to connect to that server */
187
apr_status_t test_https_server_setup(test_baton_t **tb_p,
188
test_server_message_t *message_list,
189
apr_size_t message_count,
190
test_server_action_t *action_list,
191
apr_size_t action_count,
193
serf_connection_setup_t conn_setup,
195
const char **certfiles,
196
const char *client_cn,
197
serf_ssl_need_server_cert_t server_cert_cb,
204
conn_setup ? conn_setup : default_https_conn_setup,
209
if (status != APR_SUCCESS)
213
tb->server_cert_cb = server_cert_cb;
215
/* Prepare a server. */
216
setup_https_test_server(&tb->serv_ctx, tb->serv_addr,
217
message_list, message_count,
218
action_list, action_count, options,
219
keyfile, certfiles, client_cn,
221
status = start_test_server(tb->serv_ctx);
226
/* Setup an http server and the client context to connect to that server */
227
apr_status_t test_http_server_setup(test_baton_t **tb_p,
228
test_server_message_t *message_list,
229
apr_size_t message_count,
230
test_server_action_t *action_list,
231
apr_size_t action_count,
233
serf_connection_setup_t conn_setup,
240
conn_setup ? conn_setup : default_http_conn_setup,
245
if (status != APR_SUCCESS)
250
/* Prepare a server. */
251
setup_test_server(&tb->serv_ctx, tb->serv_addr,
252
message_list, message_count,
253
action_list, action_count, options,
255
status = start_test_server(tb->serv_ctx);
260
/* Setup a proxy server and an http server and the client context to connect to
150
263
test_server_proxy_setup(test_baton_t **tb_p,
151
264
test_server_message_t *serv_message_list,
175
290
/* Prepare the server. */
176
status = test_start_server(&tb->serv_ctx, tb->serv_addr,
177
serv_message_list, serv_message_count,
178
serv_action_list, serv_action_count,
291
setup_test_server(&tb->serv_ctx, tb->serv_addr,
292
serv_message_list, serv_message_count,
293
serv_action_list, serv_action_count,
296
status = start_test_server(tb->serv_ctx);
180
297
if (status != APR_SUCCESS)
183
300
/* Prepare the proxy. */
184
status = test_start_server(&tb->proxy_ctx, tb->proxy_addr,
185
proxy_message_list, proxy_message_count,
186
proxy_action_list, proxy_action_count,
301
setup_test_server(&tb->proxy_ctx, tb->proxy_addr,
302
proxy_message_list, proxy_message_count,
303
proxy_action_list, proxy_action_count,
306
status = start_test_server(tb->proxy_ctx);
192
apr_status_t test_server_teardown(test_baton_t *tb, apr_pool_t *pool)
311
/* Setup a proxy server and a https server and the client context to connect to
314
test_https_server_proxy_setup(test_baton_t **tb_p,
315
test_server_message_t *serv_message_list,
316
apr_size_t serv_message_count,
317
test_server_action_t *serv_action_list,
318
apr_size_t serv_action_count,
319
test_server_message_t *proxy_message_list,
320
apr_size_t proxy_message_count,
321
test_server_action_t *proxy_action_list,
322
apr_size_t proxy_action_count,
324
serf_connection_setup_t conn_setup,
326
const char **certfiles,
327
const char *client_cn,
328
serf_ssl_need_server_cert_t server_cert_cb,
194
serf_connection_close(tb->connection);
197
test_server_destroy(tb->serv_ctx, pool);
199
test_server_destroy(tb->proxy_ctx, pool);
335
conn_setup ? conn_setup : default_https_conn_setup,
337
TRUE, /* use proxy */
340
if (status != APR_SUCCESS)
344
tb->server_cert_cb = server_cert_cb;
346
/* Prepare a https server. */
347
setup_https_test_server(&tb->serv_ctx, tb->serv_addr,
348
serv_message_list, serv_message_count,
349
serv_action_list, serv_action_count,
351
keyfile, certfiles, client_cn,
353
status = start_test_server(tb->serv_ctx);
355
/* Prepare the proxy. */
356
setup_test_server(&tb->proxy_ctx, tb->proxy_addr,
357
proxy_message_list, proxy_message_count,
358
proxy_action_list, proxy_action_count,
361
status = start_test_server(tb->proxy_ctx);
204
apr_pool_t *test_setup(void)
366
void *test_setup(void *dummy)
206
368
apr_pool_t *test_pool;
207
369
apr_pool_create(&test_pool, NULL);
208
370
return test_pool;
211
void test_teardown(apr_pool_t *test_pool)
213
apr_pool_destroy(test_pool);
373
void *test_teardown(void *baton)
375
apr_pool_t *pool = baton;
376
apr_pool_destroy(pool);
381
/* Helper function, runs the client and server context loops and validates
382
that no errors were encountered, and all messages were sent and received. */
384
test_helper_run_requests_no_check(CuTest *tc, test_baton_t *tb,
386
handler_baton_t handler_ctx[],
389
apr_pool_t *iter_pool;
393
apr_pool_create(&iter_pool, pool);
397
apr_pool_clear(iter_pool);
399
/* run server event loop */
400
status = run_test_server(tb->serv_ctx, 0, iter_pool);
401
if (!APR_STATUS_IS_TIMEUP(status) &&
402
SERF_BUCKET_READ_ERROR(status))
405
/* run proxy event loop */
407
status = run_test_server(tb->proxy_ctx, 0, iter_pool);
408
if (!APR_STATUS_IS_TIMEUP(status) &&
409
SERF_BUCKET_READ_ERROR(status))
413
/* run client event loop */
414
status = serf_context_run(tb->context, 0, iter_pool);
415
if (!APR_STATUS_IS_TIMEUP(status) &&
416
SERF_BUCKET_READ_ERROR(status))
420
for (i = 0; i < num_requests; i++)
421
done &= handler_ctx[i].done;
423
apr_pool_destroy(iter_pool);
429
test_helper_run_requests_expect_ok(CuTest *tc, test_baton_t *tb,
431
handler_baton_t handler_ctx[],
436
status = test_helper_run_requests_no_check(tc, tb, num_requests,
438
CuAssertIntEquals(tc, APR_SUCCESS, status);
440
/* Check that all requests were received */
441
CuAssertIntEquals(tc, num_requests, tb->sent_requests->nelts);
442
CuAssertIntEquals(tc, num_requests, tb->accepted_requests->nelts);
443
CuAssertIntEquals(tc, num_requests, tb->handled_requests->nelts);
446
serf_bucket_t* accept_response(serf_request_t *request,
447
serf_bucket_t *stream,
448
void *acceptor_baton,
452
serf_bucket_alloc_t *bkt_alloc;
453
handler_baton_t *ctx = acceptor_baton;
454
serf_bucket_t *response;
456
/* get the per-request bucket allocator */
457
bkt_alloc = serf_request_get_alloc(request);
459
/* Create a barrier so the response doesn't eat us! */
460
c = serf_bucket_barrier_create(stream, bkt_alloc);
462
APR_ARRAY_PUSH(ctx->accepted_requests, int) = ctx->req_id;
464
response = serf_bucket_response_create(c, bkt_alloc);
466
if (strcasecmp(ctx->method, "HEAD") == 0)
467
serf_bucket_response_set_head(response);
472
apr_status_t setup_request(serf_request_t *request,
474
serf_bucket_t **req_bkt,
475
serf_response_acceptor_t *acceptor,
476
void **acceptor_baton,
477
serf_response_handler_t *handler,
478
void **handler_baton,
481
handler_baton_t *ctx = setup_baton;
482
serf_bucket_t *body_bkt;
486
/* Create a raw request bucket. */
487
*req_bkt = serf_bucket_simple_create(ctx->request, strlen(ctx->request),
489
serf_request_get_alloc(request));
493
if (ctx->req_id >= 0) {
494
/* create a simple body text */
495
const char *str = apr_psprintf(pool, "%d", ctx->req_id);
497
body_bkt = serf_bucket_simple_create(
498
str, strlen(str), NULL, NULL,
499
serf_request_get_alloc(request));
505
serf_request_bucket_request_create(request,
506
ctx->method, ctx->path,
508
serf_request_get_alloc(request));
511
APR_ARRAY_PUSH(ctx->sent_requests, int) = ctx->req_id;
513
*acceptor = ctx->acceptor;
514
*acceptor_baton = ctx;
515
*handler = ctx->handler;
516
*handler_baton = ctx;
521
apr_status_t handle_response(serf_request_t *request,
522
serf_bucket_t *response,
526
handler_baton_t *ctx = handler_baton;
529
serf_connection_request_create(ctx->tb->connection,
540
status = serf_bucket_read(response, 2048, &data, &len);
541
if (SERF_BUCKET_READ_ERROR(status))
544
if (APR_STATUS_IS_EOF(status)) {
545
APR_ARRAY_PUSH(ctx->handled_requests, int) = ctx->req_id;
550
if (APR_STATUS_IS_EAGAIN(status)) {
559
void setup_handler(test_baton_t *tb, handler_baton_t *handler_ctx,
560
const char *method, const char *path,
562
serf_response_handler_t handler)
564
handler_ctx->method = method;
565
handler_ctx->path = path;
566
handler_ctx->done = FALSE;
568
handler_ctx->acceptor = accept_response;
569
handler_ctx->acceptor_baton = NULL;
570
handler_ctx->handler = handler ? handler : handle_response;
571
handler_ctx->req_id = req_id;
572
handler_ctx->accepted_requests = tb->accepted_requests;
573
handler_ctx->sent_requests = tb->sent_requests;
574
handler_ctx->handled_requests = tb->handled_requests;
575
handler_ctx->tb = tb;
576
handler_ctx->request = NULL;
579
void create_new_prio_request(test_baton_t *tb,
580
handler_baton_t *handler_ctx,
581
const char *method, const char *path,
584
setup_handler(tb, handler_ctx, method, path, req_id, NULL);
585
serf_connection_priority_request_create(tb->connection,
590
void create_new_request(test_baton_t *tb,
591
handler_baton_t *handler_ctx,
592
const char *method, const char *path,
595
setup_handler(tb, handler_ctx, method, path, req_id, NULL);
596
serf_connection_request_create(tb->connection,
602
create_new_request_with_resp_hdlr(test_baton_t *tb,
603
handler_baton_t *handler_ctx,
604
const char *method, const char *path,
606
serf_response_handler_t handler)
608
setup_handler(tb, handler_ctx, method, path, req_id, handler);
609
serf_connection_request_create(tb->connection,