You are viewing a plain text version of this content. The canonical link for it is here.
Posted to jetspeed-dev@portals.apache.org by ta...@apache.org on 2004/12/02 04:15:27 UTC
cvs commit: jakarta-jetspeed-2/components/sso/src/test/org/apache/jetspeed/sso TestBasicSSO.java
taylor 2004/12/01 19:15:27
Added: components/sso/src/test/org/apache/jetspeed/sso
TestBasicSSO.java
Log:
test basic authentication (this test should be skipped)
Revision Changes Path
1.1 jakarta-jetspeed-2/components/sso/src/test/org/apache/jetspeed/sso/TestBasicSSO.java
Index: TestBasicSSO.java
===================================================================
/*
* Copyright 2000-2004 The Apache Software Foundation.
*
* 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.
*/
package org.apache.jetspeed.sso;
import java.io.InputStream;
import org.apache.commons.httpclient.Cookie;
import org.apache.commons.httpclient.Header;
import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpConnection;
import org.apache.commons.httpclient.HttpState;
import org.apache.commons.httpclient.UsernamePasswordCredentials;
import org.apache.commons.httpclient.auth.AuthScheme;
import org.apache.commons.httpclient.auth.HttpAuthenticator;
import org.apache.commons.httpclient.cookie.CookiePolicy;
import org.apache.commons.httpclient.methods.GetMethod;
import org.apache.commons.httpclient.methods.MultipartPostMethod;
import junit.framework.Test;
import junit.framework.TestCase;
import junit.framework.TestSuite;
/**
* TestBasicSSO
*
* @author <a href="mailto:taylor@apache.org">David Sean Taylor</a>
* @version $Id: TestBasicSSO.java,v 1.1 2004/12/02 03:15:27 taylor Exp $
*/
public class TestBasicSSO extends TestCase
{
public static Test suite()
{
return new TestSuite(TestBasicSSO.class);
}
public void testBasicSSO() throws Exception
{
System.out.println("Testing SSO");
connect("http://localhost:8080/demo/sso-basic", "tomcat", "tomcat");
}
public void connect(String server, String username, String password) throws Exception
{
HttpClient client = new HttpClient();
UsernamePasswordCredentials credentials = new UsernamePasswordCredentials(username, password);
StringBuffer authenticationHeader = new StringBuffer("BASIC");
authenticationHeader.append(" realm=\"");
authenticationHeader.append("jetspeed");
authenticationHeader.append("\"");
Header[] headers = { new Header("WWW-Authenticate", authenticationHeader.toString())};
AuthScheme scheme = null;
client.getState().setCredentials(null, null, credentials);
GetMethod get = new GetMethod(server);
// post = new MultipartPostMethod(server);
get.setDoAuthentication(true);
try
{
scheme = HttpAuthenticator.selectAuthScheme(headers);
HttpConnection conn = client.getHttpConnectionManager().getConnection(get.getHostConfiguration());
boolean authenticated = HttpAuthenticator.authenticate(scheme, get, conn, client.getState());
if (!authenticated)
{
throw new Exception("Failed to create authentication headers to HTTP Connection");
}
int status = client.executeMethod(get);
System.out.println("response = [" + get.getResponseBodyAsString() + "]");
Cookie[] cookies = client.getState().getCookies();
Cookie mycookie = null;
// Display the cookies
System.out.println("Present cookies: ");
for (int i = 0; i < cookies.length; i++)
{
System.out.println(" - " + cookies[i].toExternalForm());
mycookie = cookies[i];
}
// get.releaseConnection();
// client.endSession();
HttpState initialState = new HttpState();
initialState.addCookie(mycookie);
// client.getParams().setCookiePolicy(CookiePolicy.RFC_2109);
client = new HttpClient();
client.setState(initialState);
get = new GetMethod(server);
status = client.executeMethod(get);
System.out.println("response = [" + get.getResponseBodyAsString() + "]");
cookies = client.getState().getCookies();
// Display the cookies
System.out.println("Present cookies: ");
for (int i = 0; i < cookies.length; i++)
{
System.out.println(" - " + cookies[i].toExternalForm());
}
get.releaseConnection();
}
catch (Throwable t)
{
throw new Exception("Unexpected exception in creating HTTP authentication headers", t);
}
}
}
---------------------------------------------------------------------
To unsubscribe, e-mail: jetspeed-dev-unsubscribe@jakarta.apache.org
For additional commands, e-mail: jetspeed-dev-help@jakarta.apache.org