Improve test coverage in UserJsonDecoder
[clamp.git] / src / test / java / org / onap / clamp / clds / config / CldsUserJsonDecoderTest.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP CLAMP
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights
6  *                             reserved.
7  * ================================================================================
8  * Modifications Copyright (c) 2019 Samsung
9  * ================================================================================
10  * Licensed under the Apache License, Version 2.0 (the "License");
11  * you may not use this file except in compliance with the License.
12  * You may obtain a copy of the License at
13  *
14  * http://www.apache.org/licenses/LICENSE-2.0
15  *
16  * Unless required by applicable law or agreed to in writing, software
17  * distributed under the License is distributed on an "AS IS" BASIS,
18  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19  * See the License for the specific language governing permissions and
20  * limitations under the License.
21  * ============LICENSE_END============================================
22  * Modifications copyright (c) 2018 Nokia
23  * ===================================================================
24  * 
25  */
26
27 package org.onap.clamp.clds.config;
28
29 import static org.assertj.core.api.Assertions.assertThat;
30 import org.junit.Test;
31 import org.onap.clamp.clds.exception.CldsUsersException;
32 import org.onap.clamp.clds.service.CldsUser;
33
34
35 public class CldsUserJsonDecoderTest {
36
37     private String user1 = "admin1";
38     private String user2 = "admin2";
39     private String password = "5f4dcc3b5aa765d61d8327deb882cf99";
40     private String[] normalPermissionsArray = {
41         "permission-type-cl|dev|read", "permission-type-cl|dev|update", "permission-type-cl-manage|dev|*",
42         "permission-type-filter-vf|dev|*", "permission-type-template|dev|read",
43         "permission-type-template|dev|update"
44     };
45     private String[] incompletePermissionsArray = {
46         "permission-type-cl|dev|*", "permission-type-cl|dev|*", "permission-type-cl-manage|dev|*",
47         "permission-type-filter-vf|dev|*", "permission-type-template|dev|read",
48         "permission-type-template|dev|update"
49     };
50
51     @Test
52     public void testDecodingDoubleUsers() {
53
54         //when
55         CldsUser[] usersArray = CldsUserJsonDecoder
56             .decodeJson(CldsUserJsonDecoderTest.class.getResourceAsStream("/clds/clds-users-two-users.json"));
57
58         //then
59         assertThat(usersArray).hasSize(2);
60         assertThat(usersArray[0])
61             .extracting(CldsUser::getUser, CldsUser::getPassword, CldsUser::getPermissionsString)
62             .containsExactly(user1, password, normalPermissionsArray);
63
64         assertThat(usersArray[1])
65             .extracting(CldsUser::getUser, CldsUser::getPassword, CldsUser::getPermissionsString)
66             .containsExactly(user2, password, normalPermissionsArray);
67
68     }
69
70     @Test
71     public void testDecodingNoPermission() {
72         // when
73         CldsUser[] usersArray = CldsUserJsonDecoder
74                 .decodeJson(this.getClass().getResourceAsStream("/clds/clds-users-no-permission.json"));
75
76         //then
77         assertThat(usersArray).hasSize(1);
78         CldsUser user = usersArray[0];
79         assertThat(user.getUser()).isEqualTo(user1);
80         assertThat(user.getPassword()).isEqualTo(null);
81         assertThat(user.getPermissionsString()).isEmpty();
82     }
83
84     @Test
85     public void testDecodingIncompletePermissions() {
86
87         //when
88         CldsUser[] usersArray = CldsUserJsonDecoder
89                 .decodeJson(this.getClass().getResourceAsStream("/clds/clds-users-incomplete-permissions.json"));
90
91         //then
92         assertThat(usersArray).hasSize(1);
93         CldsUser user = usersArray[0];
94         assertThat(user.getUser()).isEqualTo(user1);
95         assertThat(user.getPassword()).isEqualTo(password);
96         assertThat(user.getPermissionsString()).isEqualTo(incompletePermissionsArray);
97     }
98
99     @Test(expected = CldsUsersException.class)
100     public void shouldThrowCldsUsersException() {
101         //when
102         CldsUserJsonDecoder
103                 .decodeJson(this.getClass().getResourceAsStream("/clds/clds-parse-exception.json"));
104     }
105
106 }