1 package org.cacert.gigi.pages.account;
3 import static org.hamcrest.CoreMatchers.*;
4 import static org.junit.Assert.*;
6 import java.io.IOException;
7 import java.security.GeneralSecurityException;
8 import java.security.KeyPair;
10 import org.cacert.gigi.GigiApiException;
11 import org.cacert.gigi.dbObjects.Group;
12 import org.cacert.gigi.pages.account.certs.CertificateRequest;
13 import org.cacert.gigi.testUtils.ClientTest;
14 import org.cacert.gigi.util.AuthorizationContext;
15 import org.junit.Test;
17 public class TestCertificateRequest extends ClientTest {
19 KeyPair kp = generateKeypair();
21 AuthorizationContext ac;
23 public TestCertificateRequest() throws GeneralSecurityException, IOException {
24 ac = new AuthorizationContext(u, u);
25 makeAssurer(u.getId());
26 grant(email, Group.CODESIGNING);
31 public void testIssuingOtherName() throws Exception {
33 new CertificateRequest(ac, generatePEMCSR(kp, "CN=hansi")).draft();
35 } catch (GigiApiException e) {
36 assertThat(e.getMessage(), containsString("name you entered was invalid"));
41 public void testIssuingDefault() throws Exception {
42 new CertificateRequest(ac, generatePEMCSR(kp, "CN=" + CertificateRequest.DEFAULT_CN + ",EMAIL=" + email)).draft();
46 public void testIssuingRealName() throws Exception {
47 new CertificateRequest(ac, generatePEMCSR(kp, "CN=a b,EMAIL=" + email)).draft();
51 public void testIssuingModifiedName() throws Exception {
53 new CertificateRequest(ac, generatePEMCSR(kp, "CN=a ab")).draft();
55 } catch (GigiApiException e) {
56 assertThat(e.getMessage(), containsString("name you entered was invalid"));
61 // TODO annotate that this depends on default config
63 public void testCodesignModifiedName() throws Exception {
65 CertificateRequest cr = new CertificateRequest(ac, generatePEMCSR(kp, "CN=a ab"));
66 cr.update("name", "SHA512", "code-a", null, null, "email:" + email, null, null);
67 } catch (GigiApiException e) {
68 assertThat(e.getMessage(), containsString("does not match the details"));