blob: 2b4d9efa430068b639d759b6c442aaabca780e13 [file] [log] [blame]
/* $Id$
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to you under the Apache License, Version
* 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* test_url.c -- test etch_url
*/
#include "etch_runtime.h"
#include "etch_url.h"
#include "etch_map.h"
#include "etch_thread.h"
#include "etch_objecttypes.h"
#include <stdio.h>
#include "CUnit.h"
#include <wchar.h>
#define IS_DEBUG_CONSOLE FALSE
// extern types
extern apr_pool_t* g_etch_main_pool;
/* - - - - - - - - - - - - - -
* unit test infrastructure
* - - - - - - - - - - - - - -
*/
static int init_suite(void)
{
etch_status_t etch_status = ETCH_SUCCESS;
etch_status = etch_runtime_initialize(NULL);
if(etch_status != NULL) {
// error
}
return 0;
}
static int clean_suite(void)
{
etch_runtime_shutdown();
return 0;
}
/* - - - - - - - - - - - - - -
* tests
* - - - - - - - - - - - - - -
*/
/*
* test_parse_1
*/
static void test_parse_1(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"www.cisco.com";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, ETCH_URL_DEFAULT_SCHEME);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, RAWURL);
CU_ASSERT_EQUAL(result,0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/*
* test_parse_2
*/
static void test_parse_2(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"http://www.cisco.com/cuae";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, L"http");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, L"www.cisco.com");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->uri, L"cuae");
CU_ASSERT_EQUAL(result,0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/*
* test_parse_3
*/
static void test_parse_3(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"http://www.cisco.com:8080/cuae?param";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, L"http");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, L"www.cisco.com");
CU_ASSERT_EQUAL(result,0);
result = url->port == 8080;
CU_ASSERT_EQUAL(result,TRUE);
result = wcscmp(url->uri, L"cuae");
CU_ASSERT_EQUAL(result,0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/*
* test_parse_4
*/
static void test_parse_4(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"http://administrator:metreos@www.cisco.com:8080/cuae?param";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, L"http");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->user, L"administrator");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->password, L"metreos");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, L"www.cisco.com");
CU_ASSERT_EQUAL(result,0);
result = url->port == 8080;
CU_ASSERT_EQUAL(result,TRUE);
result = wcscmp(url->uri, L"cuae");
CU_ASSERT_EQUAL(result,0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/*
* test_parse_5
* since colon is both scheme and username:password delimiter
* ensure we can omit scheme and include password
*/
static void test_parse_5(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"administrator:metreos@www.cisco.com:8080/cuae?param";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, L"http");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->user, L"administrator");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->password, L"metreos");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, L"www.cisco.com");
CU_ASSERT_EQUAL(result,0);
result = url->port == 8080;
CU_ASSERT_EQUAL(result,TRUE);
result = wcscmp(url->uri, L"cuae");
CU_ASSERT_EQUAL(result,0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/*
* test_parse_6
*/
static void test_parse_6(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"tcp://administrator:metreos@localhost:10000/defUri;param1;param2?term1=true&term2=false#defFragment";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, L"tcp");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->user, L"administrator");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->password, L"metreos");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, L"localhost");
CU_ASSERT_EQUAL(result,0);
result = url->port == 10000;
CU_ASSERT_EQUAL(result,TRUE);
result = wcscmp(url->uri, L"defUri");
CU_ASSERT_EQUAL(result,0);
result = etchurl_paramcount(url);
CU_ASSERT_EQUAL(result,2);
result = etchurl_termcount(url);
CU_ASSERT_EQUAL(result,2);
do
{ etch_iterator* iterator = etchurl_get_params(url);
CU_ASSERT_PTR_NOT_NULL_FATAL(iterator);
while(iterator->has_next(iterator))
{ int matches = 0;
etch_string* val = (etch_string*) iterator->current_value;
wchar_t* param = val? val->v.valw: NULL;
if (param && 0 == wcscmp(param, L"param1")) matches++;
if (param && 0 == wcscmp(param, L"param2")) matches++;
CU_ASSERT_EQUAL(matches,1);
iterator->next(iterator);
}
etch_object_destroy(iterator);
} while(0);
do
{ etch_iterator iterator;
set_iterator(&iterator, url->terms, &url->terms->iterable);
while(iterator.has_next(&iterator))
{ int keymatches = 0, valmatches = 0;
wchar_t* key = (wchar_t*) iterator.current_key;
etch_string* valobj = (etch_string*) iterator.current_value;
wchar_t* val = valobj? valobj->v.valw: NULL;
if (key && 0 == wcscmp(key, L"term1")) keymatches++;
if (key && 0 == wcscmp(key, L"term2")) keymatches++;
CU_ASSERT_EQUAL(keymatches,1);
if (val && 0 == wcscmp(val, L"false")) valmatches++;
if (val && 0 == wcscmp(val, L"true")) valmatches++;
CU_ASSERT_EQUAL(valmatches,1);
iterator.next(&iterator);
}
} while(0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/*
* test_parse_7
* test a url with duplicate term names
*/
static void test_parse_7(void)
{
int result = 0;
etch_url* url = NULL;
wchar_t* RAWURL = L"tcp://administrator:metreos@localhost:10000/defUri;param1;param2?term1=true&term1=false";
url = new_url(RAWURL);
CU_ASSERT_PTR_NOT_NULL_FATAL(url);
CU_ASSERT_NOT_EQUAL(url->bytecount,0);
CU_ASSERT_NOT_EQUAL(url->charcount,0);
result = wcscmp(url->raw, RAWURL);
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->scheme, L"tcp");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->user, L"administrator");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->password, L"metreos");
CU_ASSERT_EQUAL(result,0);
result = wcscmp(url->host, L"localhost");
CU_ASSERT_EQUAL(result,0);
result = url->port == 10000;
CU_ASSERT_EQUAL(result,TRUE);
result = wcscmp(url->uri, L"defUri");
CU_ASSERT_EQUAL(result,0);
result = etchurl_paramcount(url);
CU_ASSERT_EQUAL(result,2);
/* since terms had same name, the two terms should now be collected into a set,
* therefore the count (at top level) should be 1. this is of course based
* on our omniscient knowledge of the url content */
result = etchurl_termcount(url);
CU_ASSERT_EQUAL(result,1);
do /* iterate all params */
{ etch_iterator* iterator = etchurl_get_params(url);
CU_ASSERT_PTR_NOT_NULL_FATAL(iterator);
while(iterator->has_next(iterator))
{ int matches = 0;
etch_string* val = (etch_string*) iterator->current_value;
wchar_t* param = val? val->v.valw: NULL;
if (param && 0 == wcscmp(param, L"param1")) matches++;
if (param && 0 == wcscmp(param, L"param2")) matches++;
CU_ASSERT_EQUAL(matches,1);
iterator->next(iterator);
}
etch_object_destroy(iterator);
} while(0);
do /* iterate all terms */
{ etch_iterator iterator1;
set_iterator(&iterator1, url->terms, &url->terms->iterable);
/* this is hard coded base on our knowledge of the url content.
* there should be one term in the term map with the value "term1",
* and its value will be a set whose two members are etch_string
* objects having values of "true" and "false"
*/
while(iterator1.has_next(&iterator1))
{
etch_iterator iterator2;
etch_set* setobj = (etch_set*)iterator1.current_value;
CU_ASSERT_EQUAL_FATAL(is_etch_set(setobj), TRUE);
result = etchmap_count(setobj);
CU_ASSERT_EQUAL(result, 2);
set_iterator(&iterator2, setobj, &setobj->iterable);
while(iterator2.has_next(&iterator2))
{
int matches = 0;
wchar_t* val = 0;
etch_string* setmember = iterator2.current_key;
CU_ASSERT_EQUAL_FATAL(is_etch_string(setmember), TRUE);
val = setmember->v.valw;
if (val && 0 == wcscmp(val, L"true")) matches++;
if (val && 0 == wcscmp(val, L"false")) matches++;
CU_ASSERT_EQUAL(matches,1);
iterator2.next(&iterator2);
}
iterator1.next(&iterator1);
}
} while(0);
etch_object_destroy(url);
#ifdef ETCH_DEBUGALLOC
g_bytes_allocated = etch_showmem(0,IS_DEBUG_CONSOLE); /* verify all memory freed */
CU_ASSERT_EQUAL(g_bytes_allocated, 0);
// start fresh for next test
memtable_clear();
#endif
}
/**
* main
*/
//int _tmain(int argc, _TCHAR* argv[])
CU_pSuite test_etch_url_suite()
{
CU_pSuite pSuite = CU_add_suite("suite_url", init_suite, clean_suite);
CU_add_test(pSuite, "test parse 1", test_parse_1);
CU_add_test(pSuite, "test parse 2", test_parse_2);
CU_add_test(pSuite, "test parse 3", test_parse_3);
CU_add_test(pSuite, "test parse 4", test_parse_4);
CU_add_test(pSuite, "test parse 5", test_parse_5);
CU_add_test(pSuite, "test parse 6", test_parse_6);
CU_add_test(pSuite, "test parse 7", test_parse_7);
return pSuite;
}