org.qi4j.library.http.MutualSecureJettyServiceTest.java Source code

Java tutorial

Introduction

Here is the source code for org.qi4j.library.http.MutualSecureJettyServiceTest.java

Source

/*
 * Copyright (c) 2011, Paul Merlin. All Rights Reserved.
 *
 * 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.qi4j.library.http;

import java.io.IOException;

import static org.junit.Assert.assertEquals;
import org.junit.Test;

import org.qi4j.bootstrap.AssemblyException;
import org.qi4j.bootstrap.ModuleAssembly;
import static org.qi4j.library.http.Servlets.addServlets;
import static org.qi4j.library.http.Servlets.serve;

import org.apache.http.client.methods.HttpGet;
import org.qi4j.test.EntityTestAssembler;

public class MutualSecureJettyServiceTest extends AbstractSecureJettyTest {

    public void assemble(ModuleAssembly module) throws AssemblyException {
        new EntityTestAssembler().assemble(module);
        new SecureJettyServiceAssembler().assemble(module);
        // START SNIPPET: config
        SecureJettyConfiguration config = module.forMixin(SecureJettyConfiguration.class).declareDefaults();
        config.hostName().set("127.0.0.1");
        config.port().set(HTTPS_PORT);

        config.keystorePath().set(SERVER_KEYSTORE_PATH);
        config.keystoreType().set("JCEKS");
        config.keystorePassword().set(KS_PASSWORD);

        config.truststorePath().set(TRUSTSTORE_PATH);
        config.truststoreType().set("JCEKS");
        config.truststorePassword().set(KS_PASSWORD);

        config.wantClientAuth().set(Boolean.TRUE);
        // END SNIPPET: config

        addServlets(serve("/hello").with(HelloWorldServletService.class)).to(module);
    }

    @Test
    public void testWithoutClientCertificate() throws IOException {
        // As we set wantClientAuth we can request without a client certificate ...
        String output = trustHttpClient.execute(new HttpGet("https://127.0.0.1:8441/hello"), stringResponseHandler);
        assertEquals("Hello World", output);
    }

    @Test
    public void testWithClientCertificate() throws IOException {
        // ... and with one
        String output = mutualHttpClient.execute(new HttpGet("https://127.0.0.1:8441/hello"),
                stringResponseHandler);
        assertEquals("Hello Mutual World", output);
    }

}