1 /*============LICENSE_START=======================================================
2 * oom-truststore-merger
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
10 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
20 package org.onap.oom.truststoremerger.certification.file.model;
22 import static org.assertj.core.api.Assertions.assertThat;
23 import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
24 import static org.mockito.Mockito.mock;
25 import static org.mockito.Mockito.when;
26 import static org.onap.oom.truststoremerger.api.CertificateConstants.X_509_CERTIFICATE;
28 import java.io.IOException;
29 import java.security.cert.Certificate;
30 import java.security.cert.CertificateEncodingException;
31 import java.util.ArrayList;
32 import java.util.List;
33 import org.junit.jupiter.api.AfterAll;
34 import org.junit.jupiter.api.Test;
35 import org.onap.oom.truststoremerger.api.ExitableException;
36 import org.onap.oom.truststoremerger.certification.file.provider.entry.CertificateWithAlias;
37 import org.onap.oom.truststoremerger.certification.file.provider.entry.CertificateWithAliasFactory;
38 import org.onap.oom.truststoremerger.certification.file.TestCertificateProvider;
39 import org.onap.oom.truststoremerger.certification.file.exception.MissingTruststoreException;
40 import org.onap.oom.truststoremerger.certification.file.exception.TruststoreDataOperationException;
41 import org.onap.oom.truststoremerger.certification.file.exception.WriteTruststoreFileException;
43 class PemTruststoreTest {
45 public static final int EXPECTED_ONE = 1;
46 public static final int EXPECTED_THREE = 3;
47 public static final int FIRST_ELEMENT = 0;
49 private final CertificateWithAliasFactory factory = new CertificateWithAliasFactory();
52 void pemTruststoreShouldReadCertificatesFromFile() throws ExitableException {
55 PemTruststore pemTruststore = TestCertificateProvider.getSamplePemTruststoreFile();
58 List<CertificateWithAlias> certificates = pemTruststore.getCertificates();
59 Certificate certificate = certificates.get(FIRST_ELEMENT).getCertificate();
62 assertThat(certificates).hasSize(EXPECTED_ONE);
63 assertThat(certificate.getType()).isEqualTo(X_509_CERTIFICATE);
67 void pemTruststoreShouldAddDifferentCertificates() throws IOException, ExitableException {
70 PemTruststore tmpPemTruststoreFile = TestCertificateProvider.createTmpPemTruststoreFile();
71 List<CertificateWithAlias> jksTruststoreCertificates = TestCertificateProvider
72 .getSampleJksTruststoreFileWithUniqueAlias().getCertificates();
73 List<CertificateWithAlias> p12TruststoreCertificates = TestCertificateProvider.getSampleP12Truststore()
77 tmpPemTruststoreFile.addCertificate(jksTruststoreCertificates);
78 tmpPemTruststoreFile.addCertificate(p12TruststoreCertificates);
79 tmpPemTruststoreFile.saveFile();
81 PemTruststore tmpPemTruststoreSaved = TestCertificateProvider.getTmpPemTruststoreFile();
82 List<CertificateWithAlias> addedCertificates = tmpPemTruststoreSaved.getCertificates();
83 Certificate certificate = addedCertificates.get(FIRST_ELEMENT).getCertificate();
86 assertThat(addedCertificates).hasSize(EXPECTED_THREE);
87 assertThat(certificate.getType()).isEqualTo(X_509_CERTIFICATE);
92 void privateKeyIsSkippedWhileReadingCertificates() throws ExitableException {
94 PemTruststore pemTruststore = TestCertificateProvider.getPemWithPrivateKeyTruststoreFile();
97 List<CertificateWithAlias> certificate = pemTruststore.getCertificates();
100 assertThat(certificate).hasSize(EXPECTED_ONE);
104 void shouldThrowExceptionWhenCannotSaveFile() throws IOException, ExitableException {
106 PemTruststore tmpPemTruststoreFile = TestCertificateProvider.createTmpPemTruststoreFile();
107 List<CertificateWithAlias> pemTruststoreCertificates =
108 TestCertificateProvider.getSamplePemTruststoreFile().getCertificates();
110 tmpPemTruststoreFile.addCertificate(pemTruststoreCertificates);
111 tmpPemTruststoreFile.getFile().setWritable(false);
113 assertThatExceptionOfType(WriteTruststoreFileException.class)
114 .isThrownBy(tmpPemTruststoreFile::saveFile);
119 void shouldThrowExceptionWhenFileNotContainsCertificate() throws IOException {
121 PemTruststore tmpPemTruststoreFile = TestCertificateProvider.createEmptyTmpPemTruststoreFile();
123 assertThatExceptionOfType(MissingTruststoreException.class)
124 .isThrownBy(tmpPemTruststoreFile::getCertificates);
128 void shouldThrowExceptionWhenCannotConvertCertificateToPem() throws Exception {
130 PemTruststore pemTruststore = TestCertificateProvider.createTmpPemTruststoreFile();
131 Certificate certificate = mock(Certificate.class);
133 when(certificate.getEncoded()).thenThrow(new CertificateEncodingException());
135 List<CertificateWithAlias> certificatesWithAliases = new ArrayList<>();
136 certificatesWithAliases.add(factory.createPemCertificate(certificate));
137 pemTruststore.addCertificate(certificatesWithAliases);
140 assertThatExceptionOfType(TruststoreDataOperationException.class)
141 .isThrownBy(pemTruststore::saveFile);
145 static void removeTemporaryFiles() throws IOException {
146 TestCertificateProvider.removeTemporaryFiles();