Merge "Set localhost in config"
[clamp.git] / src / test / java / org / onap / clamp / clds / it / HttpsIT.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP CLAMP
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights
6  *                             reserved.
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  * ============LICENSE_END============================================
20  * ===================================================================
21  * ECOMP is a trademark and service mark of AT&T Intellectual Property.
22  */
23
24 package org.onap.clamp.clds.it;
25
26 import static org.assertj.core.api.Assertions.assertThat;
27
28 import java.io.IOException;
29 import java.net.HttpURLConnection;
30
31 import javax.net.ssl.HostnameVerifier;
32 import javax.net.ssl.HttpsURLConnection;
33 import javax.net.ssl.SSLContext;
34 import javax.net.ssl.SSLSession;
35 import javax.net.ssl.TrustManager;
36 import javax.net.ssl.X509TrustManager;
37
38 import org.junit.BeforeClass;
39 import org.junit.Test;
40 import org.junit.runner.RunWith;
41 import org.onap.clamp.clds.AbstractIT;
42 import org.springframework.beans.factory.annotation.Value;
43 import org.springframework.boot.test.context.SpringBootTest;
44 import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
45 import org.springframework.http.HttpStatus;
46 import org.springframework.http.ResponseEntity;
47 import org.springframework.http.client.SimpleClientHttpRequestFactory;
48 import org.springframework.test.context.TestPropertySource;
49 import org.springframework.test.context.junit4.SpringRunner;
50 import org.springframework.web.client.RestTemplate;
51
52 /**
53  * Test HTTP and HTTPS settings + redirection of HTTP to HTTPS.
54  */
55 @RunWith(SpringRunner.class)
56 @SpringBootTest(webEnvironment = WebEnvironment.DEFINED_PORT)
57 @TestPropertySource(locations = "classpath:https/https-test.properties")
58 public class HttpsIT extends AbstractIT {
59
60     @Value("${server.port}")
61     private String httpsPort;
62
63     @Value("${server.http-to-https-redirection.port}")
64     private String httpPort;
65
66     @BeforeClass
67     public static void setUp() {
68
69         try {
70             // setup ssl context to ignore certificate errors
71             SSLContext ctx = SSLContext.getInstance("TLS");
72             X509TrustManager tm = new X509TrustManager() {
73
74                 @Override
75                 public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType)
76                         throws java.security.cert.CertificateException {
77                 }
78
79                 @Override
80                 public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType)
81                         throws java.security.cert.CertificateException {
82                 }
83
84                 @Override
85                 public java.security.cert.X509Certificate[] getAcceptedIssuers() {
86                     return null;
87                 }
88             };
89             ctx.init(null, new TrustManager[] { tm }, null);
90             SSLContext.setDefault(ctx);
91         } catch (Exception ex) {
92             ex.printStackTrace();
93         }
94
95     }
96
97     @Test
98     public void testDesignerIndex() throws Exception {
99         RestTemplate template = new RestTemplate();
100         final MySimpleClientHttpRequestFactory factory = new MySimpleClientHttpRequestFactory(new HostnameVerifier() {
101
102             @Override
103             public boolean verify(final String hostname, final SSLSession session) {
104                 return true;
105             }
106         });
107         template.setRequestFactory(factory);
108
109         ResponseEntity<String> entity = template
110                 .getForEntity("http://localhost:" + this.httpPort + "/designer/index.html", String.class);
111         assertThat(entity.getStatusCode()).isEqualTo(HttpStatus.FOUND);
112
113         ResponseEntity<String> httpsEntity = template
114                 .getForEntity("https://localhost:" + this.httpsPort + "/designer/index.html", String.class);
115         assertThat(httpsEntity.getStatusCode()).isEqualTo(HttpStatus.OK);
116         assertThat(httpsEntity.getBody()).contains("CLDS");
117
118     }
119
120     /**
121      * Http Request Factory for ignoring SSL hostname errors. Not for production
122      * use!
123      */
124     class MySimpleClientHttpRequestFactory extends SimpleClientHttpRequestFactory {
125
126         private final HostnameVerifier verifier;
127
128         public MySimpleClientHttpRequestFactory(final HostnameVerifier verifier) {
129             this.verifier = verifier;
130         }
131
132         @Override
133         protected void prepareConnection(final HttpURLConnection connection, final String httpMethod)
134                 throws IOException {
135             if (connection instanceof HttpsURLConnection) {
136                 ((HttpsURLConnection) connection).setHostnameVerifier(this.verifier);
137             }
138             super.prepareConnection(connection, httpMethod);
139         }
140     }
141
142 }