org.commonjava.indy.httprox.ProxyHttpsTest.java Source code

Java tutorial

Introduction

Here is the source code for org.commonjava.indy.httprox.ProxyHttpsTest.java

Source

/**
 * Copyright (C) 2011-2018 Red Hat, Inc. (https://github.com/Commonjava/indy)
 *
 * 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.commonjava.indy.httprox;

import org.apache.commons.io.IOUtils;
import org.apache.http.StatusLine;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.conn.ssl.SSLSocketFactory;
import org.apache.http.impl.client.CloseableHttpClient;
import org.commonjava.indy.client.core.helper.HttpResources;
import org.commonjava.indy.model.core.RemoteRepository;
import org.commonjava.indy.model.core.dto.StoreListingDTO;
import org.commonjava.indy.test.fixture.core.CoreServerFixture;
import org.junit.Test;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.security.KeyStore;

import static org.commonjava.indy.model.core.GenericPackageTypeDescriptor.GENERIC_PKG_KEY;
import static org.hamcrest.CoreMatchers.notNullValue;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;

public class ProxyHttpsTest extends AbstractHttproxFunctionalTest {

    private static final String USER = "user";

    private static final String PASS = "password";

    private static final String content = "This is a test";

    String https_url = "https://oss.sonatype.org/content/repositories/releases/org/commonjava/indy/indy-api/1.3.1/indy-api-1.3.1.pom";

    @Test
    public void run() throws Exception {
        String ret = null;
        ret = regression();
        assertEquals(content, ret);

        ret = get(https_url, true, USER, PASS);
        assertTrue(ret.contains("<artifactId>indy-api</artifactId>"));

        StoreListingDTO<RemoteRepository> repo = this.client.stores()
                .getRemoteByUrl("https://oss.sonatype.org:443/", GENERIC_PKG_KEY);
        repo.getItems().forEach(repository -> System.out.println(">>> " + repository));
        assertTrue(repo.getItems().size() == 1);
    }

    // Regression test for HTTP url
    private String regression() throws Exception {
        final String path = "org/foo/bar/1.0/bar-1.0.nocache";
        final String testRepo = "test";
        String url = server.formatUrl(testRepo, path);
        server.expect(url, 200, content);
        return get(url, false, USER, PASS);
    }

    protected String get(String url, boolean withCACert, String user, String pass) throws Exception {
        CloseableHttpClient client;

        if (withCACert) {
            File jks = new File(etcDir, "ssl/ca.jks");
            KeyStore trustStore = getTrustStore(jks);
            SSLSocketFactory socketFactory = new SSLSocketFactory(trustStore);
            client = proxiedHttp(user, pass, socketFactory);
        } else {
            client = proxiedHttp(user, pass);
        }

        HttpGet get = new HttpGet(url);
        CloseableHttpResponse response = null;

        InputStream stream = null;
        try {
            response = client.execute(get, proxyContext(user, pass));
            StatusLine status = response.getStatusLine();
            System.out.println("status >>>> " + status);

            if (status.getStatusCode() == 404) {
                return status.toString();
            }

            stream = response.getEntity().getContent();
            final String resulting = IOUtils.toString(stream);

            assertThat(resulting, notNullValue());
            System.out.println("\n\n>>>>>>>\n\n" + resulting + "\n\n");

            return resulting;
        } finally {
            IOUtils.closeQuietly(stream);
            HttpResources.cleanupResources(get, response, client);
        }
    }

    protected KeyStore getTrustStore(File jks) throws Exception {
        KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
        try (FileInputStream instream = new FileInputStream(jks)) {
            trustStore.load(instream, "passwd".toCharArray());
        }
        return trustStore;
    }

    @Override
    protected int getTestTimeoutMultiplier() {
        return 1;
    }

    @Override
    protected String getAdditionalHttproxConfig() {
        return "MITM.enabled=true\nMITM.ca.key=${indy.home}/etc/indy/ssl/ca.der\n"
                + "MITM.ca.cert=${indy.home}/etc/indy/ssl/ca.crt\n" + "MITM.dn.template=CN=<host>, O=Test Org";
    }

    @Override
    protected void initTestData(CoreServerFixture fixture) throws IOException {
        copyToConfigFile("ssl/ca.der", "ssl/ca.der");
        copyToConfigFile("ssl/ca.crt", "ssl/ca.crt");
        copyToConfigFile("ssl/ca.jks", "ssl/ca.jks");
    }
}