1 /*
2 * $Header: /home/cvs/jakarta-commons/httpclient/src/test/org/apache/commons/httpclient/TestHttpUrlMethod.java,v 1.5 2003/01/23 22:48:27 jsdever Exp $
3 * $Revision: 1.5 $
4 * $Date: 2003/01/23 22:48:27 $
5 * ====================================================================
6 *
7 * The Apache Software License, Version 1.1
8 *
9 * Copyright (c) 1999-2003 The Apache Software Foundation. All rights
10 * reserved.
11 *
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
14 * are met:
15 *
16 * 1. Redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer.
18 *
19 * 2. Redistributions in binary form must reproduce the above copyright
20 * notice, this list of conditions and the following disclaimer in
21 * the documentation and/or other materials provided with the
22 * distribution.
23 *
24 * 3. The end-user documentation included with the redistribution, if
25 * any, must include the following acknowlegement:
26 * "This product includes software developed by the
27 * Apache Software Foundation (http://www.apache.org/)."
28 * Alternately, this acknowlegement may appear in the software itself,
29 * if and wherever such third-party acknowlegements normally appear.
30 *
31 * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
32 * Foundation" must not be used to endorse or promote products derived
33 * from this software without prior written permission. For written
34 * permission, please contact apache@apache.org.
35 *
36 * 5. Products derived from this software may not be called "Apache"
37 * nor may "Apache" appear in their names without prior written
38 * permission of the Apache Group.
39 *
40 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
41 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
42 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
43 * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
44 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
45 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
46 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
47 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
48 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
49 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
50 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51 * SUCH DAMAGE.
52 * ====================================================================
53 *
54 * This software consists of voluntary contributions made by many
55 * individuals on behalf of the Apache Software Foundation. For more
56 * information on the Apache Software Foundation, please see
57 * <http://www.apache.org/>.
58 *
59 * [Additional notices, if required by prior licensing conditions]
60 *
61 */
62
63 package org.apache.commons.httpclient;
64
65 import junit.framework.Test;
66 import junit.framework.TestCase;
67 import junit.framework.TestSuite;
68
69 import org.apache.commons.httpclient.methods.GetMethod;
70
71 /***
72 *
73 * Unit tests for {@link org.apache.commons.httpclient.HttpMethod}
74 * constructors that take URLs. These tests do not require any network
75 * connection or web app.
76 *
77 * @author Marc A. Saegesser
78 * @version $Id: TestHttpUrlMethod.java,v 1.5 2003/01/23 22:48:27 jsdever Exp $
79 */
80 public class TestHttpUrlMethod extends TestCase {
81
82 // ------------------------------------------------------------ Constructor
83 public TestHttpUrlMethod(String testName) {
84 super(testName);
85 }
86
87 // ------------------------------------------------------------------- Main
88 public static void main(String args[]) {
89 String[] testCaseName = { TestHttpUrlMethod.class.getName() };
90 junit.textui.TestRunner.main(testCaseName);
91 }
92
93 // ------------------------------------------------------- TestCase Methods
94
95 public static Test suite() {
96 return new TestSuite(TestHttpUrlMethod.class);
97 }
98
99
100 // ----------------------------------------------------------- Test Methods
101
102 // Test constructors
103
104 public void testUrlGetMethodWithPathQuery() {
105 GetMethod method = new GetMethod("http://www.fubar.com/path1/path2?query=string");
106 try {
107 assertEquals(
108 "Get URL",
109 "http://www.fubar.com/path1/path2?query=string",
110 method.getURI().toString()
111 );
112 } catch ( URIException e ) {
113 fail( "trouble getting URI: " + e );
114 }
115 assertEquals("Get Path", "/path1/path2", method.getPath());
116 assertEquals("Get query string", "query=string", method.getQueryString());
117
118 }
119
120 public void testUrlGetMethodWithPath() {
121 GetMethod method = new GetMethod("http://www.fubar.com/path1/path2");
122 try {
123 assertEquals(
124 "Get URL",
125 "http://www.fubar.com/path1/path2",
126 method.getURI().toString()
127 );
128 } catch ( URIException e ) {
129 fail( "trouble getting URI: " + e );
130 }
131 assertEquals("Get Path", "/path1/path2", method.getPath());
132 assertEquals("Get query string", null, method.getQueryString());
133
134 }
135
136 public void testUrlGetMethod() {
137 GetMethod method = new GetMethod("http://www.fubar.com/");
138 try {
139 assertEquals(
140 "Get URL",
141 "http://www.fubar.com/",
142 method.getURI().toString()
143 );
144 } catch ( URIException e ) {
145 fail( "trouble getting URI: " + e );
146 }
147 assertEquals("Get Path", "/", method.getPath());
148 assertEquals("Get query string", null, method.getQueryString());
149
150 }
151
152
153 public void testUrlGetMethodWithInvalidProtocol() {
154 try
155 {
156 GetMethod method = new GetMethod("crap://www.fubar.com/");
157 fail("The use of invalid protocol must have resulted in an IllegalStateException");
158 }
159 catch(IllegalStateException e)
160 {
161 //expected exception
162 }
163 }
164 }
This page was automatically generated by Maven