/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright (c) 2015-2017 Oracle and/or its affiliates. All rights reserved. * * The contents of this file are subject to the terms of either the GNU * General Public License Version 2 only ("GPL") or the Common Development * and Distribution License("CDDL") (collectively, the "License"). You * may not use this file except in compliance with the License. You can * obtain a copy of the License at * http://glassfish.java.net/public/CDDL+GPL_1_1.html * or packager/legal/LICENSE.txt. See the License for the specific * language governing permissions and limitations under the License. * * When distributing the software, include this License Header Notice in each * file and include the License file at packager/legal/LICENSE.txt. * * GPL Classpath Exception: * Oracle designates this particular file as subject to the "Classpath" * exception as provided by Oracle in the GPL Version 2 section of the License * file that accompanied this code. * * Modifications: * If applicable, add the following below the License Header, with the fields * enclosed by brackets [] replaced by your own identifying information: * "Portions Copyright [year] [name of copyright owner]" * * Contributor(s): * If you wish your version of this file to be governed by only the CDDL or * only the GPL Version 2, indicate your decision by adding "[Contributor] * elects to include this software in this distribution under the [CDDL or GPL * Version 2] license." If you don't indicate a single choice of license, a * recipient has the option to distribute your version of this file under * either the CDDL, the GPL Version 2 or to extend the choice of license to * its licensees as provided above. However, if you add GPL Version 2 code * and therefore, elected the GPL Version 2 license, then the option applies * only if the new code is made subject to such option by the copyright * holder. */ package org.glassfish.jersey.tests.e2e.client.connector.ssl; import java.io.IOException; import java.io.InputStream; import java.util.Arrays; import javax.net.ssl.SSLContext; import org.glassfish.jersey.SslConfigurator; import org.glassfish.jersey.apache.connector.ApacheConnectorProvider; import org.glassfish.jersey.client.HttpUrlConnectorProvider; import org.glassfish.jersey.client.spi.ConnectorProvider; import org.glassfish.jersey.grizzly.connector.GrizzlyConnectorProvider; import org.glassfish.jersey.jetty.connector.JettyConnectorProvider; import org.junit.After; import org.junit.Before; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import com.google.common.io.ByteStreams; /** * SSL connector hostname verification tests. * * @author Petr Bouda (petr.bouda at oracle.com) */ @RunWith(Parameterized.class) public abstract class AbstractConnectorServerTest { // Default truststore and keystore private static final String CLIENT_TRUST_STORE = "truststore-localhost-client"; private static final String SERVER_KEY_STORE = "keystore-localhost-server"; private static final String CLIENT_KEY_STORE = "keystore-client"; /** * Test parameters provider. * * @return test parameters. */ @Parameterized.Parameters(name = "{index}: {0}") public static Iterable<Object[]> testData() { return Arrays.asList(new Object[][] { {new HttpUrlConnectorProvider()}, {new GrizzlyConnectorProvider()}, {new JettyConnectorProvider()}, {new ApacheConnectorProvider()} }); } @Parameterized.Parameter(0) public ConnectorProvider connectorProvider; private final Object serverGuard = new Object(); private Server server = null; @Before public void setUp() throws Exception { synchronized (serverGuard) { if (server != null) { throw new IllegalStateException( "Test run sync issue: Another instance of the SSL-secured HTTP test server has been already started."); } server = Server.start(serverKeyStore()); } } @After public void tearDown() throws Exception { synchronized (serverGuard) { if (server == null) { throw new IllegalStateException("Test run sync issue: There is no SSL-secured HTTP test server to stop."); } server.stop(); server = null; } } protected SSLContext getSslContext() throws IOException { final InputStream trustStore = SslConnectorConfigurationTest.class.getResourceAsStream(clientTrustStore()); final InputStream keyStore = SslConnectorConfigurationTest.class.getResourceAsStream(CLIENT_KEY_STORE); return SslConfigurator.newInstance() .trustStoreBytes(ByteStreams.toByteArray(trustStore)) .trustStorePassword("asdfgh") .keyStoreBytes(ByteStreams.toByteArray(keyStore)) .keyPassword("asdfgh") .createSSLContext(); } protected String serverKeyStore() { return SERVER_KEY_STORE; } protected String clientTrustStore() { return CLIENT_TRUST_STORE; } }