/**
* Copyright (c) 2009 - 2012 Red Hat, Inc.
*
* This software is licensed to you under the GNU General Public License,
* version 2 (GPLv2). There is NO WARRANTY for this software, express or
* implied, including the implied warranties of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. You should have received a copy of GPLv2
* along with this software; if not, see
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
*
* Red Hat trademarks are not licensed under GPLv2. No permission is
* granted to use or replicate Red Hat trademarks that are incorporated
* in this software or its documentation.
*/
package org.candlepin.auth;
import static org.junit.Assert.*;
import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.*;
import org.candlepin.model.Consumer;
import org.candlepin.model.ConsumerCurator;
import org.candlepin.model.ConsumerType;
import org.candlepin.model.ConsumerType.ConsumerTypeEnum;
import org.candlepin.model.DeletedConsumerCurator;
import org.candlepin.model.Owner;
import org.jboss.resteasy.spi.HttpRequest;
import org.junit.Before;
import org.junit.Test;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.xnap.commons.i18n.I18n;
import java.security.cert.X509Certificate;
import javax.inject.Provider;
import javax.security.auth.x500.X500Principal;
public class SSLAuthTest {
@Mock private HttpRequest httpRequest;
@Mock private ConsumerCurator consumerCurator;
@Mock private DeletedConsumerCurator deletedConsumerCurator;
@Mock private Provider<I18n> i18nProvider;
private SSLAuth auth;
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
this.auth = new SSLAuth(this.consumerCurator, this.deletedConsumerCurator, i18nProvider);
}
/**
* No cert
*
* @throws Exception
*/
@Test
public void noCert() throws Exception {
assertNull(this.auth.getPrincipal(httpRequest));
}
/**
* Happy path - parses the username from the cert's DN correctly.
*
* @throws Exception
*/
@Test
public void correctUserName() throws Exception {
Owner owner = new Owner("test owner");
Consumer consumer = new Consumer("machine_name", "test user", owner,
new ConsumerType(ConsumerTypeEnum.SYSTEM));
ConsumerPrincipal expected = new ConsumerPrincipal(consumer);
String dn = "CN=453-44423-235";
mockCert(dn);
when(this.consumerCurator.getConsumer("453-44423-235")).thenReturn(consumer);
assertEquals(expected, this.auth.getPrincipal(httpRequest));
}
/**
* DN is set but does not contain UID
*
* @throws Exception
*/
@Test
public void noUuidOnCert() throws Exception {
mockCert("OU=something");
when(this.consumerCurator.findByUuid(anyString())).thenReturn(
new Consumer("machine_name", "test user", null, null));
assertNull(this.auth.getPrincipal(httpRequest));
}
/**
* Uuid in the cert is not found by the curator.
*
* @throws Exception
*/
@Test
public void noValidConsumerEntity() throws Exception {
mockCert("CN=235-8");
when(this.consumerCurator.findByUuid("235-8")).thenReturn(null);
assertNull(this.auth.getPrincipal(httpRequest));
}
private void mockCert(String dn) {
X509Certificate idCert = mock(X509Certificate.class);
X500Principal principal = new X500Principal(dn);
when(idCert.getSubjectX500Principal()).thenReturn(principal);
when(this.httpRequest.getAttribute("javax.servlet.request.X509Certificate"))
.thenReturn(new X509Certificate[]{idCert});
}
}