fixes for supporting non-gui application access provisioning
[portal.git] / ecomp-portal-BE-common / src / test / java / org / onap / portalapp / portal / service / AdminRolesServiceImplTest.java
1 /*-
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  * Modifications Copyright (c) 2019 Samsung
8  * ===================================================================
9  *
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
14  *
15  *             http://www.apache.org/licenses/LICENSE-2.0
16  *
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.
22  *
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
27  *
28  *             https://creativecommons.org/licenses/by/4.0/
29  *
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.
35  *
36  * ============LICENSE_END============================================
37  *
38  * 
39  */
40 package org.onap.portalapp.portal.service;
41
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;
46
47 import java.util.ArrayList;
48 import java.util.HashMap;
49 import java.util.List;
50 import java.util.Map;
51 import java.util.SortedSet;
52
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;
90
91 @RunWith(PowerMockRunner.class)
92 @PrepareForTest({ EcompPortalUtils.class, PortalConstants.class, SystemProperties.class,
93                 EPCommonSystemProperties.class })
94 public class AdminRolesServiceImplTest {
95
96         @Mock
97         DataAccessService dataAccessService = new DataAccessServiceImpl();
98
99     @Mock
100     ExternalAccessRolesService externalAccessRolesService;
101
102         @Mock
103         EPAppCommonServiceImpl epAppCommonServiceImpl = new EPAppCommonServiceImpl();
104
105         @Mock
106         SearchServiceImpl searchServiceImpl = new SearchServiceImpl();
107
108         @Mock
109         SessionFactory sessionFactory;
110
111         @Mock
112         Session session;
113
114         @Mock
115         Transaction transaction;
116
117         @Mock
118         RestTemplate template = new RestTemplate();
119
120         @Before
121         public void setup() {
122                 MockitoAnnotations.initMocks(this);
123                 Mockito.when(sessionFactory.openSession()).thenReturn(session);
124                 Mockito.when(session.beginTransaction()).thenReturn(transaction);
125         }
126
127         @After
128         public void after() {
129                 session.close();
130         }
131
132         @InjectMocks
133         AdminRolesServiceImpl adminRolesServiceImpl = new AdminRolesServiceImpl();
134
135         private Long ACCOUNT_ADMIN_ROLE_ID = 999L;
136         
137         private Long ECOMP_APP_ID = 1L;
138         
139         public EPApp mockApp() {
140                 EPApp app = new EPApp();
141                 app.setName("Test");
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");
148                 app.setId((long) 1);
149                 app.setAppRestEndpoint("test");
150                 app.setAlternateLandingPage("test");
151                 app.setName("test");
152                 app.setMlAppName("test");
153                 app.setMlAppAdminId("test");
154                 app.setAppBasicAuthUsername("test");
155                 app.setAppBasicAuthPassword("test");
156                 app.setOpen(false);
157                 app.setEnabled(true);
158                 app.setUebKey("test");
159                 app.setUebSecret("test");
160                 app.setUebTopicName("test");
161                 app.setAppType(EpAppType.GUI);
162                 return app;
163         }
164
165         MockEPUser mockUser = new MockEPUser();
166
167         @SuppressWarnings("deprecation")
168         @Test
169         public void getAppsWithAdminRoleStateForUserTest() {
170                 EPUser user = mockUser.mockEPUser();
171                 EPApp app = mockApp();
172                 app.setId(1l);
173                 List<EPUser> users = new ArrayList<>();
174                 users.add(user);
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);
182                 role.setId(1l);
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<>();
191                 appsList.add(app);
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);
196         }
197         
198         @Test
199         public void getAppsWithAdminRoleStateForUserTestWithException() {
200                 EPUser user = mockUser.mockEPUser();
201                 EPApp app = mockApp();
202                 app.setId(1l);
203                 List<EPUser> users = new ArrayList<>();
204                 users.add(user);
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());
209
210                 
211         }
212
213         @SuppressWarnings({ "deprecation", "unchecked" })
214         @Test
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();
222                 app.setId(1l);
223                 EPApp app2 = mockApp();
224                 app2.setName("app2");
225                 app2.setNameSpace("com.test.app2");
226                 app2.setId(2l);
227                 EPApp app3 = mockApp();
228                 app3.setName("app3");
229                 app3.setNameSpace("com.test.app3");
230                 app3.setId(3l);
231                 List<EPApp> apps = new ArrayList<>();
232                 apps.add(app);
233                 apps.add(app2);
234                 apps.add(app3);
235                 Mockito.when(epAppCommonServiceImpl.getAppsFullList()).thenReturn(apps);
236
237                 List<EPUser> localUserList = new ArrayList<>();
238                 localUserList.add(user);
239                 Mockito.when(
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);
246                 role.setId(999l);
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();
257                 app4.setId(6l);
258                 app4.setName("app7");
259                 app4.setNameSpace("com.test.app7");
260                 List<EPApp> apps2 = new ArrayList<>();
261                 apps2.add(app);
262                 apps2.add(app2);
263                 apps2.add(app3);
264                 apps2.add(app4);
265                 Mockito.when(dataAccessService.executeNamedQuery("getCentralizedApps", null, null)).thenReturn(apps2);
266                 Mockito.when(
267                                 EPCommonSystemProperties.containsProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
268                                 .thenReturn(true);
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);
278                 
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);
313                 assertTrue(actual);
314         }
315
316         @Test
317         public void isSuperAdminTest() {
318                 EPUser user = mockUser.mockEPUser();
319                 user.setId(1l);
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);
333                 assertTrue(actual);
334         }
335
336         @Test
337         public void isSuperAdminExceptionTest() {
338                 EPUser user = mockUser.mockEPUser();
339                 user.setId(1l);
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);
345                 assertFalse(actual);
346         }
347
348         @Test
349         public void isAccountAdminTest() {
350                 EPUser user = mockUser.mockEPUser();
351                 EPApp app = mockApp();
352                 app.setId(2l);
353                 SortedSet<EPUserApp> userApps = user.getEPUserApps();
354                 EPUserApp epUserApp = new EPUserApp();
355                 EPRole role = new EPRole();
356                 role.setActive(true);
357                 role.setId(999l);
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()))
365                                 .thenReturn(user);
366                 boolean actual = adminRolesServiceImpl.isAccountAdmin(user);
367                 assertTrue(actual);
368         }
369
370         @Test
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);
376                 assertFalse(actual);
377         }
378
379     @Test
380     public void isAccountAdminUserNull() {
381         boolean actual = adminRolesServiceImpl.isAccountAdmin(null);
382         assertFalse(actual);
383     }
384
385     @Test
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()))
392                 .thenReturn(roles);
393         Mockito.when(externalAccessRolesService.getFunctionCodeType(Matchers.anyString())).thenReturn("approver");
394         boolean actual = adminRolesServiceImpl.isRoleAdmin(user);
395         assertTrue(actual);
396     }
397
398         @Test
399         public void isUserTest() {
400                 EPUser user = mockUser.mockEPUser();
401                 EPApp app = mockApp();
402                 app.setId(2l);
403                 SortedSet<EPUserApp> userApps = user.getEPUserApps();
404                 EPUserApp epUserApp = new EPUserApp();
405                 EPRole role = new EPRole();
406                 role.setActive(true);
407                 role.setId(2l);
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()))
415                                 .thenReturn(user);
416                 boolean actual = adminRolesServiceImpl.isUser(user);
417                 assertTrue(actual);
418         }
419
420         @Test
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);
426                 assertFalse(actual);
427         }
428
429         @Test
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);
436                 role.setId(1l);
437                 role.setName("test role");
438                 expected.add(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);
443         }
444
445         @Test
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);
453                 role.setId(999l);
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);
466                 assertTrue(actual);
467         }
468
469         @Test
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);
476                 assertFalse(actual);
477         }
478 }