Reorganize dashboard into subfolders
[portal/ric-dashboard.git] / dashboard / webapp-backend / src / test / java / org / oransc / ric / portal / dashboard / controller / AdminControllerExtension.java
1 /*-
2  * ========================LICENSE_START=================================
3  * O-RAN-SC
4  * %%
5  * Copyright (C) 2019 AT&T Intellectual Property
6  * %%
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ========================LICENSE_END===================================
19  */
20 package org.oransc.ric.portal.dashboard.controller;
21
22 import java.lang.invoke.MethodHandles;
23
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26 import org.springframework.context.annotation.Profile;
27 import org.springframework.http.HttpStatus;
28 import org.springframework.http.MediaType;
29 import org.springframework.web.bind.annotation.GetMapping;
30 import org.springframework.web.bind.annotation.RequestMapping;
31 import org.springframework.web.bind.annotation.RestController;
32 import org.springframework.web.client.HttpClientErrorException;
33 import org.springframework.web.client.RestClientResponseException;
34
35 /**
36  * Extends the Admin controller with methods that throw exceptions to support
37  * testing.
38  */
39 @Profile("test")
40 @RestController
41 @RequestMapping(value = AdminController.CONTROLLER_PATH, produces = MediaType.APPLICATION_JSON_VALUE)
42 public class AdminControllerExtension {
43
44         public static final String HTTP_STATUS_CODE_EXCEPTION_METHOD = "hscexception";
45         public static final String REST_CLIENT_RESPONSE_EXCEPTION_METHOD = "rcrexception";
46         public static final String RUNTIME_EXCEPTION_METHOD = "rexception";
47
48         private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
49
50         @GetMapping(HTTP_STATUS_CODE_EXCEPTION_METHOD)
51         public void throwHttpStatusCodeException() {
52                 logger.warn("throwing HttpStatusCodeException");
53                 throw new HttpClientErrorException(HttpStatus.CHECKPOINT, "simulate http status code exception");
54         }
55
56         @GetMapping(REST_CLIENT_RESPONSE_EXCEPTION_METHOD)
57         public void throwRestClientResponseException() {
58                 logger.warn("throwing RestClientResponseException");
59                 throw new RestClientResponseException("simulate remote client failure", 0, "bar", null, null, null);
60         }
61
62         @GetMapping(RUNTIME_EXCEPTION_METHOD)
63         public void throwRuntimeException() {
64                 logger.warn("throwing RuntimeException");
65                 throw new RuntimeException("simulate runtime failure");
66         }
67
68 }