2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ===================================================================
7 * Modifications Copyright (c) 2019 Samsung
8 * ===================================================================
10 * Unless otherwise specified, all software contained herein is licensed
11 * under the Apache License, Version 2.0 (the "License");
12 * you may not use this software except in compliance with the License.
13 * You may obtain a copy of the License at
15 * http://www.apache.org/licenses/LICENSE-2.0
17 * Unless required by applicable law or agreed to in writing, software
18 * distributed under the License is distributed on an "AS IS" BASIS,
19 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20 * See the License for the specific language governing permissions and
21 * limitations under the License.
23 * Unless otherwise specified, all documentation contained herein is licensed
24 * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
25 * you may not use this documentation except in compliance with the License.
26 * You may obtain a copy of the License at
28 * https://creativecommons.org/licenses/by/4.0/
30 * Unless required by applicable law or agreed to in writing, documentation
31 * distributed under the License is distributed on an "AS IS" BASIS,
32 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33 * See the License for the specific language governing permissions and
34 * limitations under the License.
36 * ============LICENSE_END============================================
40 package org.onap.portalapp.portal.service;
42 import static org.junit.Assert.assertEquals;
43 import static org.junit.Assert.assertFalse;
44 import static org.junit.Assert.assertNotNull;
45 import static org.junit.Assert.assertTrue;
47 import java.util.ArrayList;
48 import java.util.HashMap;
49 import java.util.List;
51 import java.util.SortedSet;
53 import org.hibernate.SQLQuery;
54 import org.hibernate.Session;
55 import org.hibernate.SessionFactory;
56 import org.hibernate.Transaction;
57 import org.json.simple.JSONObject;
58 import org.junit.After;
59 import org.junit.Before;
60 import org.junit.Test;
61 import org.junit.runner.RunWith;
62 import org.mockito.InjectMocks;
63 import org.mockito.Matchers;
64 import org.mockito.Mock;
65 import org.mockito.Mockito;
66 import org.mockito.MockitoAnnotations;
67 import org.onap.portalapp.portal.core.MockEPUser;
68 import org.onap.portalapp.portal.domain.EPApp;
69 import org.onap.portalapp.portal.domain.EPRole;
70 import org.onap.portalapp.portal.domain.EPUser;
71 import org.onap.portalapp.portal.domain.EPUserApp;
72 import org.onap.portalapp.portal.domain.EpAppType;
73 import org.onap.portalapp.portal.domain.UserRole;
74 import org.onap.portalapp.portal.transport.AppNameIdIsAdmin;
75 import org.onap.portalapp.portal.transport.AppsListWithAdminRole;
76 import org.onap.portalapp.portal.utils.EPCommonSystemProperties;
77 import org.onap.portalapp.portal.utils.EcompPortalUtils;
78 import org.onap.portalapp.portal.utils.PortalConstants;
79 import org.onap.portalsdk.core.service.DataAccessService;
80 import org.onap.portalsdk.core.service.DataAccessServiceImpl;
81 import org.onap.portalsdk.core.util.SystemProperties;
82 import org.powermock.api.mockito.PowerMockito;
83 import org.powermock.core.classloader.annotations.PrepareForTest;
84 import org.powermock.modules.junit4.PowerMockRunner;
85 import org.springframework.http.HttpEntity;
86 import org.springframework.http.HttpMethod;
87 import org.springframework.http.HttpStatus;
88 import org.springframework.http.ResponseEntity;
89 import org.springframework.web.client.RestTemplate;
91 @RunWith(PowerMockRunner.class)
92 @PrepareForTest({ EcompPortalUtils.class, PortalConstants.class, SystemProperties.class,
93 EPCommonSystemProperties.class })
94 public class AdminRolesServiceImplTest {
97 DataAccessService dataAccessService = new DataAccessServiceImpl();
100 ExternalAccessRolesService externalAccessRolesService;
103 EPAppCommonServiceImpl epAppCommonServiceImpl = new EPAppCommonServiceImpl();
106 SearchServiceImpl searchServiceImpl = new SearchServiceImpl();
109 SessionFactory sessionFactory;
115 Transaction transaction;
118 RestTemplate template = new RestTemplate();
121 public void setup() {
122 MockitoAnnotations.initMocks(this);
123 Mockito.when(sessionFactory.openSession()).thenReturn(session);
124 Mockito.when(session.beginTransaction()).thenReturn(transaction);
128 public void after() {
133 AdminRolesServiceImpl adminRolesServiceImpl = new AdminRolesServiceImpl();
135 private Long ACCOUNT_ADMIN_ROLE_ID = 999L;
137 private Long ECOMP_APP_ID = 1L;
139 public EPApp mockApp() {
140 EPApp app = new EPApp();
142 app.setImageUrl("test");
143 app.setNameSpace("com.test.app");
144 app.setRolesInAAF(true);
145 app.setAppDescription("test");
146 app.setAppNotes("test");
147 app.setLandingPage("test");
149 app.setAppRestEndpoint("test");
150 app.setAlternateLandingPage("test");
152 app.setMlAppName("test");
153 app.setMlAppAdminId("test");
154 app.setAppBasicAuthUsername("test");
155 app.setAppBasicAuthPassword("test");
157 app.setEnabled(true);
158 app.setUebKey("test");
159 app.setUebSecret("test");
160 app.setUebTopicName("test");
161 app.setAppType(EpAppType.GUI);
165 MockEPUser mockUser = new MockEPUser();
167 @SuppressWarnings("deprecation")
169 public void getAppsWithAdminRoleStateForUserTest() {
170 EPUser user = mockUser.mockEPUser();
171 EPApp app = mockApp();
173 List<EPUser> users = new ArrayList<>();
175 Map<String, String> userParams = new HashMap<>();
176 userParams.put("org_user_id", user.getOrgUserId());
177 Mockito.when(dataAccessService.executeNamedQuery("getEPUserByOrgUserId", userParams, null)).thenReturn(users);
178 List<EPUserApp> userAppList = new ArrayList<>();
179 EPUserApp epUserApp = new EPUserApp();
180 EPRole role = new EPRole();
181 role.setActive(true);
183 role.setName("test role");
184 epUserApp.setApp(app);
185 epUserApp.setRole(role);
186 epUserApp.setUserId(1l);
187 userAppList.add(epUserApp);
188 Mockito.when(dataAccessService.getList(EPUserApp.class,
189 " where userId = " + user.getId() + " and role.id = " + 999, null, null)).thenReturn(userAppList);
190 List<EPApp> appsList = new ArrayList<>();
192 Mockito.when(dataAccessService.getList(EPApp.class,
193 " where ( enabled = 'Y' or id = " + ECOMP_APP_ID + ")", null, null)).thenReturn(appsList);
194 AppsListWithAdminRole actual = adminRolesServiceImpl.getAppsWithAdminRoleStateForUser(user.getOrgUserId());
195 assertNotNull(actual);
199 public void getAppsWithAdminRoleStateForUserTestWithException() {
200 EPUser user = mockUser.mockEPUser();
201 EPApp app = mockApp();
203 List<EPUser> users = new ArrayList<>();
205 Map<String, String> userParams = new HashMap<>();
206 userParams.put("org_user_id", user.getOrgUserId());
207 Mockito.when(dataAccessService.executeNamedQuery("getEPUserByOrgUserId", userParams, null)).thenReturn(users);
208 AppsListWithAdminRole actual = adminRolesServiceImpl.getAppsWithAdminRoleStateForUser(user.getOrgUserId());
213 @SuppressWarnings({ "deprecation", "unchecked" })
215 public void setAppsWithAdminRoleStateForUserTest() {
216 PowerMockito.mockStatic(EPCommonSystemProperties.class);
217 PowerMockito.mockStatic(EcompPortalUtils.class);
218 PowerMockito.mockStatic(PortalConstants.class);
219 PowerMockito.mockStatic(SystemProperties.class);
220 EPUser user = mockUser.mockEPUser();
221 EPApp app = mockApp();
223 EPApp app2 = mockApp();
224 app2.setName("app2");
225 app2.setNameSpace("com.test.app2");
227 EPApp app3 = mockApp();
228 app3.setName("app3");
229 app3.setNameSpace("com.test.app3");
231 List<EPApp> apps = new ArrayList<>();
235 Mockito.when(epAppCommonServiceImpl.getAppsFullList()).thenReturn(apps);
237 List<EPUser> localUserList = new ArrayList<>();
238 localUserList.add(user);
240 dataAccessService.getList(EPUser.class, " where org_user_id='" + user.getOrgUserId() + "'", null, null))
241 .thenReturn(localUserList);
242 List<EPUserApp> oldAppsWhereUserIsAdmin = new ArrayList<EPUserApp>();
243 EPUserApp epUserApp = new EPUserApp();
244 EPRole role = new EPRole();
245 role.setActive(true);
247 role.setName("app5");
248 epUserApp.setApp(app);
249 epUserApp.setRole(role);
250 epUserApp.setUserId(1l);
251 oldAppsWhereUserIsAdmin.add(epUserApp);
252 Mockito.when(dataAccessService.getList(EPUserApp.class,
253 " where userId = " + user.getId() + " and role.id = " + ACCOUNT_ADMIN_ROLE_ID, null,
254 null)).thenReturn(oldAppsWhereUserIsAdmin);
255 Mockito.when(EcompPortalUtils.checkIfRemoteCentralAccessAllowed()).thenReturn(true);
256 EPApp app4 = mockApp();
258 app4.setName("app7");
259 app4.setNameSpace("com.test.app7");
260 List<EPApp> apps2 = new ArrayList<>();
265 Mockito.when(dataAccessService.executeNamedQuery("getCentralizedApps", null, null)).thenReturn(apps2);
267 EPCommonSystemProperties.containsProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
269 Mockito.when(SystemProperties.getProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
270 .thenReturn("@test.com");
271 JSONObject getUserRoles = new JSONObject();
272 ResponseEntity<String> getResponse = new ResponseEntity<>(getUserRoles.toString(), HttpStatus.OK);
273 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.GET),
274 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(getResponse);
275 ResponseEntity<String> addResponse = new ResponseEntity<>(HttpStatus.CREATED);
276 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.POST),
277 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(addResponse);
279 AppsListWithAdminRole newAppsListWithAdminRoles = new AppsListWithAdminRole();
280 ArrayList<AppNameIdIsAdmin> appsRoles = new ArrayList<>();
281 AppNameIdIsAdmin appNameIdIsAdmin = new AppNameIdIsAdmin();
282 appNameIdIsAdmin.setAppName("app1");
283 appNameIdIsAdmin.setId(2l);
284 appNameIdIsAdmin.setIsAdmin(true);
285 appNameIdIsAdmin.setRestrictedApp(false);
286 AppNameIdIsAdmin appNameIdIsAdmin2 = new AppNameIdIsAdmin();
287 appNameIdIsAdmin2.setAppName("app2");
288 appNameIdIsAdmin2.setId(3l);
289 appNameIdIsAdmin2.setIsAdmin(true);
290 appNameIdIsAdmin2.setRestrictedApp(false);
291 appsRoles.add(appNameIdIsAdmin);
292 appsRoles.add(appNameIdIsAdmin2);
293 newAppsListWithAdminRoles.setOrgUserId(user.getOrgUserId());
294 newAppsListWithAdminRoles.setAppsRoles(appsRoles);
295 Mockito.when((EPApp) session.get(EPApp.class, appNameIdIsAdmin.id)).thenReturn(app2);
296 Mockito.when((EPApp) session.get(EPApp.class, appNameIdIsAdmin2.id)).thenReturn(app3);
297 JSONObject getUserRoles2 = new JSONObject();
298 JSONObject getUserRoles3 = new JSONObject();
299 JSONObject getUserRoles4 = new JSONObject();
300 JSONObject finalUserRoles = new JSONObject();
301 getUserRoles2.put("role", "com.test.app3.Account_Administrator");
302 getUserRoles3.put("role", "com.test.app3.admin");
303 getUserRoles4.put("role", "com.test.app3.owner");
304 List<JSONObject> userRoles = new ArrayList<>();
305 userRoles.add(getUserRoles2);
306 userRoles.add(getUserRoles3);
307 userRoles.add(getUserRoles4);
308 finalUserRoles.put("userRole", userRoles);
309 ResponseEntity<String> getResponse2 = new ResponseEntity<>(finalUserRoles.toString(), HttpStatus.OK);
310 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.GET),
311 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(getResponse2);
312 boolean actual = adminRolesServiceImpl.setAppsWithAdminRoleStateForUser(newAppsListWithAdminRoles);
317 public void isSuperAdminTest() {
318 EPUser user = mockUser.mockEPUser();
320 SQLQuery SqlQuery = Mockito.mock(SQLQuery.class);
321 Mockito.when(session.createSQLQuery(Matchers.anyString())).thenReturn(SqlQuery);
322 List<UserRole> userRoleList = new ArrayList<>();
323 UserRole userRole = new UserRole();
324 userRole.setFirstName("Hello");
325 userRole.setLastName("World");
326 userRole.setRoleId(1l);
327 userRole.setRoleName("test");
328 userRole.setUser_Id(1l);
329 userRoleList.add(userRole);
330 Mockito.when(dataAccessService.executeSQLQuery(Matchers.anyString(), Matchers.any(), Matchers.anyMap()))
331 .thenReturn(userRoleList);
332 boolean actual = adminRolesServiceImpl.isSuperAdmin(user);
337 public void isSuperAdminExceptionTest() {
338 EPUser user = mockUser.mockEPUser();
340 SQLQuery SqlQuery = Mockito.mock(SQLQuery.class);
341 Mockito.when(session.createSQLQuery(Matchers.anyString())).thenReturn(SqlQuery);
342 Mockito.doThrow(new NullPointerException()).when(dataAccessService).executeSQLQuery(Matchers.anyString(),
343 Matchers.any(), Matchers.anyMap());
344 boolean actual = adminRolesServiceImpl.isSuperAdmin(user);
349 public void isAccountAdminTest() {
350 EPUser user = mockUser.mockEPUser();
351 EPApp app = mockApp();
353 SortedSet<EPUserApp> userApps = user.getEPUserApps();
354 EPUserApp epUserApp = new EPUserApp();
355 EPRole role = new EPRole();
356 role.setActive(true);
358 role.setName("test role");
359 epUserApp.setApp(app);
360 epUserApp.setRole(role);
361 epUserApp.setUserId(1l);
362 userApps.add(epUserApp);
363 user.setUserApps(userApps);
364 Mockito.when((EPUser) dataAccessService.getDomainObject(Matchers.any(), Matchers.anyLong(), Matchers.anyMap()))
366 boolean actual = adminRolesServiceImpl.isAccountAdmin(user);
371 public void isAccountAdminExceptionTest() {
372 EPUser user = mockUser.mockEPUser();
373 Mockito.doThrow(new NullPointerException()).when(dataAccessService).getDomainObject(Matchers.any(),
374 Matchers.anyLong(), Matchers.anyMap());
375 boolean actual = adminRolesServiceImpl.isAccountAdmin(user);
380 public void isAccountAdminUserNull() {
381 boolean actual = adminRolesServiceImpl.isAccountAdmin(null);
386 public void isRoleAdminTest() {
387 EPUser user = mockUser.mockEPUser();
388 List<String> roles = new ArrayList<>();
389 roles.add("approver\\|");
390 Mockito.when(dataAccessService.executeNamedQuery(
391 Matchers.eq("getRoleFunctionsOfUserforAlltheApplications"), Matchers.any(), Matchers.any()))
393 Mockito.when(externalAccessRolesService.getFunctionCodeType(Matchers.anyString())).thenReturn("approver");
394 boolean actual = adminRolesServiceImpl.isRoleAdmin(user);
399 public void isUserTest() {
400 EPUser user = mockUser.mockEPUser();
401 EPApp app = mockApp();
403 SortedSet<EPUserApp> userApps = user.getEPUserApps();
404 EPUserApp epUserApp = new EPUserApp();
405 EPRole role = new EPRole();
406 role.setActive(true);
408 role.setName("test role");
409 epUserApp.setApp(app);
410 epUserApp.setRole(role);
411 epUserApp.setUserId(1l);
412 userApps.add(epUserApp);
413 user.setUserApps(userApps);
414 Mockito.when((EPUser) dataAccessService.getDomainObject(Matchers.any(), Matchers.anyLong(), Matchers.anyMap()))
416 boolean actual = adminRolesServiceImpl.isUser(user);
421 public void isUserExceptionTest() {
422 EPUser user = mockUser.mockEPUser();
423 Mockito.doThrow(new NullPointerException()).when(dataAccessService).getDomainObject(Matchers.any(),
424 Matchers.anyLong(), Matchers.anyMap());
425 boolean actual = adminRolesServiceImpl.isUser(user);
430 public void getRolesByAppTest() {
431 EPUser user = mockUser.mockEPUser();
432 EPApp app = mockApp();
433 List<EPRole> expected = new ArrayList<>();
434 EPRole role = new EPRole();
435 role.setActive(true);
437 role.setName("test role");
439 Mockito.when(dataAccessService.executeSQLQuery(Matchers.anyString(), Matchers.any(), Matchers.anyMap()))
440 .thenReturn(expected);
441 List<EPRole> actual = adminRolesServiceImpl.getRolesByApp(user, app.getId());
442 assertEquals(expected, actual);
446 public void isAccountAdminOfApplicationTest() {
447 EPUser user = mockUser.mockEPUser();
448 EPApp app = mockApp();
449 SortedSet<EPUserApp> userApps = user.getEPUserApps();
450 EPUserApp epUserApp = new EPUserApp();
451 EPRole role = new EPRole();
452 role.setActive(true);
454 role.setName("test role");
455 epUserApp.setApp(app);
456 epUserApp.setRole(role);
457 epUserApp.setUserId(1l);
458 userApps.add(epUserApp);
459 user.setUserApps(userApps);
460 List<Integer> userAdminApps = new ArrayList<>();
461 userAdminApps.add(1);
462 userAdminApps.add(2);
463 Mockito.when(dataAccessService.executeNamedQuery(Matchers.anyString(), Matchers.anyMap(), Matchers.anyMap()))
464 .thenReturn(userAdminApps);
465 boolean actual = adminRolesServiceImpl.isAccountAdminOfApplication(user, app);
470 public void isAccountAdminOfApplicationExceptionTest() {
471 EPUser user = mockUser.mockEPUser();
472 EPApp app = mockApp();
473 Mockito.doThrow(new NullPointerException()).when(dataAccessService).getDomainObject(Matchers.any(),
474 Matchers.anyLong(), Matchers.anyMap());
475 boolean actual = adminRolesServiceImpl.isAccountAdminOfApplication(user, app);