blob: cd95f2c21420ac22a30a6b47f5cdc1c26de04e27 [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
* <p>
* http://www.apache.org/licenses/LICENSE-2.0
* <p>
* 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.manifoldcf.agents.output.solr.tests;
import org.apache.http.HttpException;
import org.apache.http.HttpRequest;
import org.apache.http.HttpRequestInterceptor;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.AuthState;
import org.apache.http.auth.Credentials;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.protocol.HttpClientContext;
import org.apache.http.impl.auth.BasicScheme;
import org.apache.http.message.BasicHttpRequest;
import org.apache.http.protocol.HttpContext;
import org.apache.manifoldcf.agents.output.solr.PreemptiveBasicAuthInterceptor;
import org.junit.Test;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
public class PreemptiveBasicAuthInterceptorTest {
@Test
public void shouldAddBasicAuthenticationToRequestIfNotAlreadySet() throws Exception {
final HttpRequestInterceptor interceptor = new PreemptiveBasicAuthInterceptor(AuthScope.ANY);
final HttpContext context = contextWithoutBasicAuth(new UsernamePasswordCredentials("user", "secret"));
interceptor.process(get(), context);
final AuthState authState = (AuthState) context.getAttribute(HttpClientContext.TARGET_AUTH_STATE);
assertTrue(authState.getAuthScheme() instanceof BasicScheme);
assertEquals("user", authState.getCredentials().getUserPrincipal().getName());
assertEquals("secret", authState.getCredentials().getPassword());
}
@Test
public void shouldThrowHttpExceptionIfNoCredentialsWereProvided() {
final HttpRequestInterceptor interceptor = new PreemptiveBasicAuthInterceptor(AuthScope.ANY);
final HttpContext context = contextWithoutBasicAuth(null);
try {
interceptor.process(get(), context);
fail("Expected an HttpException, but none was raised.");
} catch (HttpException e) {
assertEquals("Missing credentials for preemptive basic authentication.", e.getMessage());
} catch (IOException e) {
fail("Expected an HttpException, but an IOException was raised instead.");
}
}
private HttpRequest get() {
return new BasicHttpRequest("GET", "https://manifoldcf.apache.org/");
}
private HttpContext contextWithoutBasicAuth(final Credentials credentials) {
final CredentialsProvider credentialsProvider = new FakeCredentialsProvider();
credentialsProvider.setCredentials(AuthScope.ANY, credentials);
final AuthState authState = new AuthState();
final HttpContext context = new FakeHttpContext();
context.setAttribute(HttpClientContext.CREDS_PROVIDER, credentialsProvider);
context.setAttribute(HttpClientContext.TARGET_AUTH_STATE, authState);
return context;
}
static class FakeHttpContext implements HttpContext {
private final Map<String, Object> context = new HashMap<>();
@Override
public Object getAttribute(final String id) {
return context.get(id);
}
@Override
public void setAttribute(final String id, final Object obj) {
context.put(id, obj);
}
@Override
public Object removeAttribute(final String id) {
return context.remove(id);
}
}
static class FakeCredentialsProvider implements CredentialsProvider {
private final Map<AuthScope, Credentials> credentialsByAuthScope = new HashMap<>();
@Override
public void setCredentials(final AuthScope authScope, final Credentials credentials) {
credentialsByAuthScope.put(authScope, credentials);
}
@Override
public Credentials getCredentials(final AuthScope authScope) {
return credentialsByAuthScope.get(authScope);
}
@Override
public void clear() {
credentialsByAuthScope.clear();
}
}
}