/* * Copyright 2014 Harald Wellmann. * * 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.ops4j.pax.web.itest; import static org.hamcrest.CoreMatchers.is; import static org.junit.Assert.assertThat; import static org.ops4j.pax.exam.CoreOptions.junitBundles; import static org.ops4j.pax.exam.CoreOptions.linkBundle; import static org.ops4j.pax.exam.CoreOptions.options; import static org.ops4j.pax.web.itest.util.TestConfiguration.logbackBundles; import static org.ops4j.pax.web.itest.util.TestConfiguration.paxUndertowBundles; import static org.ops4j.pax.web.itest.util.TestConfiguration.undertowBundles; import static org.ops4j.pax.web.itest.util.WebAssertions.assertResourceContainsString; import static org.ops4j.pax.web.itest.util.WebAssertions.getHttpPort; import java.io.IOException; import java.net.Authenticator; import java.net.PasswordAuthentication; import java.net.URL; import javax.inject.Inject; import javax.servlet.ServletContext; import org.junit.Test; import org.junit.runner.RunWith; import org.ops4j.pax.exam.Configuration; import org.ops4j.pax.exam.Option; import org.ops4j.pax.exam.junit.PaxExam; import org.ops4j.pax.exam.spi.reactors.ExamReactorStrategy; import org.ops4j.pax.exam.spi.reactors.PerClass; @RunWith(PaxExam.class) @ExamReactorStrategy(PerClass.class) public class BasicAuthenticationTest { @Inject private ServletContext servletContext; @Configuration public Option[] config() { return options( linkBundle("pax-web-sample-auth-basic"), linkBundle("pax-web-sample-login"), undertowBundles(), paxUndertowBundles(), logbackBundles(), junitBundles()); } @Test public void shouldPermitAccess() throws Exception { assertThat(servletContext.getContextPath(), is("/basic")); Authenticator.setDefault(new Authenticator() { @Override protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("username", "username".toCharArray()); } }); assertResourceContainsString("basic/hello", "Hello from Pax Web!"); } @Test(expected = IOException.class) public void shouldDenyAccessOnWrongPassword() throws Exception { assertThat(servletContext.getContextPath(), is("/basic")); Authenticator.setDefault(new Authenticator() { @Override protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("username", "bla".toCharArray()); } }); URL url = new URL(String.format("http://localhost:%s/basic/hello", getHttpPort())); url.openStream(); } @Test public void shouldPermitAccessToUnprotectedResource() throws Exception { assertThat(servletContext.getContextPath(), is("/basic")); Authenticator.setDefault(new Authenticator() { @Override protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("username", "wrong".toCharArray()); } }); assertResourceContainsString("basic/plain.txt", "plain text"); } @Test public void shouldPermitUnauthenticatedAccessToUnprotectedResource() throws Exception { assertThat(servletContext.getContextPath(), is("/basic")); Authenticator.setDefault(null); assertResourceContainsString("basic/plain.txt", "plain text"); } }