org.obm.sync.push.client.SSLContextFactoryTest.java Source code

Java tutorial

Introduction

Here is the source code for org.obm.sync.push.client.SSLContextFactoryTest.java

Source

/* ***** BEGIN LICENSE BLOCK *****
 * 
 * Copyright (C) 2013-2014 Linagora
 *
 * This program is free software: you can redistribute it and/or 
 * modify it under the terms of the GNU Affero General Public License as 
 * published by the Free Software Foundation, either version 3 of the 
 * License, or (at your option) any later version, provided you comply 
 * with the Additional Terms applicable for OBM connector by Linagora 
 * pursuant to Section 7 of the GNU Affero General Public License, 
 * subsections (b), (c), and (e), pursuant to which you must notably (i) retain 
 * the Message sent thanks to OBM, Free Communication by Linagora? 
 * signature notice appended to any and all outbound messages 
 * (notably e-mail and meeting requests), (ii) retain all hypertext links between 
 * OBM and obm.org, as well as between Linagora and linagora.com, and (iii) refrain 
 * from infringing Linagora intellectual property rights over its trademarks 
 * and commercial brands. Other Additional Terms apply, 
 * see <http://www.linagora.com/licenses/> for more details. 
 *
 * This program is distributed in the hope that it will be useful, 
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License 
 * for more details. 
 *
 * You should have received a copy of the GNU Affero General Public License 
 * and its applicable Additional Terms for OBM along with this program. If not, 
 * see <http://www.gnu.org/licenses/> for the GNU Affero General Public License version 3 
 * and <http://www.linagora.com/licenses/> for the Additional Terms applicable to 
 * OBM connectors. 
 * 
 * ***** END LICENSE BLOCK ***** */
package org.obm.sync.push.client;

import static org.assertj.core.api.Assertions.assertThat;

import java.io.ByteArrayInputStream;
import java.io.EOFException;
import java.io.InputStream;
import java.security.KeyStore;
import java.security.cert.Certificate;
import java.security.cert.CertificateFactory;

import javax.net.ssl.SSLContext;

import org.apache.commons.io.IOUtils;
import org.junit.Test;

public class SSLContextFactoryTest {

    @Test(expected = IllegalArgumentException.class)
    public void testRequirePKCS12() {
        SSLContextFactory.create(null, "password".toCharArray());
    }

    @Test(expected = IllegalArgumentException.class)
    public void testRequirePKCS12Password() {
        SSLContextFactory.create(new ByteArrayInputStream("test".getBytes()), null);
    }

    @Test(expected = EOFException.class)
    public void testKeyStoreFailsIfNotPKCS12() throws Throwable {
        InputStream pkcs12Stream = IOUtils.toInputStream("I'm not a pkcs12 key store");
        char[] pkcs12Password = "toto".toCharArray();

        try {
            SSLContextFactory.create(pkcs12Stream, pkcs12Password);
        } catch (RuntimeException e) {
            assertThat(e.getCause()).isNotNull();
            throw e.getCause();
        }
    }

    @Test
    public void testKeyStoreIsPKCS12() throws Exception {
        InputStream pkcs12Stream = ClassLoader.getSystemClassLoader().getResourceAsStream("pkcs_pwd_toto.p12");
        char[] pkcs12Password = "toto".toCharArray();

        KeyStore keyStore = SSLContextFactory.loadPKCS12KeyStore(pkcs12Stream, pkcs12Password);

        InputStream pkcs12InnerX509 = ClassLoader.getSystemClassLoader().getResourceAsStream("pkcs_inner_x509.crt");
        Certificate pkcs12InnerCertificate = CertificateFactory.getInstance("x509")
                .generateCertificate(pkcs12InnerX509);
        assertThat(keyStore.getType()).isEqualToIgnoringCase("pkcs12");
        assertThat(keyStore.getCertificate("client2")).isEqualTo(pkcs12InnerCertificate);
    }

    @Test
    public void testCorrectSSLContextFactoryCall() {
        InputStream pkcs12Stream = ClassLoader.getSystemClassLoader().getResourceAsStream("pkcs_pwd_toto.p12");
        char[] pkcs12Password = "toto".toCharArray();

        SSLContext sslContext = SSLContextFactory.create(pkcs12Stream, pkcs12Password);

        assertThat(sslContext).isNotNull();
    }
}