d47cb52dd20601afa22d58ffe04da0cd3a4caff0
[policy/distribution.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2018 Intel. All rights reserved.
4  *  Copyright (C) 2019 Nordix Foundation.
5  *  Modifications Copyright (C) 2020-2021 AT&T Intellectual Property. All rights reserved.
6  *  Modifications Copyright (C) 2020 Nordix Foundation
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *      http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  *
20  * SPDX-License-Identifier: Apache-2.0
21  * ============LICENSE_END=========================================================
22  */
23
24 package org.onap.policy.distribution.main.rest;
25
26 import static org.assertj.core.api.Assertions.assertThatCode;
27 import static org.junit.Assert.assertEquals;
28
29 import java.io.IOException;
30 import java.security.SecureRandom;
31 import java.util.Properties;
32 import javax.net.ssl.SSLContext;
33 import javax.net.ssl.TrustManager;
34 import javax.ws.rs.client.Client;
35 import javax.ws.rs.client.ClientBuilder;
36 import javax.ws.rs.client.Invocation;
37 import javax.ws.rs.client.WebTarget;
38 import javax.ws.rs.core.MediaType;
39 import org.glassfish.jersey.client.authentication.HttpAuthenticationFeature;
40 import org.junit.Before;
41 import org.junit.Test;
42 import org.onap.policy.common.parameters.ParameterService;
43 import org.onap.policy.common.utils.network.NetworkUtil;
44 import org.onap.policy.common.utils.security.SelfSignedKeyStore;
45 import org.onap.policy.distribution.main.PolicyDistributionException;
46 import org.onap.policy.distribution.main.parameters.CommonTestData;
47 import org.onap.policy.distribution.main.startstop.Main;
48
49 /**
50  * Class to perform unit test of HealthCheckMonitor.
51  *
52  * @author Libo Zhu (libo.zhu@intel.com)
53  */
54 public class TestHttpsStatisticDistributionRestServer {
55
56     private int port;
57
58     @Before
59     public void setUp() {
60         ParameterService.clear();
61     }
62
63     @Test
64     public void testHttpsDistributionStatistic() {
65         assertThatCode(() -> {
66             final Main main = startDistributionService();
67             final StatisticsReport report = performStatisticCheck();
68             validateReport(200, 0, 0, 0, 0, 0, 0, report);
69             stopDistributionService(main);
70         }).doesNotThrowAnyException();
71     }
72
73     private Main startDistributionService() throws IOException, InterruptedException {
74         final Properties systemProps = System.getProperties();
75         systemProps.put("javax.net.ssl.keyStore", new SelfSignedKeyStore().getKeystoreName());
76         systemProps.put("javax.net.ssl.keyStorePassword", SelfSignedKeyStore.KEYSTORE_PASSWORD);
77         System.setProperties(systemProps);
78
79         port = CommonTestData.makeConfigFile("parameters/DistributionConfigParameters_Https.json");
80         final String[] distributionConfigParameters = { "-c", CommonTestData.CONFIG_FILE };
81         return new Main(distributionConfigParameters);
82     }
83
84     private void stopDistributionService(final Main main) throws PolicyDistributionException {
85         main.shutdown();
86     }
87
88     private StatisticsReport performStatisticCheck() throws Exception {
89         final TrustManager[] noopTrustManager = NetworkUtil.getAlwaysTrustingManager();
90
91         final SSLContext sc = SSLContext.getInstance("TLSv1.2");
92         sc.init(null, noopTrustManager, new SecureRandom());
93         final ClientBuilder clientBuilder =
94                 ClientBuilder.newBuilder().sslContext(sc).hostnameVerifier((host, session) -> true);
95         final Client client = clientBuilder.build();
96         final HttpAuthenticationFeature feature = HttpAuthenticationFeature.basic("healthcheck", "zb!XztG34");
97         client.register(feature);
98
99         final WebTarget webTarget = client.target("https://localhost:" + port + "/statistics");
100
101         final Invocation.Builder invocationBuilder = webTarget.request(MediaType.APPLICATION_JSON);
102
103         CommonTestData.awaitServer(port);
104         return invocationBuilder.get(StatisticsReport.class);
105     }
106
107     private void validateReport(final int code, final int total, final int successCount, final int failureCount,
108             final int download, final int downloadSuccess, final int downloadFailure, final StatisticsReport report) {
109         assertEquals(code, report.getCode());
110         assertEquals(total, report.getTotalDistributionCount());
111         assertEquals(successCount, report.getDistributionSuccessCount());
112         assertEquals(failureCount, report.getDistributionFailureCount());
113         assertEquals(download, report.getTotalDownloadCount());
114         assertEquals(downloadSuccess, report.getDownloadSuccessCount());
115         assertEquals(downloadFailure, report.getDownloadFailureCount());
116     }
117 }