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