2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights
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
14 * http://www.apache.org/licenses/LICENSE-2.0
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 * ===================================================================
27 package org.onap.clamp.clds.config;
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;
35 public class CldsUserJsonDecoderTest {
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"
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"
52 public void testDecodingDoubleUsers() {
55 CldsUser[] usersArray = CldsUserJsonDecoder
56 .decodeJson(CldsUserJsonDecoderTest.class.getResourceAsStream("/clds/clds-users-two-users.json"));
59 assertThat(usersArray).hasSize(2);
60 assertThat(usersArray[0])
61 .extracting(CldsUser::getUser, CldsUser::getPassword, CldsUser::getPermissionsString)
62 .containsExactly(user1, password, normalPermissionsArray);
64 assertThat(usersArray[1])
65 .extracting(CldsUser::getUser, CldsUser::getPassword, CldsUser::getPermissionsString)
66 .containsExactly(user2, password, normalPermissionsArray);
71 public void testDecodingNoPermission() {
73 CldsUser[] usersArray = CldsUserJsonDecoder
74 .decodeJson(this.getClass().getResourceAsStream("/clds/clds-users-no-permission.json"));
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();
85 public void testDecodingIncompletePermissions() {
88 CldsUser[] usersArray = CldsUserJsonDecoder
89 .decodeJson(this.getClass().getResourceAsStream("/clds/clds-users-incomplete-permissions.json"));
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);
99 @Test(expected = CldsUsersException.class)
100 public void shouldThrowCldsUsersException() {
103 .decodeJson(this.getClass().getResourceAsStream("/clds/clds-parse-exception.json"));