|
Packit |
3adb1e |
/* ====================================================================
|
|
Packit |
3adb1e |
* Licensed to the Apache Software Foundation (ASF) under one
|
|
Packit |
3adb1e |
* or more contributor license agreements. See the NOTICE file
|
|
Packit |
3adb1e |
* distributed with this work for additional information
|
|
Packit |
3adb1e |
* regarding copyright ownership. The ASF licenses this file
|
|
Packit |
3adb1e |
* to you under the Apache License, Version 2.0 (the
|
|
Packit |
3adb1e |
* "License"); you may not use this file except in compliance
|
|
Packit |
3adb1e |
* with the License. You may obtain a copy of the License at
|
|
Packit |
3adb1e |
*
|
|
Packit |
3adb1e |
* http://www.apache.org/licenses/LICENSE-2.0
|
|
Packit |
3adb1e |
*
|
|
Packit |
3adb1e |
* Unless required by applicable law or agreed to in writing,
|
|
Packit |
3adb1e |
* software distributed under the License is distributed on an
|
|
Packit |
3adb1e |
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
Packit |
3adb1e |
* KIND, either express or implied. See the License for the
|
|
Packit |
3adb1e |
* specific language governing permissions and limitations
|
|
Packit |
3adb1e |
* under the License.
|
|
Packit |
3adb1e |
* ====================================================================
|
|
Packit |
3adb1e |
*/
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#include <apr.h>
|
|
Packit |
3adb1e |
#include <apr_pools.h>
|
|
Packit |
3adb1e |
#include <apr_strings.h>
|
|
Packit |
3adb1e |
#include <apr_random.h>
|
|
Packit |
3adb1e |
#include <zlib.h>
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#include "serf.h"
|
|
Packit |
3adb1e |
#include "test_serf.h"
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* test case has access to internal functions. */
|
|
Packit |
3adb1e |
#include "serf_private.h"
|
|
Packit |
3adb1e |
#include "serf_bucket_util.h"
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static apr_status_t read_all(serf_bucket_t *bkt,
|
|
Packit |
3adb1e |
char *buf,
|
|
Packit |
3adb1e |
apr_size_t buf_len,
|
|
Packit |
3adb1e |
apr_size_t *read_len)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t data_len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
apr_size_t read;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
read = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &data_len);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (!SERF_BUCKET_READ_ERROR(status))
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
if (data_len > buf_len - read)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
/* Buffer is not large enough to read all data */
|
|
Packit |
3adb1e |
data_len = buf_len - read;
|
|
Packit |
3adb1e |
status = SERF_ERROR_ISSUE_IN_TESTSUITE;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
memcpy(buf + read, data, data_len);
|
|
Packit |
3adb1e |
read += data_len;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
} while(status == APR_SUCCESS);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
*read_len = read;
|
|
Packit |
3adb1e |
return status;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Reads bucket until EOF found and compares read data with zero terminated
|
|
Packit |
3adb1e |
string expected. Report all failures using CuTest. */
|
|
Packit |
3adb1e |
void read_and_check_bucket(CuTest *tc, serf_bucket_t *bkt,
|
|
Packit |
3adb1e |
const char *expected)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during bucket reading.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
CuAssert(tc, "Read more data than expected.",
|
|
Packit |
3adb1e |
strlen(expected) >= len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(expected, data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
expected += len;
|
|
Packit |
3adb1e |
} while(!APR_STATUS_IS_EOF(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Read less data than expected.", strlen(expected) == 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Reads bucket with serf_bucket_readline until EOF found and compares:
|
|
Packit |
3adb1e |
- actual line endings with expected line endings
|
|
Packit |
3adb1e |
- actual data with zero terminated string expected.
|
|
Packit |
3adb1e |
Reports all failures using CuTest. */
|
|
Packit |
3adb1e |
void readlines_and_check_bucket(CuTest *tc, serf_bucket_t *bkt,
|
|
Packit |
3adb1e |
int acceptable,
|
|
Packit |
3adb1e |
const char *expected,
|
|
Packit |
3adb1e |
int expected_nr_of_lines)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
int actual_nr_of_lines = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
int found;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_readline(bkt, acceptable, &found,
|
|
Packit |
3adb1e |
&data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during bucket reading.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
CuAssert(tc, "Read more data than expected.",
|
|
Packit |
3adb1e |
strlen(expected) >= len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(expected, data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
expected += len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (found == SERF_NEWLINE_CRLF_SPLIT)
|
|
Packit |
3adb1e |
continue;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (found != SERF_NEWLINE_NONE)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
actual_nr_of_lines++;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Unexpected line ending type!",
|
|
Packit |
3adb1e |
found & acceptable);
|
|
Packit |
3adb1e |
if (found & SERF_NEWLINE_CR)
|
|
Packit |
3adb1e |
CuAssert(tc, "CR Line ending was reported but not in data!",
|
|
Packit |
3adb1e |
strncmp(data + len - 1, "\r", 1) == 0);
|
|
Packit |
3adb1e |
if (found & SERF_NEWLINE_LF)
|
|
Packit |
3adb1e |
CuAssert(tc, "LF Line ending was reported but not in data!",
|
|
Packit |
3adb1e |
strncmp(data + len - 1, "\n", 1) == 0);
|
|
Packit |
3adb1e |
if (found & SERF_NEWLINE_CRLF)
|
|
Packit |
3adb1e |
CuAssert(tc, "CRLF Line ending was reported but not in data!",
|
|
Packit |
3adb1e |
strncmp(data + len - 2, "\r\n", 2) == 0);
|
|
Packit |
3adb1e |
} else
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
if (status == APR_EOF && len)
|
|
Packit |
3adb1e |
actual_nr_of_lines++;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (acceptable & SERF_NEWLINE_CR)
|
|
Packit |
3adb1e |
CuAssert(tc, "CR Line ending was not reported but in data!",
|
|
Packit |
3adb1e |
strncmp(data + len - 1, "\r", 1) != 0);
|
|
Packit |
3adb1e |
if (acceptable & SERF_NEWLINE_LF)
|
|
Packit |
3adb1e |
CuAssert(tc, "LF Line ending was not reported but in data!",
|
|
Packit |
3adb1e |
strncmp(data + len - 1, "\n", 1) != 0);
|
|
Packit |
3adb1e |
if (acceptable & SERF_NEWLINE_CRLF)
|
|
Packit |
3adb1e |
CuAssert(tc, "CRLF Line ending was not reported but in data!",
|
|
Packit |
3adb1e |
strncmp(data + len - 2, "\r\n", 2) != 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
} while(!APR_STATUS_IS_EOF(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, expected_nr_of_lines, actual_nr_of_lines);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read less data than expected.", strlen(expected) == 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/******************************** TEST CASES **********************************/
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_simple_bucket_readline(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
serf_bucket_t *bkt;
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
int found;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
const char *body;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING(
|
|
Packit |
3adb1e |
"line1" CRLF
|
|
Packit |
3adb1e |
"line2",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Initialize parameters to check that they will be initialized. */
|
|
Packit |
3adb1e |
len = 0x112233;
|
|
Packit |
3adb1e |
data = 0;
|
|
Packit |
3adb1e |
status = serf_bucket_readline(bkt, SERF_NEWLINE_CRLF, &found, &data, &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_NEWLINE_CRLF, found);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 7, len);
|
|
Packit |
3adb1e |
CuAssert(tc, data, strncmp("line1" CRLF, data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Initialize parameters to check that they will be initialized. */
|
|
Packit |
3adb1e |
len = 0x112233;
|
|
Packit |
3adb1e |
data = 0;
|
|
Packit |
3adb1e |
status = serf_bucket_readline(bkt, SERF_NEWLINE_CRLF, &found, &data, &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_NEWLINE_NONE, found);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 5, len);
|
|
Packit |
3adb1e |
CuAssert(tc, data, strncmp("line2", data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* acceptable line types should be reported */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" CRLF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_CRLF, "line1" CRLF, 1);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" LF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_LF, "line1" LF, 1);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" LF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_LF, "line1" LF, 1);
|
|
Packit |
3adb1e |
/* special cases, but acceptable */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" CRLF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_CR, "line1" CRLF, 2);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" CRLF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_LF, "line1" CRLF, 1);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Unacceptable line types should not be reported */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" LF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_CR, "line1" LF, 1);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" LF, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_CRLF, "line1" LF, 1);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" CR, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_LF, "line1" CR, 1);
|
|
Packit |
3adb1e |
#if 0
|
|
Packit |
3adb1e |
/* TODO: looks like a bug, CRLF acceptable on buffer with CR returns
|
|
Packit |
3adb1e |
SERF_NEWLINE_CRLF_SPLIT, but here that CR comes at the end of the
|
|
Packit |
3adb1e |
buffer (APR_EOF), so should have been SERF_NEWLINE_NONE! */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" CR, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_CRLF, "line1" CR, 1);
|
|
Packit |
3adb1e |
#endif
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
body = "12345678901234567890" CRLF
|
|
Packit |
3adb1e |
"12345678901234567890" CRLF
|
|
Packit |
3adb1e |
"12345678901234567890" CRLF;
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING(body, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, bkt, SERF_NEWLINE_LF, body, 3);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_response_bucket_read(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING(
|
|
Packit |
3adb1e |
"HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 7" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"abc1234",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read all bucket and check it content. */
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, bkt, "abc1234");
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_response_bucket_headers(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp, *hdr;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING(
|
|
Packit |
3adb1e |
"HTTP/1.1 405 Method Not Allowed" CRLF
|
|
Packit |
3adb1e |
"Date: Sat, 12 Jun 2010 14:17:10 GMT" CRLF
|
|
Packit |
3adb1e |
"Server: Apache" CRLF
|
|
Packit |
3adb1e |
"Allow: " CRLF
|
|
Packit |
3adb1e |
"Content-Length: 7" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/html; charset=iso-8859-1" CRLF
|
|
Packit |
3adb1e |
"NoSpace:" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"abc1234",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read all bucket and check it content. */
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, bkt, "abc1234");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
hdr = serf_bucket_response_get_headers(bkt);
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc,
|
|
Packit |
3adb1e |
"",
|
|
Packit |
3adb1e |
serf_bucket_headers_get(hdr, "Allow"));
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc,
|
|
Packit |
3adb1e |
"7",
|
|
Packit |
3adb1e |
serf_bucket_headers_get(hdr, "Content-Length"));
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc,
|
|
Packit |
3adb1e |
"",
|
|
Packit |
3adb1e |
serf_bucket_headers_get(hdr, "NoSpace"));
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_response_bucket_chunked_read(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp, *hdrs;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING(
|
|
Packit |
3adb1e |
"HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"3" CRLF
|
|
Packit |
3adb1e |
"abc" CRLF
|
|
Packit |
3adb1e |
"4" CRLF
|
|
Packit |
3adb1e |
"1234" CRLF
|
|
Packit |
3adb1e |
"0" CRLF
|
|
Packit |
3adb1e |
"Footer: value" CRLF
|
|
Packit |
3adb1e |
CRLF,
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read all bucket and check it content. */
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, bkt, "abc1234");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
hdrs = serf_bucket_response_get_headers(bkt);
|
|
Packit |
3adb1e |
CuAssertTrue(tc, hdrs != NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Check that trailing headers parsed correctly. */
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "value", serf_bucket_headers_get(hdrs, "Footer"));
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_bucket_header_set(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
serf_bucket_t *hdrs = serf_bucket_headers_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertTrue(tc, hdrs != NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_headers_set(hdrs, "Foo", "bar");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "bar", serf_bucket_headers_get(hdrs, "Foo"));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_headers_set(hdrs, "Foo", "baz");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "bar,baz", serf_bucket_headers_get(hdrs, "Foo"));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_headers_set(hdrs, "Foo", "test");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "bar,baz,test", serf_bucket_headers_get(hdrs, "Foo"));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* headers are case insensitive. */
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "bar,baz,test", serf_bucket_headers_get(hdrs, "fOo"));
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_iovec_buckets(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *iobkt;
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
struct iovec vecs[32];
|
|
Packit |
3adb1e |
struct iovec tgt_vecs[32];
|
|
Packit |
3adb1e |
int i;
|
|
Packit |
3adb1e |
int vecs_used;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 1: Read a single string in an iovec, store it in a iovec_bucket
|
|
Packit |
3adb1e |
and then read it back. */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING(
|
|
Packit |
3adb1e |
"line1" CRLF
|
|
Packit |
3adb1e |
"line2",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(bkt, SERF_READ_ALL_AVAIL, 32, vecs,
|
|
Packit |
3adb1e |
&vecs_used);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
iobkt = serf_bucket_iovec_create(vecs, vecs_used, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Check available data */
|
|
Packit |
3adb1e |
status = serf_bucket_peek(iobkt, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, strlen("line1" CRLF "line2"), len);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Try to read only a few bytes (less than what's in the first buffer). */
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, 3, 32, tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 1, vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 3, tgt_vecs[0].iov_len);
|
|
Packit |
3adb1e |
CuAssert(tc, tgt_vecs[0].iov_base,
|
|
Packit |
3adb1e |
strncmp("lin", tgt_vecs[0].iov_base, tgt_vecs[0].iov_len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read the rest of the data. */
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, SERF_READ_ALL_AVAIL, 32, tgt_vecs,
|
|
Packit |
3adb1e |
&vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 1, vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, strlen("e1" CRLF "line2"), tgt_vecs[0].iov_len);
|
|
Packit |
3adb1e |
CuAssert(tc, tgt_vecs[0].iov_base,
|
|
Packit |
3adb1e |
strncmp("e1" CRLF "line2", tgt_vecs[0].iov_base, tgt_vecs[0].iov_len - 3) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Bucket should now be empty */
|
|
Packit |
3adb1e |
status = serf_bucket_peek(iobkt, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, len);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 2: Read multiple character bufs in an iovec, then read them back
|
|
Packit |
3adb1e |
in bursts. */
|
|
Packit |
3adb1e |
for (i = 0; i < 32 ; i++) {
|
|
Packit |
3adb1e |
vecs[i].iov_base = apr_psprintf(test_pool, "data %02d 901234567890", i);
|
|
Packit |
3adb1e |
vecs[i].iov_len = strlen(vecs[i].iov_base);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
iobkt = serf_bucket_iovec_create(vecs, 32, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Check that some data is in the buffer. Don't verify the actual data, the
|
|
Packit |
3adb1e |
amount of data returned is not guaranteed to be the full buffer. */
|
|
Packit |
3adb1e |
status = serf_bucket_peek(iobkt, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertTrue(tc, len > 0);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status); /* this assumes not all data is
|
|
Packit |
3adb1e |
returned at once,
|
|
Packit |
3adb1e |
not guaranteed! */
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read 1 buf. 20 = sizeof("data %2d 901234567890") */
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, 1 * 20, 32,
|
|
Packit |
3adb1e |
tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 1, vecs_used);
|
|
Packit |
3adb1e |
CuAssert(tc, tgt_vecs[0].iov_base,
|
|
Packit |
3adb1e |
strncmp("data 00 901234567890", tgt_vecs[0].iov_base, tgt_vecs[0].iov_len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read 2 bufs. */
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, 2 * 20, 32,
|
|
Packit |
3adb1e |
tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 2, vecs_used);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Read the remaining 29 bufs. */
|
|
Packit |
3adb1e |
vecs_used = 400; /* test if iovec code correctly resets vecs_used */
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, SERF_READ_ALL_AVAIL, 32,
|
|
Packit |
3adb1e |
tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 29, vecs_used);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 3: use serf_bucket_read */
|
|
Packit |
3adb1e |
for (i = 0; i < 32 ; i++) {
|
|
Packit |
3adb1e |
vecs[i].iov_base = apr_psprintf(test_pool, "DATA %02d 901234567890", i);
|
|
Packit |
3adb1e |
vecs[i].iov_len = strlen(vecs[i].iov_base);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
iobkt = serf_bucket_iovec_create(vecs, 32, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(iobkt, 10, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 10, len);
|
|
Packit |
3adb1e |
CuAssert(tc, data,
|
|
Packit |
3adb1e |
strncmp("DATA 00 90", data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(iobkt, 10, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 10, len);
|
|
Packit |
3adb1e |
CuAssert(tc, tgt_vecs[0].iov_base,
|
|
Packit |
3adb1e |
strncmp("1234567890", data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
for (i = 1; i < 31 ; i++) {
|
|
Packit |
3adb1e |
const char *exp = apr_psprintf(test_pool, "DATA %02d 901234567890", i);
|
|
Packit |
3adb1e |
status = serf_bucket_read(iobkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 20, len);
|
|
Packit |
3adb1e |
CuAssert(tc, data,
|
|
Packit |
3adb1e |
strncmp(exp, data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(iobkt, 20, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 20, len);
|
|
Packit |
3adb1e |
CuAssert(tc, data,
|
|
Packit |
3adb1e |
strncmp("DATA 31 901234567890", data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 3: read an empty iovec */
|
|
Packit |
3adb1e |
iobkt = serf_bucket_iovec_create(vecs, 0, alloc);
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, SERF_READ_ALL_AVAIL, 32,
|
|
Packit |
3adb1e |
tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, vecs_used);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(iobkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, len);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 4: read 0 bytes from an iovec */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING("line1" CRLF, alloc);
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(bkt, SERF_READ_ALL_AVAIL, 32, vecs,
|
|
Packit |
3adb1e |
&vecs_used);
|
|
Packit |
3adb1e |
iobkt = serf_bucket_iovec_create(vecs, vecs_used, alloc);
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(iobkt, 0, 32,
|
|
Packit |
3adb1e |
tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, vecs_used);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Construct a header bucket with some headers, and then read from it. */
|
|
Packit |
3adb1e |
static void test_header_buckets(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
const char *cur;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_t *hdrs = serf_bucket_headers_create(alloc);
|
|
Packit |
3adb1e |
CuAssertTrue(tc, hdrs != NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_headers_set(hdrs, "Content-Type", "text/plain");
|
|
Packit |
3adb1e |
serf_bucket_headers_set(hdrs, "Content-Length", "100");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Note: order not guaranteed, assume here that it's fifo. */
|
|
Packit |
3adb1e |
cur = "Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 100" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
CRLF;
|
|
Packit |
3adb1e |
while (1) {
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(hdrs, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Unexpected error when waiting for response headers",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
if (SERF_BUCKET_READ_ERROR(status) ||
|
|
Packit |
3adb1e |
APR_STATUS_IS_EOF(status))
|
|
Packit |
3adb1e |
break;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Check that the bytes read match with expected at current position. */
|
|
Packit |
3adb1e |
CuAssertStrnEquals(tc, cur, len, data);
|
|
Packit |
3adb1e |
cur += len;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_aggregate_buckets(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *aggbkt;
|
|
Packit |
3adb1e |
struct iovec tgt_vecs[32];
|
|
Packit |
3adb1e |
int vecs_used;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
const char *BODY = "12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
CRLF;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 1: read 0 bytes from an aggregate */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING(BODY, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read_iovec(aggbkt, 0, 32,
|
|
Packit |
3adb1e |
tgt_vecs, &vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, vecs_used);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 2: peek the available bytes, should be non-0 */
|
|
Packit |
3adb1e |
len = SERF_READ_ALL_AVAIL;
|
|
Packit |
3adb1e |
status = serf_bucket_peek(aggbkt, &data, &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* status should be either APR_SUCCESS or APR_EOF */
|
|
Packit |
3adb1e |
if (status == APR_SUCCESS)
|
|
Packit |
3adb1e |
CuAssertTrue(tc, len > 0 && len < strlen(BODY));
|
|
Packit |
3adb1e |
else if (status == APR_EOF)
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, strlen(BODY), len);
|
|
Packit |
3adb1e |
else
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 3: read the data from the bucket. */
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, aggbkt, BODY);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 4: multiple child buckets appended. */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY, 15, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+15, strlen(BODY)-15, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, aggbkt, BODY);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 5: multiple child buckets prepended. */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+15, strlen(BODY)-15, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_prepend(aggbkt, bkt);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY, 15, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_prepend(aggbkt, bkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, aggbkt, BODY);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 6: ensure peek doesn't return APR_EAGAIN, or APR_EOF incorrectly. */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY, 15, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+15, strlen(BODY)-15, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
len = 1234;
|
|
Packit |
3adb1e |
status = serf_bucket_peek(aggbkt, &data, &len;;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
CuAssert(tc, "Length should be positive.",
|
|
Packit |
3adb1e |
len > 0 && len <= strlen(BODY) );
|
|
Packit |
3adb1e |
CuAssert(tc, "Data should match first part of body.",
|
|
Packit |
3adb1e |
strncmp(BODY, data, len) == 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_aggregate_bucket_readline(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *aggbkt;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
const char *BODY = "12345678901234567890" CRLF
|
|
Packit |
3adb1e |
"12345678901234567890" CRLF
|
|
Packit |
3adb1e |
"12345678901234567890" CRLF;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 1: read lines from an aggregate bucket */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY, 22, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt); /* 1st line */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+22, strlen(BODY)-22, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt); /* 2nd and 3rd line */
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING(BODY, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, aggbkt, SERF_NEWLINE_CRLF, BODY, 3);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 2: start with empty bucket */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN("", 0, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt); /* empty bucket */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY, 22, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt); /* 1st line */
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+22, strlen(BODY)-22, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt); /* 2nd and 3rd line */
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING(BODY, alloc);
|
|
Packit |
3adb1e |
readlines_and_check_bucket(tc, aggbkt, SERF_NEWLINE_CRLF, BODY, 3);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test for issue: the server aborts the connection in the middle of
|
|
Packit |
3adb1e |
streaming the body of the response, where the length was set with the
|
|
Packit |
3adb1e |
Content-Length header. Test that we get a decent error code from the
|
|
Packit |
3adb1e |
response bucket instead of APR_EOF. */
|
|
Packit |
3adb1e |
static void test_response_body_too_small_cl(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Make a response of 60 bytes, but set the Content-Length to 100. */
|
|
Packit |
3adb1e |
#define BODY "12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 100" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
BODY,
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Read more data than expected.",
|
|
Packit |
3adb1e |
strlen(BODY) >= len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(BODY, data, len) == 0);
|
|
Packit |
3adb1e |
CuAssert(tc, "Error expected due to response body too short!",
|
|
Packit |
3adb1e |
SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_ERROR_TRUNCATED_HTTP_RESPONSE, status);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
#undef BODY
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test for issue: the server aborts the connection in the middle of
|
|
Packit |
3adb1e |
streaming the body of the response, using chunked encoding. Test that we get
|
|
Packit |
3adb1e |
a decent error code from the response bucket instead of APR_EOF. */
|
|
Packit |
3adb1e |
static void test_response_body_too_small_chunked(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Make a response of 60 bytes, but set the chunk size to 60 and don't end
|
|
Packit |
3adb1e |
with chunk of length 0. */
|
|
Packit |
3adb1e |
#define BODY "12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"64" CRLF BODY,
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Read more data than expected.",
|
|
Packit |
3adb1e |
strlen(BODY) >= len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(BODY, data, len) == 0);
|
|
Packit |
3adb1e |
CuAssert(tc, "Error expected due to response body too short!",
|
|
Packit |
3adb1e |
SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_ERROR_TRUNCATED_HTTP_RESPONSE, status);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
#undef BODY
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test for issue: the server aborts the connection in the middle of
|
|
Packit |
3adb1e |
streaming trailing CRLF after body chunk. Test that we get
|
|
Packit |
3adb1e |
a decent error code from the response bucket instead of APR_EOF. */
|
|
Packit |
3adb1e |
static void test_response_body_chunked_no_crlf(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"2" CRLF
|
|
Packit |
3adb1e |
"AB",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
char buf[1024];
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = read_all(bkt, buf, sizeof(buf), &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_ERROR_TRUNCATED_HTTP_RESPONSE, status);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test for issue: the server aborts the connection in the middle of
|
|
Packit |
3adb1e |
streaming trailing CRLF after body chunk. Test that we get
|
|
Packit |
3adb1e |
a decent error code from the response bucket instead of APR_EOF. */
|
|
Packit |
3adb1e |
static void test_response_body_chunked_incomplete_crlf(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"2" CRLF
|
|
Packit |
3adb1e |
"AB"
|
|
Packit |
3adb1e |
"\r",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
char buf[1024];
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = read_all(bkt, buf, sizeof(buf), &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_ERROR_TRUNCATED_HTTP_RESPONSE, status);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_response_body_chunked_gzip_small(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
"Content-Encoding: gzip" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"2" CRLF
|
|
Packit |
3adb1e |
"A",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
char buf[1024];
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = read_all(bkt, buf, sizeof(buf), &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_ERROR_TRUNCATED_HTTP_RESPONSE, status);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_response_bucket_peek_at_headers(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_t *resp_bkt1, *tmp, *hdrs;
|
|
Packit |
3adb1e |
serf_status_line sl;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
const char *hdr_val, *cur;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#define EXP_RESPONSE "HTTP/1.1 200 OK" CRLF\
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF\
|
|
Packit |
3adb1e |
"Content-Length: 100" CRLF\
|
|
Packit |
3adb1e |
CRLF\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING(EXP_RESPONSE,
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
resp_bkt1 = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_response_status(resp_bkt1, &sl);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 200, sl.code);
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "OK", sl.reason);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, SERF_HTTP_11, sl.version);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Ensure that the status line & headers are read in the response_bucket. */
|
|
Packit |
3adb1e |
status = serf_bucket_response_wait_for_headers(resp_bkt1);
|
|
Packit |
3adb1e |
CuAssert(tc, "Unexpected error when waiting for response headers",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
hdrs = serf_bucket_response_get_headers(resp_bkt1);
|
|
Packit |
3adb1e |
CuAssertPtrNotNull(tc, hdrs);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
hdr_val = serf_bucket_headers_get(hdrs, "Content-Type");
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "text/plain", hdr_val);
|
|
Packit |
3adb1e |
hdr_val = serf_bucket_headers_get(hdrs, "Content-Length");
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "100", hdr_val);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Create a new bucket for the response which still has the original
|
|
Packit |
3adb1e |
status line & headers. */
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_response_full_become_aggregate(resp_bkt1);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
cur = EXP_RESPONSE;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
while (1) {
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(resp_bkt1, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Unexpected error when waiting for response headers",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
if (SERF_BUCKET_READ_ERROR(status) ||
|
|
Packit |
3adb1e |
APR_STATUS_IS_EOF(status))
|
|
Packit |
3adb1e |
break;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Check that the bytes read match with expected at current position. */
|
|
Packit |
3adb1e |
CuAssertStrnEquals(tc, cur, len, data);
|
|
Packit |
3adb1e |
cur += len;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
#undef EXP_RESPONSE
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* ### this test is useful, but needs to switch to the new COPY bucket
|
|
Packit |
3adb1e |
### to test the behavior. */
|
|
Packit |
3adb1e |
#if 0
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test that the internal function serf_default_read_iovec, used by many
|
|
Packit |
3adb1e |
bucket types, groups multiple buffers in one iovec. */
|
|
Packit |
3adb1e |
static void test_serf_default_read_iovec(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *aggbkt;
|
|
Packit |
3adb1e |
struct iovec tgt_vecs[32];
|
|
Packit |
3adb1e |
int vecs_used, i;
|
|
Packit |
3adb1e |
apr_size_t actual_len = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
const char *BODY = "12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890"\
|
|
Packit |
3adb1e |
CRLF;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 1: multiple children, should be read in one iovec. */
|
|
Packit |
3adb1e |
aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY, 20, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+20, 20, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
bkt = SERF_BUCKET_SIMPLE_STRING_LEN(BODY+40, strlen(BODY)-40, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, bkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_default_read_iovec(aggbkt, SERF_READ_ALL_AVAIL, 32, tgt_vecs,
|
|
Packit |
3adb1e |
&vecs_used);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
for (i = 0; i < vecs_used; i++)
|
|
Packit |
3adb1e |
actual_len += tgt_vecs[i].iov_len;
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, strlen(BODY), actual_len);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#endif
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test that serf doesn't hang in an endless loop when a linebuf is in
|
|
Packit |
3adb1e |
split-CRLF state. */
|
|
Packit |
3adb1e |
static void test_linebuf_crlf_split(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *mock_bkt, *bkt;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
mockbkt_action actions[]= {
|
|
Packit |
3adb1e |
{ 1, "HTTP/1.1 200 OK" CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
{ 1, "Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
{ 1, "6" CR, APR_SUCCESS },
|
|
Packit |
3adb1e |
{ 1, "", APR_EAGAIN },
|
|
Packit |
3adb1e |
{ 1, LF "blabla" CRLF CRLF, APR_SUCCESS }, };
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
const char *expected = "blabla";
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
mock_bkt = serf_bucket_mock_create(actions, 5, alloc);
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(mock_bkt, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during bucket reading.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
CuAssert(tc, "Read more data than expected.",
|
|
Packit |
3adb1e |
strlen(expected) >= len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(expected, data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
expected += len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (len == 0 && status == APR_EAGAIN)
|
|
Packit |
3adb1e |
serf_bucket_mock_more_data_arrived(mock_bkt);
|
|
Packit |
3adb1e |
} while(!APR_STATUS_IS_EOF(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Read less data than expected.", strlen(expected) == 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test handling responses without a reason by response buckets. */
|
|
Packit |
3adb1e |
static void test_response_bucket_no_reason(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
test_baton_t *tb = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
serf_status_line sline;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(tb->pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 401" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 2" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"AB",
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
read_and_check_bucket(tc, bkt, "AB");
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_response_status(bkt, &sline);
|
|
Packit |
3adb1e |
CuAssertTrue(tc, sline.version == SERF_HTTP_11);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 401, sline.code);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Probably better to have just "Logon failed" as reason. But current
|
|
Packit |
3adb1e |
behavior is also acceptable.*/
|
|
Packit |
3adb1e |
CuAssertStrEquals(tc, "", sline.reason);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test that serf can handle lines that don't arrive completely in one go.
|
|
Packit |
3adb1e |
It doesn't really run random, it tries inserting APR_EAGAIN in all possible
|
|
Packit |
3adb1e |
places in the response message, only one currently. */
|
|
Packit |
3adb1e |
static void test_random_eagain_in_response(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
apr_pool_t *iter_pool;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#define BODY "12345678901234567890123456789012345678901234567890"\
|
|
Packit |
3adb1e |
"12345678901234567890123456789012345678901234567890"
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
const char *expected = apr_psprintf(test_pool, "%s%s", BODY, BODY);
|
|
Packit |
3adb1e |
const char *fullmsg = "HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Date: Fri, 12 Jul 2013 15:13:52 GMT" CRLF
|
|
Packit |
3adb1e |
"Server: Apache/2.2.17 (Unix) mod_ssl/2.2.17 OpenSSL/1.0.1e DAV/2 "
|
|
Packit |
3adb1e |
"mod_wsgi/3.4 Python/2.7.3 SVN/1.7.10" CRLF
|
|
Packit |
3adb1e |
"DAV: 1,2" CRLF
|
|
Packit |
3adb1e |
"DAV: version-control,checkout,working-resource" CRLF
|
|
Packit |
3adb1e |
"DAV: merge,baseline,activity,version-controlled-collection" CRLF
|
|
Packit |
3adb1e |
"DAV: http://subversion.tigris.org/xmlns/dav/svn/depth" CRLF
|
|
Packit |
3adb1e |
"DAV: http://subversion.tigris.org/xmlns/dav/svn/log-revprops" CRLF
|
|
Packit |
3adb1e |
"DAV: http://subversion.tigris.org/xmlns/dav/svn/atomic-revprops" CRLF
|
|
Packit |
3adb1e |
"DAV: http://subversion.tigris.org/xmlns/dav/svn/partial-replay" CRLF
|
|
Packit |
3adb1e |
"DAV: http://subversion.tigris.org/xmlns/dav/svn/mergeinfo" CRLF
|
|
Packit |
3adb1e |
"DAV: <http://apache.org/dav/propset/fs/1>" CRLF
|
|
Packit |
3adb1e |
"MS-Author-Via: DAV" CRLF
|
|
Packit |
3adb1e |
"Allow: OPTIONS,GET,HEAD,POST,DELETE,TRACE,PROPFIND,PROPPATCH,COPY,MOVE,"
|
|
Packit |
3adb1e |
"LOCK,UNLOCK,CHECKOUT" CRLF
|
|
Packit |
3adb1e |
"SVN-Youngest-Rev: 1502584" CRLF
|
|
Packit |
3adb1e |
"SVN-Repository-UUID: 13f79535-47bb-0310-9956-ffa450edef68" CRLF
|
|
Packit |
3adb1e |
"SVN-Repository-Root: /repos/asf" CRLF
|
|
Packit |
3adb1e |
"SVN-Me-Resource: /repos/asf/!svn/me" CRLF
|
|
Packit |
3adb1e |
"SVN-Rev-Root-Stub: /repos/asf/!svn/rvr" CRLF
|
|
Packit |
3adb1e |
"SVN-Rev-Stub: /repos/asf/!svn/rev" CRLF
|
|
Packit |
3adb1e |
"SVN-Txn-Root-Stub: /repos/asf/!svn/txr" CRLF
|
|
Packit |
3adb1e |
"SVN-Txn-Stub: /repos/asf/!svn/txn" CRLF
|
|
Packit |
3adb1e |
"SVN-VTxn-Root-Stub: /repos/asf/!svn/vtxr" CRLF
|
|
Packit |
3adb1e |
"SVN-VTxn-Stub: /repos/asf/!svn/vtxn" CRLF
|
|
Packit |
3adb1e |
"Vary: Accept-Encoding" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/xml; charset=\"utf-8\"" CRLF
|
|
Packit |
3adb1e |
"Transfer-Encoding: chunked" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"64" CRLF
|
|
Packit |
3adb1e |
BODY CRLF
|
|
Packit |
3adb1e |
"64" CRLF
|
|
Packit |
3adb1e |
BODY CRLF
|
|
Packit |
3adb1e |
"0" CRLF
|
|
Packit |
3adb1e |
CRLF;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
const long nr_of_tests = strlen(fullmsg);
|
|
Packit |
3adb1e |
long i;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
mockbkt_action actions[]= {
|
|
Packit |
3adb1e |
{ 1, NULL, APR_EAGAIN },
|
|
Packit |
3adb1e |
{ 1, NULL, APR_EAGAIN },
|
|
Packit |
3adb1e |
};
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_create(&iter_pool, test_pool);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
for (i = 0; i < nr_of_tests; i++) {
|
|
Packit |
3adb1e |
serf_bucket_t *mock_bkt, *bkt;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc;
|
|
Packit |
3adb1e |
const char *ptr = expected;
|
|
Packit |
3adb1e |
const char *part1, *part2;
|
|
Packit |
3adb1e |
apr_size_t cut;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_clear(iter_pool);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
alloc = serf_bucket_allocator_create(iter_pool, NULL, NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
cut = i % strlen(fullmsg);
|
|
Packit |
3adb1e |
part1 = apr_pstrndup(iter_pool, fullmsg, cut);
|
|
Packit |
3adb1e |
part2 = apr_pstrdup(iter_pool, fullmsg + cut);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
actions[0].data = part1;
|
|
Packit |
3adb1e |
actions[1].data = part2;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
mock_bkt = serf_bucket_mock_create(actions, 2, alloc);
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(mock_bkt, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data, *errmsg;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during bucket reading.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
errmsg = apr_psprintf(iter_pool,
|
|
Packit |
3adb1e |
"Read more data than expected, EAGAIN"
|
|
Packit |
3adb1e |
" inserted at pos: %d, remainder: \"%s\"",
|
|
Packit |
3adb1e |
cut, fullmsg + cut);
|
|
Packit |
3adb1e |
CuAssert(tc, errmsg, strlen(ptr) >= len);
|
|
Packit |
3adb1e |
errmsg = apr_psprintf(iter_pool,
|
|
Packit |
3adb1e |
"Read data is not equal to expected, EAGAIN"
|
|
Packit |
3adb1e |
" inserted at pos: %d, remainder: \"%s\"",
|
|
Packit |
3adb1e |
cut, fullmsg + cut);
|
|
Packit |
3adb1e |
CuAssertStrnEquals_Msg(tc, errmsg, ptr, len, data);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
ptr += len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (len == 0 && status == APR_EAGAIN)
|
|
Packit |
3adb1e |
serf_bucket_mock_more_data_arrived(mock_bkt);
|
|
Packit |
3adb1e |
} while(!APR_STATUS_IS_EOF(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Read less data than expected.", strlen(ptr) == 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
apr_pool_destroy(iter_pool);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_dechunk_buckets(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *mock_bkt, *bkt;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(test_pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
mockbkt_action actions[]= {
|
|
Packit |
3adb1e |
/* one chunk */
|
|
Packit |
3adb1e |
{ 1, "6" CRLF "blabla" CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
/* EAGAIN after first chunk */
|
|
Packit |
3adb1e |
{ 1, "6" CRLF "blabla" CRLF, APR_EAGAIN },
|
|
Packit |
3adb1e |
{ 1, "6" CRLF "blabla" CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
/* CRLF after body split */
|
|
Packit |
3adb1e |
{ 1, "6" CRLF "blabla" CR, APR_EAGAIN },
|
|
Packit |
3adb1e |
{ 1, LF, APR_SUCCESS },
|
|
Packit |
3adb1e |
/* CRLF before body split */
|
|
Packit |
3adb1e |
{ 1, "6" CR, APR_SUCCESS },
|
|
Packit |
3adb1e |
{ 1, "", APR_EAGAIN },
|
|
Packit |
3adb1e |
{ 1, LF "blabla" CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
/* empty chunk */
|
|
Packit |
3adb1e |
{ 1, "", APR_SUCCESS },
|
|
Packit |
3adb1e |
/* two chunks */
|
|
Packit |
3adb1e |
{ 1, "6" CRLF "blabla" CRLF "6" CRLF "blabla" CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
/* three chunks */
|
|
Packit |
3adb1e |
{ 1, "6" CRLF "blabla" CRLF "6" CRLF "blabla" CRLF
|
|
Packit |
3adb1e |
"0" CRLF "" CRLF, APR_SUCCESS },
|
|
Packit |
3adb1e |
};
|
|
Packit |
3adb1e |
const int nr_of_actions = sizeof(actions) / sizeof(mockbkt_action);
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
const char *body = "blabla";
|
|
Packit |
3adb1e |
const char *expected = apr_psprintf(test_pool, "%s%s%s%s%s%s%s%s%s", body,
|
|
Packit |
3adb1e |
body, body, body, body, body, body,
|
|
Packit |
3adb1e |
body, body);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
mock_bkt = serf_bucket_mock_create(actions, nr_of_actions, alloc);
|
|
Packit |
3adb1e |
bkt = serf_bucket_dechunk_create(mock_bkt, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &len;;
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during bucket reading.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
CuAssert(tc, "Read more data than expected.",
|
|
Packit |
3adb1e |
strlen(expected) >= len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(expected, data, len) == 0);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
expected += len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (len == 0 && status == APR_EAGAIN)
|
|
Packit |
3adb1e |
serf_bucket_mock_more_data_arrived(mock_bkt);
|
|
Packit |
3adb1e |
} while(!APR_STATUS_IS_EOF(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Read less data than expected.", strlen(expected) == 0);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test that the Content-Length header will be ignored when the response
|
|
Packit |
3adb1e |
should not have returned a body. See RFC2616, section 4.4, nbr. 1. */
|
|
Packit |
3adb1e |
static void test_response_no_body_expected(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *bkt, *tmp;
|
|
Packit |
3adb1e |
apr_pool_t *test_pool = tc->testBaton;
|
|
Packit |
3adb1e |
char buf[1024];
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc;
|
|
Packit |
3adb1e |
int i;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* response bucket should consider the blablablablabla as start of the
|
|
Packit |
3adb1e |
next response, in all these cases it should APR_EOF after the empty
|
|
Packit |
3adb1e |
line. */
|
|
Packit |
3adb1e |
test_server_message_t message_list[] = {
|
|
Packit |
3adb1e |
{ "HTTP/1.1 100 Continue" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 6500000" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"blablablablabla" CRLF },
|
|
Packit |
3adb1e |
{ "HTTP/1.1 204 No Content" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 6500000" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"blablablablabla" CRLF },
|
|
Packit |
3adb1e |
{ "HTTP/1.1 304 Not Modified" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 6500000" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"blablablablabla" CRLF },
|
|
Packit |
3adb1e |
};
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
alloc = serf_bucket_allocator_create(test_pool, NULL, NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 1: a response to a HEAD request. */
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING("HTTP/1.1 200 OK" CRLF
|
|
Packit |
3adb1e |
"Content-Type: text/plain" CRLF
|
|
Packit |
3adb1e |
"Content-Length: 6500000" CRLF
|
|
Packit |
3adb1e |
CRLF
|
|
Packit |
3adb1e |
"blablablablabla" CRLF,
|
|
Packit |
3adb1e |
alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
serf_bucket_response_set_head(bkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = read_all(bkt, buf, sizeof(buf), &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, len);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test 2: a response with status for which server must not send a body. */
|
|
Packit |
3adb1e |
for (i = 0; i < sizeof(message_list) / sizeof(test_server_message_t); i++) {
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tmp = SERF_BUCKET_SIMPLE_STRING(message_list[i].text, alloc);
|
|
Packit |
3adb1e |
bkt = serf_bucket_response_create(tmp, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = read_all(bkt, buf, sizeof(buf), &len;;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_EOF, status);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, 0, len);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static apr_status_t deflate_compress(const char **data, apr_size_t *len,
|
|
Packit |
3adb1e |
z_stream *zdestr,
|
|
Packit |
3adb1e |
const char *orig, apr_size_t orig_len,
|
|
Packit |
3adb1e |
int last,
|
|
Packit |
3adb1e |
apr_pool_t *pool)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
int zerr;
|
|
Packit |
3adb1e |
apr_size_t buf_size;
|
|
Packit |
3adb1e |
void *write_buf;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* The largest buffer we should need is 0.1% larger than the
|
|
Packit |
3adb1e |
uncompressed data, + 12 bytes. This info comes from zlib.h.
|
|
Packit |
3adb1e |
buf_size = orig_len + (orig_len / 1000) + 12;
|
|
Packit |
3adb1e |
Note: This isn't sufficient when using Z_NO_FLUSH and extremely compressed
|
|
Packit |
3adb1e |
data. Use a buffer bigger than what we need. */
|
|
Packit |
3adb1e |
buf_size = 100000;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
write_buf = apr_palloc(pool, buf_size);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
zdestr->next_in = (Bytef *)orig; /* Casting away const! */
|
|
Packit |
3adb1e |
zdestr->avail_in = (uInt)orig_len;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
zerr = Z_OK;
|
|
Packit |
3adb1e |
zdestr->next_out = write_buf;
|
|
Packit |
3adb1e |
zdestr->avail_out = (uInt)buf_size;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
while ((last && zerr != Z_STREAM_END) ||
|
|
Packit |
3adb1e |
(!last && zdestr->avail_in > 0))
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
zerr = deflate(zdestr, last ? Z_FINISH : Z_NO_FLUSH);
|
|
Packit |
3adb1e |
if (zerr < 0)
|
|
Packit |
3adb1e |
return APR_EGENERAL;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
*data = write_buf;
|
|
Packit |
3adb1e |
*len = buf_size - zdestr->avail_out;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
return APR_SUCCESS;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Reads bucket until EOF found and compares read data with zero terminated
|
|
Packit |
3adb1e |
string expected. Report all failures using CuTest. */
|
|
Packit |
3adb1e |
static void read_bucket_and_check_pattern(CuTest *tc, serf_bucket_t *bkt,
|
|
Packit |
3adb1e |
const char *pattern,
|
|
Packit |
3adb1e |
apr_size_t expected_len)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
const char *expected;
|
|
Packit |
3adb1e |
const apr_size_t pattern_len = strlen(pattern);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_size_t exp_rem = 0;
|
|
Packit |
3adb1e |
apr_size_t actual_len = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t act_rem;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &act_rem);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during bucket reading.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
actual_len += act_rem;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
while (act_rem > 0) {
|
|
Packit |
3adb1e |
apr_size_t bytes_to_compare;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (exp_rem == 0) {
|
|
Packit |
3adb1e |
expected = pattern;
|
|
Packit |
3adb1e |
exp_rem = pattern_len;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
bytes_to_compare = act_rem < exp_rem ? act_rem : exp_rem;
|
|
Packit |
3adb1e |
CuAssert(tc, "Read data is not equal to expected.",
|
|
Packit |
3adb1e |
strncmp(expected, data, bytes_to_compare) == 0);
|
|
Packit |
3adb1e |
data += bytes_to_compare;
|
|
Packit |
3adb1e |
act_rem -= bytes_to_compare;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
expected += bytes_to_compare;
|
|
Packit |
3adb1e |
exp_rem -= bytes_to_compare;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
} while(!APR_STATUS_IS_EOF(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertIntEquals_Msg(tc, "Read less data than expected.", 0, exp_rem);
|
|
Packit |
3adb1e |
CuAssertIntEquals_Msg(tc, "Read less/more data than expected.", actual_len,
|
|
Packit |
3adb1e |
expected_len);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void deflate_buckets(CuTest *tc, int nr_of_loops, apr_pool_t *pool)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *msg = "12345678901234567890123456789012345678901234567890";
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
test_baton_t *tb = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
z_stream zdestr;
|
|
Packit |
3adb1e |
int i;
|
|
Packit |
3adb1e |
const char gzip_header[10] =
|
|
Packit |
3adb1e |
{ '\037', '\213', Z_DEFLATED, 0,
|
|
Packit |
3adb1e |
0, 0, 0, 0, /* mtime */
|
|
Packit |
3adb1e |
0, 0x03 /* Unix OS_CODE */
|
|
Packit |
3adb1e |
};
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_t *aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
serf_bucket_t *defbkt = serf_bucket_deflate_create(aggbkt, alloc,
|
|
Packit |
3adb1e |
SERF_DEFLATE_GZIP);
|
|
Packit |
3adb1e |
serf_bucket_t *strbkt;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#if 0 /* Enable logging */
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_config_t *config;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_context_t *ctx = serf_context_create(pool);
|
|
Packit |
3adb1e |
/* status = */ serf__config_store_get_config(ctx, NULL, &config, pool);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_set_config(defbkt, config);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
#endif
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
memset(&zdestr, 0, sizeof(z_stream));
|
|
Packit |
3adb1e |
/* HTTP uses raw deflate format, so windows size => -15 */
|
|
Packit |
3adb1e |
CuAssert(tc, "zlib init failed.",
|
|
Packit |
3adb1e |
deflateInit2(&zdestr, Z_DEFAULT_COMPRESSION, Z_DEFLATED, -15, 8,
|
|
Packit |
3adb1e |
Z_DEFAULT_STRATEGY) == Z_OK);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
strbkt = SERF_BUCKET_SIMPLE_STRING_LEN(gzip_header, 10, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, strbkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
for (i = 0; i < nr_of_loops; i++) {
|
|
Packit |
3adb1e |
const char *data = NULL;
|
|
Packit |
3adb1e |
apr_size_t len = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (i == nr_of_loops - 1) {
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS,
|
|
Packit |
3adb1e |
deflate_compress(&data, &len, &zdestr, msg,
|
|
Packit |
3adb1e |
strlen(msg), 1, pool));
|
|
Packit |
3adb1e |
} else {
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS,
|
|
Packit |
3adb1e |
deflate_compress(&data, &len, &zdestr, msg,
|
|
Packit |
3adb1e |
strlen(msg), 0, pool));
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (len == 0)
|
|
Packit |
3adb1e |
continue;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
strbkt = SERF_BUCKET_SIMPLE_STRING_LEN(data, len, alloc);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, strbkt);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tb->user_baton_l = APR_EOF;
|
|
Packit |
3adb1e |
read_bucket_and_check_pattern(tc, defbkt, msg, nr_of_loops * strlen(msg));
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void test_deflate_buckets(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
int i;
|
|
Packit |
3adb1e |
apr_pool_t *iterpool;
|
|
Packit |
3adb1e |
test_baton_t *tb = tc->testBaton;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_create(&iterpool, tb->pool);
|
|
Packit |
3adb1e |
for (i = 1; i < 1000; i++) {
|
|
Packit |
3adb1e |
apr_pool_clear(iterpool);
|
|
Packit |
3adb1e |
deflate_buckets(tc, i, iterpool);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
apr_pool_destroy(iterpool);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static apr_status_t discard_data(serf_bucket_t *bkt,
|
|
Packit |
3adb1e |
apr_size_t *read_len)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t data_len;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
apr_size_t read;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
read = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
do
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
status = serf_bucket_read(bkt, SERF_READ_ALL_AVAIL, &data, &data_len);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (!SERF_BUCKET_READ_ERROR(status)) {
|
|
Packit |
3adb1e |
read += data_len;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
} while(status == APR_SUCCESS);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
*read_len = read;
|
|
Packit |
3adb1e |
return status;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static apr_status_t hold_open(void *baton, serf_bucket_t *aggbkt)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
test_baton_t *tb = baton;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
return tb->user_baton_l;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static void put_32bit(unsigned char *buf, unsigned long x)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
buf[0] = (unsigned char)(x & 0xFF);
|
|
Packit |
3adb1e |
buf[1] = (unsigned char)((x & 0xFF00) >> 8);
|
|
Packit |
3adb1e |
buf[2] = (unsigned char)((x & 0xFF0000) >> 16);
|
|
Packit |
3adb1e |
buf[3] = (unsigned char)((x & 0xFF000000) >> 24);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
static serf_bucket_t *
|
|
Packit |
3adb1e |
create_gzip_deflate_bucket(serf_bucket_t *stream, z_stream *outzstr,
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_bucket_t *strbkt;
|
|
Packit |
3adb1e |
serf_bucket_t *defbkt = serf_bucket_deflate_create(stream, alloc,
|
|
Packit |
3adb1e |
SERF_DEFLATE_GZIP);
|
|
Packit |
3adb1e |
int zerr;
|
|
Packit |
3adb1e |
const char gzip_header[10] =
|
|
Packit |
3adb1e |
{ '\037', '\213', Z_DEFLATED, 0,
|
|
Packit |
3adb1e |
0, 0, 0, 0, /* mtime */
|
|
Packit |
3adb1e |
0, 0x03 /* Unix OS_CODE */
|
|
Packit |
3adb1e |
};
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
memset(outzstr, 0, sizeof(z_stream));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* HTTP uses raw deflate format, so windows size => -15 */
|
|
Packit |
3adb1e |
zerr = deflateInit2(outzstr, Z_DEFAULT_COMPRESSION, Z_DEFLATED, -15, 8,
|
|
Packit |
3adb1e |
Z_DEFAULT_STRATEGY);
|
|
Packit |
3adb1e |
if (zerr != Z_OK)
|
|
Packit |
3adb1e |
return NULL;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
strbkt = SERF_BUCKET_SIMPLE_STRING_LEN(gzip_header, 10, alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(stream, strbkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
return defbkt;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Test for issue #152: the trailers of gzipped data only store the 4 most
|
|
Packit |
3adb1e |
significant bytes of the length, so when the compressed data is >4GB
|
|
Packit |
3adb1e |
we can't just compare actual length with expected length. */
|
|
Packit |
3adb1e |
static void test_deflate_4GBplus_buckets(CuTest *tc)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
test_baton_t *tb = tc->testBaton;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *alloc = serf_bucket_allocator_create(tb->pool, NULL,
|
|
Packit |
3adb1e |
NULL);
|
|
Packit |
3adb1e |
int i;
|
|
Packit |
3adb1e |
unsigned char gzip_trailer[8];
|
|
Packit |
3adb1e |
z_stream zdestr;
|
|
Packit |
3adb1e |
serf_bucket_t *aggbkt = serf_bucket_aggregate_create(alloc);
|
|
Packit |
3adb1e |
serf_bucket_t *defbkt = create_gzip_deflate_bucket(aggbkt, &zdestr, alloc);
|
|
Packit |
3adb1e |
serf_bucket_t *strbkt;
|
|
Packit |
3adb1e |
apr_pool_t *iter_pool;
|
|
Packit |
3adb1e |
apr_size_t actual_size;
|
|
Packit |
3adb1e |
unsigned long unc_crc = 0;
|
|
Packit |
3adb1e |
unsigned long unc_length = 0;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#define NR_OF_LOOPS 550000
|
|
Packit |
3adb1e |
#define BUFSIZE 8096
|
|
Packit |
3adb1e |
unsigned char uncompressed[BUFSIZE];
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_aggregate_hold_open(aggbkt, hold_open, tb);
|
|
Packit |
3adb1e |
tb->user_baton_l = APR_EAGAIN;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#if 0 /* Enable logging */
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
serf_config_t *config;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_context_t *ctx = serf_context_create(tb->pool);
|
|
Packit |
3adb1e |
/* status = */ serf__config_store_get_config(ctx, NULL, &config, tb->pool);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
serf_bucket_set_config(defbkt, config);
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
#endif
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_create(&iter_pool, tb->pool);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
actual_size = 0;
|
|
Packit |
3adb1e |
for (i = 0; i < NR_OF_LOOPS; i++) {
|
|
Packit |
3adb1e |
const char *data;
|
|
Packit |
3adb1e |
apr_size_t len;
|
|
Packit |
3adb1e |
apr_size_t read_len;
|
|
Packit |
3adb1e |
serf_bucket_alloc_t *iter_alloc;
|
|
Packit |
3adb1e |
apr_status_t status;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
apr_pool_clear(iter_pool);
|
|
Packit |
3adb1e |
iter_alloc = serf_bucket_allocator_create(iter_pool, NULL, NULL);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (i % 1000 == 0)
|
|
Packit |
3adb1e |
printf("%d\n", i);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
status = apr_generate_random_bytes(uncompressed, BUFSIZE);
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS, status);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
unc_crc = crc32(unc_crc, (const Bytef *)uncompressed, BUFSIZE);
|
|
Packit |
3adb1e |
unc_length += BUFSIZE;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (i == NR_OF_LOOPS - 1) {
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS,
|
|
Packit |
3adb1e |
deflate_compress(&data, &len, &zdestr,
|
|
Packit |
3adb1e |
(const char *)uncompressed,
|
|
Packit |
3adb1e |
BUFSIZE, 1, iter_pool));
|
|
Packit |
3adb1e |
} else {
|
|
Packit |
3adb1e |
CuAssertIntEquals(tc, APR_SUCCESS,
|
|
Packit |
3adb1e |
deflate_compress(&data, &len, &zdestr,
|
|
Packit |
3adb1e |
(const char *)uncompressed,
|
|
Packit |
3adb1e |
BUFSIZE, 0, iter_pool));
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
if (len == 0)
|
|
Packit |
3adb1e |
continue;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
strbkt = serf_bucket_simple_copy_create(data, len, iter_alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, strbkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
/* Start reading inflated data */
|
|
Packit |
3adb1e |
status = discard_data(defbkt, &read_len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during discarding of compressed data.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
actual_size += read_len;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
put_32bit(&gzip_trailer[0], unc_crc);
|
|
Packit |
3adb1e |
put_32bit(&gzip_trailer[4], unc_length);
|
|
Packit |
3adb1e |
strbkt = SERF_BUCKET_SIMPLE_STRING_LEN((const char *)gzip_trailer,
|
|
Packit |
3adb1e |
sizeof(gzip_trailer), alloc);
|
|
Packit |
3adb1e |
serf_bucket_aggregate_append(aggbkt, strbkt);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
tb->user_baton_l = APR_EOF;
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
while (1) {
|
|
Packit |
3adb1e |
apr_size_t read_len;
|
|
Packit |
3adb1e |
apr_status_t status = discard_data(defbkt, &read_len);
|
|
Packit |
3adb1e |
CuAssert(tc, "Got error during discarding of compressed data.",
|
|
Packit |
3adb1e |
!SERF_BUCKET_READ_ERROR(status));
|
|
Packit |
3adb1e |
actual_size += read_len;
|
|
Packit |
3adb1e |
if (status == APR_EOF)
|
|
Packit |
3adb1e |
break;
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuAssertTrue(tc, actual_size == (apr_size_t)NR_OF_LOOPS * BUFSIZE);
|
|
Packit |
3adb1e |
#undef NR_OF_LOOPS
|
|
Packit |
3adb1e |
#undef BUFSIZE
|
|
Packit |
3adb1e |
}
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuSuite *test_buckets(void)
|
|
Packit |
3adb1e |
{
|
|
Packit |
3adb1e |
CuSuite *suite = CuSuiteNew();
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
CuSuiteSetSetupTeardownCallbacks(suite, test_setup, test_teardown);
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_simple_bucket_readline);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_bucket_read);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_bucket_headers);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_bucket_chunked_read);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_body_too_small_cl);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_body_too_small_chunked);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_body_chunked_no_crlf);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_body_chunked_incomplete_crlf);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_body_chunked_gzip_small);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_bucket_peek_at_headers);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_bucket_no_reason);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_bucket_header_set);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_iovec_buckets);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_aggregate_buckets);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_aggregate_bucket_readline);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_header_buckets);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_linebuf_crlf_split);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_random_eagain_in_response);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_dechunk_buckets);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_response_no_body_expected);
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_deflate_buckets);
|
|
Packit |
3adb1e |
#if 0
|
|
Packit |
3adb1e |
/* This test for issue #152 takes a lot of time generating 4GB+ of random
|
|
Packit |
3adb1e |
data so it's disabled by default. */
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_deflate_4GBplus_buckets);
|
|
Packit |
3adb1e |
#endif
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
#if 0
|
|
Packit |
3adb1e |
SUITE_ADD_TEST(suite, test_serf_default_read_iovec);
|
|
Packit |
3adb1e |
#endif
|
|
Packit |
3adb1e |
|
|
Packit |
3adb1e |
return suite;
|
|
Packit |
3adb1e |
}
|