summaryrefslogtreecommitdiffstats
path: root/rubbos/app/httpd-2.0.64/srclib/apr-util/test/testuri.c
diff options
context:
space:
mode:
Diffstat (limited to 'rubbos/app/httpd-2.0.64/srclib/apr-util/test/testuri.c')
-rw-r--r--rubbos/app/httpd-2.0.64/srclib/apr-util/test/testuri.c278
1 files changed, 0 insertions, 278 deletions
diff --git a/rubbos/app/httpd-2.0.64/srclib/apr-util/test/testuri.c b/rubbos/app/httpd-2.0.64/srclib/apr-util/test/testuri.c
deleted file mode 100644
index 675fa79f..00000000
--- a/rubbos/app/httpd-2.0.64/srclib/apr-util/test/testuri.c
+++ /dev/null
@@ -1,278 +0,0 @@
-/* Copyright 2000-2005 The Apache Software Foundation or its licensors, as
- * applicable.
- *
- * Licensed 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.
- */
-
-#include <stdio.h>
-#include <stdlib.h>
-
-#include "apr_general.h"
-#include "apr_uri.h"
-
-struct aup_test {
- const char *uri;
- apr_status_t rv;
- const char *scheme;
- const char *hostinfo;
- const char *user;
- const char *password;
- const char *hostname;
- const char *port_str;
- const char *path;
- const char *query;
- const char *fragment;
- apr_port_t port;
-};
-
-struct aup_test aup_tests[] =
-{
- { "http://[/::1]/index.html", APR_EGENERAL },
- { "http://[", APR_EGENERAL },
- { "http://[?::1]/index.html", APR_EGENERAL },
-
-
- {
- "http://127.0.0.1:9999/asdf.html",
- 0, "http", "127.0.0.1:9999", NULL, NULL, "127.0.0.1", "9999", "/asdf.html", NULL, NULL, 9999
- },
- {
- "http://127.0.0.1:9999a/asdf.html",
- APR_EGENERAL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0
- },
- {
- "http://[::127.0.0.1]:9999/asdf.html",
- 0, "http", "[::127.0.0.1]:9999", NULL, NULL, "::127.0.0.1", "9999", "/asdf.html", NULL, NULL, 9999
- },
- {
- "http://[::127.0.0.1]:9999a/asdf.html",
- APR_EGENERAL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0
- },
- {
- "/error/include/top.html",
- 0, NULL, NULL, NULL, NULL, NULL, NULL, "/error/include/top.html", NULL, NULL, 0
- },
- {
- "/error/include/../contact.html.var",
- 0, NULL, NULL, NULL, NULL, NULL, NULL, "/error/include/../contact.html.var", NULL, NULL, 0
- },
- {
- "/",
- 0, NULL, NULL, NULL, NULL, NULL, NULL, "/", NULL, NULL, 0
- },
- {
- "/manual/",
- 0, NULL, NULL, NULL, NULL, NULL, NULL, "/manual/", NULL, NULL, 0
- },
- {
- "/cocoon/developing/graphics/Using%20Databases-label_over.jpg",
- 0, NULL, NULL, NULL, NULL, NULL, NULL, "/cocoon/developing/graphics/Using%20Databases-label_over.jpg", NULL, NULL, 0
- },
- {
- "http://sonyamt:garbage@127.0.0.1/filespace/",
- 0, "http", "sonyamt:garbage@127.0.0.1", "sonyamt", "garbage", "127.0.0.1", NULL, "/filespace/", NULL, NULL, 0
- },
- {
- "http://sonyamt:garbage@[fe80::1]/filespace/",
- 0, "http", "sonyamt:garbage@[fe80::1]", "sonyamt", "garbage", "fe80::1", NULL, "/filespace/", NULL, NULL, 0
- },
- {
- "http://sonyamt@[fe80::1]/filespace/?arg1=store",
- 0, "http", "sonyamt@[fe80::1]", "sonyamt", NULL, "fe80::1", NULL, "/filespace/", "arg1=store", NULL, 0
- }
-};
-
-struct uph_test {
- const char *hostinfo;
- apr_status_t rv;
- const char *hostname;
- const char *port_str;
- apr_port_t port;
-};
-
-struct uph_test uph_tests[] =
-{
- {
- "www.ibm.com:443",
- 0, "www.ibm.com", "443", 443
- },
- {
- "[fe80::1]:443",
- 0, "fe80::1", "443", 443
- },
- {
- "127.0.0.1:443",
- 0, "127.0.0.1", "443", 443
- },
- {
- "127.0.0.1",
- APR_EGENERAL, NULL, NULL, 0
- },
- {
- "[fe80:80",
- APR_EGENERAL, NULL, NULL, 0
- },
- {
- "fe80::80]:443",
- APR_EGENERAL, NULL, NULL, 0
- }
-};
-
-static void show_info(apr_status_t rv, apr_status_t expected, const apr_uri_t *info)
-{
- if (rv != expected) {
- fprintf(stderr, " actual rv: %d expected rv: %d\n", rv, expected);
- }
- else {
- fprintf(stderr,
- " scheme: %s\n"
- " hostinfo: %s\n"
- " user: %s\n"
- " password: %s\n"
- " hostname: %s\n"
- " port_str: %s\n"
- " path: %s\n"
- " query: %s\n"
- " fragment: %s\n"
- " hostent: %p\n"
- " port: %u\n"
- " is_initialized: %u\n"
- " dns_looked_up: %u\n"
- " dns_resolved: %u\n",
- info->scheme, info->hostinfo, info->user, info->password,
- info->hostname, info->port_str, info->path, info->query,
- info->fragment, info->hostent, info->port, info->is_initialized,
- info->dns_looked_up, info->dns_resolved);
- }
-}
-
-static int same_str(const char *s1, const char *s2)
-{
- if (s1 == s2) { /* e.g., NULL and NULL */
- return 1;
- }
- else if (!s1 || !s2) { /* only 1 is NULL */
- return 0;
- }
- else {
- return strcmp(s1, s2) == 0;
- }
-}
-
-static int test_aup(apr_pool_t *p)
-{
- int i;
- apr_status_t rv;
- apr_uri_t info;
- struct aup_test *t;
- const char *failed;
- int rc = 0;
-
- for (i = 0; i < sizeof(aup_tests) / sizeof(aup_tests[0]); i++) {
- memset(&info, 0, sizeof(info));
- t = &aup_tests[i];
- rv = apr_uri_parse(p, t->uri, &info);
- failed = (rv != t->rv) ? "bad rc" : NULL;
- if (!failed && t->rv == APR_SUCCESS) {
- if (!same_str(info.scheme, t->scheme))
- failed = "bad scheme";
- if (!same_str(info.hostinfo, t->hostinfo))
- failed = "bad hostinfo";
- if (!same_str(info.user, t->user))
- failed = "bad user";
- if (!same_str(info.password, t->password))
- failed = "bad password";
- if (!same_str(info.hostname, t->hostname))
- failed = "bad hostname";
- if (!same_str(info.port_str, t->port_str))
- failed = "bad port_str";
- if (!same_str(info.path, t->path))
- failed = "bad path";
- if (!same_str(info.query, t->query))
- failed = "bad query";
- if (!same_str(info.fragment, t->fragment))
- failed = "bad fragment";
- if (info.port != t->port)
- failed = "bad port";
- }
- if (failed) {
- ++rc;
- fprintf(stderr, "failure for testcase %d/uri %s: %s\n", i,
- t->uri, failed);
- show_info(rv, t->rv, &info);
- }
- else if (t->rv == APR_SUCCESS) {
- const char *s = apr_uri_unparse(p, &info,
- APR_URI_UNP_REVEALPASSWORD);
-
- if (strcmp(s, t->uri)) {
- fprintf(stderr, "apr_uri_unparsed failed for testcase %d\n", i);
- fprintf(stderr, " got %s, expected %s\n", s, t->uri);
- }
- }
- }
-
- return rc;
-}
-
-static int test_uph(apr_pool_t *p)
-{
- int i;
- apr_status_t rv;
- apr_uri_t info;
- struct uph_test *t;
- const char *failed;
- int rc = 0;
-
- for (i = 0; i < sizeof(uph_tests) / sizeof(uph_tests[0]); i++) {
- memset(&info, 0, sizeof(info));
- t = &uph_tests[i];
- rv = apr_uri_parse_hostinfo(p, t->hostinfo, &info);
- failed = (rv != t->rv) ? "bad rc" : NULL;
- if (!failed && t->rv == APR_SUCCESS) {
- if (!same_str(info.hostname, t->hostname))
- failed = "bad hostname";
- if (!same_str(info.port_str, t->port_str))
- failed = "bad port_str";
- if (info.port != t->port)
- failed = "bad port";
- }
- if (failed) {
- ++rc;
- fprintf(stderr, "failure for testcase %d/hostinfo %s: %s\n", i,
- t->hostinfo, failed);
- show_info(rv, t->rv, &info);
- }
- }
-
- return rc;
-}
-
-int main(void)
-{
- apr_pool_t *pool;
- int rc;
-
- apr_initialize();
- atexit(apr_terminate);
-
- apr_pool_create(&pool, NULL);
-
- rc = test_aup(pool);
-
- if (!rc) {
- rc = test_uph(pool);
- }
-
- return rc;
-}