[OOM cert-service-client] Add validation of email, ip and domain name
[oom/platform/cert-service.git] / certServiceClient / src / test / java / org / onap / oom / certservice / client / certification / CsrFactoryTest.java
1 /*============LICENSE_START=======================================================
2  * oom-certservice-client
3  * ================================================================================
4  * Copyright (C) 2020 Nokia. All rights reserved.
5  * ================================================================================
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  *      http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  * ============LICENSE_END=========================================================
18  */
19
20 package org.onap.oom.certservice.client.certification;
21
22
23 import static org.assertj.core.api.Assertions.assertThat;
24 import static org.mockito.Mockito.mock;
25 import static org.mockito.Mockito.when;
26
27 import java.security.KeyPair;
28 import java.util.List;
29 import org.bouncycastle.asn1.x509.GeneralName;
30 import org.junit.jupiter.api.Test;
31 import org.onap.oom.certservice.client.certification.exception.CsrGenerationException;
32 import org.onap.oom.certservice.client.certification.exception.KeyPairGenerationException;
33 import org.onap.oom.certservice.client.configuration.model.CsrConfiguration;
34 import org.onap.oom.certservice.client.configuration.model.San;
35
36 class CsrFactoryTest {
37
38     CsrConfiguration config = mock(CsrConfiguration.class);
39
40     @Test
41     void createEncodedCsr_shouldSucceedWhenAllFieldsAreSetCorrectly()
42         throws KeyPairGenerationException, CsrGenerationException {
43
44         KeyPair keyPair =
45             new KeyPairFactory(EncryptionAlgorithmConstants.RSA_ENCRYPTION_ALGORITHM,
46                 EncryptionAlgorithmConstants.KEY_SIZE).create();
47         San san1 = new San("onapexample.com", GeneralName.dNSName);
48         San san2 = new San("onapexample.com.pl", GeneralName.dNSName);
49
50         when(config.getCommonName()).thenReturn("onap.org");
51         when(config.getSans()).thenReturn(List.of(san1, san2));
52         when(config.getCountry()).thenReturn("US");
53         when(config.getLocation()).thenReturn("San-Francisco");
54         when(config.getOrganization()).thenReturn("Linux-Foundation");
55         when(config.getOrganizationUnit()).thenReturn("ONAP");
56         when(config.getState()).thenReturn("California");
57
58         assertThat(new CsrFactory(config).createCsrInPem(keyPair)).isNotEmpty();
59     }
60 }
61