Merge "Fix sql injection vulnerability"
[portal.git] / ecomp-portal-BE-common / src / test / java / org / onap / portalapp / portal / service / UserRolesCommonServiceImplTest.java
1 /*-
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  *
8  * Unless otherwise specified, all software contained herein is licensed
9  * under the Apache License, Version 2.0 (the "License");
10  * you may not use this software except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *             http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  * Unless otherwise specified, all documentation contained herein is licensed
22  * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
23  * you may not use this documentation except in compliance with the License.
24  * You may obtain a copy of the License at
25  *
26  *             https://creativecommons.org/licenses/by/4.0/
27  *
28  * Unless required by applicable law or agreed to in writing, documentation
29  * distributed under the License is distributed on an "AS IS" BASIS,
30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31  * See the License for the specific language governing permissions and
32  * limitations under the License.
33  *
34  * ============LICENSE_END============================================
35  *
36  * 
37  */
38 package org.onap.portalapp.portal.service;
39
40 import static org.junit.Assert.assertEquals;
41 import static org.junit.Assert.assertFalse;
42 import static org.junit.Assert.assertNotEquals;
43 import static org.junit.Assert.assertNull;
44 import static org.junit.Assert.assertTrue;
45
46 import java.util.ArrayList;
47 import java.util.Date;
48 import java.util.HashMap;
49 import java.util.List;
50 import java.util.Map;
51 import java.util.Set;
52 import java.util.SortedSet;
53 import java.util.TreeSet;
54
55 import javax.servlet.http.HttpServletResponse;
56
57 import org.apache.cxf.transport.http.HTTPException;
58 import org.drools.core.command.assertion.AssertEquals;
59 import org.hibernate.Query;
60 import org.hibernate.SQLQuery;
61 import org.hibernate.Session;
62 import org.hibernate.SessionFactory;
63 import org.hibernate.Transaction;
64 import org.json.JSONObject;
65 import org.junit.After;
66 import org.junit.Before;
67 import org.junit.Test;
68 import org.junit.runner.RunWith;
69 import org.mockito.InjectMocks;
70 import org.mockito.Matchers;
71 import org.mockito.Mock;
72 import org.mockito.Mockito;
73 import org.mockito.MockitoAnnotations;
74 import org.onap.portalapp.externalsystemapproval.model.ExternalSystemRoleApproval;
75 import org.onap.portalapp.externalsystemapproval.model.ExternalSystemUser;
76 import org.onap.portalapp.portal.core.MockEPUser;
77 import org.onap.portalapp.portal.domain.EPApp;
78 import org.onap.portalapp.portal.domain.EPRole;
79 import org.onap.portalapp.portal.domain.EPUser;
80 import org.onap.portalapp.portal.domain.EPUserApp;
81 import org.onap.portalapp.portal.domain.EPUserAppCatalogRoles;
82 import org.onap.portalapp.portal.domain.EPUserAppRoles;
83 import org.onap.portalapp.portal.domain.EPUserAppRolesRequest;
84 import org.onap.portalapp.portal.domain.EPUserAppRolesRequestDetail;
85 import org.onap.portalapp.portal.domain.ExternalSystemAccess;
86 import org.onap.portalapp.portal.transport.AppWithRolesForUser;
87 import org.onap.portalapp.portal.transport.CentralV2Role;
88 import org.onap.portalapp.portal.transport.EPUserAppCurrentRoles;
89 import org.onap.portalapp.portal.transport.EcompUserAppRoles;
90 import org.onap.portalapp.portal.transport.ExternalRequestFieldsValidator;
91 import org.onap.portalapp.portal.transport.FieldsValidator;
92 import org.onap.portalapp.portal.transport.FunctionalMenuItem;
93 import org.onap.portalapp.portal.transport.FunctionalMenuRole;
94 import org.onap.portalapp.portal.transport.RemoteRole;
95 import org.onap.portalapp.portal.transport.RemoteUserWithRoles;
96 import org.onap.portalapp.portal.transport.RoleInAppForUser;
97 import org.onap.portalapp.portal.transport.UserApplicationRoles;
98 import org.onap.portalapp.portal.utils.EPCommonSystemProperties;
99 import org.onap.portalapp.portal.utils.EcompPortalUtils;
100 import org.onap.portalapp.portal.utils.PortalConstants;
101 import org.onap.portalsdk.core.domain.Role;
102 import org.onap.portalsdk.core.restful.domain.EcompRole;
103 import org.onap.portalsdk.core.service.DataAccessService;
104 import org.onap.portalsdk.core.service.DataAccessServiceImpl;
105 import org.onap.portalsdk.core.service.RoleServiceImpl;
106 import org.onap.portalsdk.core.util.SystemProperties;
107 import org.powermock.api.mockito.PowerMockito;
108 import org.powermock.core.classloader.annotations.PrepareForTest;
109 import org.powermock.modules.junit4.PowerMockRunner;
110 import org.springframework.http.HttpEntity;
111 import org.springframework.http.HttpHeaders;
112 import org.springframework.http.HttpMethod;
113 import org.springframework.http.HttpStatus;
114 import org.springframework.http.ResponseEntity;
115 import org.springframework.web.client.RestTemplate;
116
117 import com.fasterxml.jackson.core.JsonProcessingException;
118 import com.fasterxml.jackson.databind.ObjectMapper;
119
120 @RunWith(PowerMockRunner.class)
121 @PrepareForTest({ EcompPortalUtils.class, SystemProperties.class, PortalConstants.class,
122                 EPCommonSystemProperties.class })
123 public class UserRolesCommonServiceImplTest {
124
125         @Mock
126         DataAccessService dataAccessService = new DataAccessServiceImpl();
127
128         @Mock
129         EPAppCommonServiceImpl epAppCommonServiceImpl = new EPAppCommonServiceImpl();
130
131         @Mock
132         ExternalAccessRolesServiceImpl externalAccessRolesServiceImpl = new ExternalAccessRolesServiceImpl();
133
134         @Mock
135         ApplicationsRestClientService applicationsRestClientService;
136
137         @Mock
138         RoleServiceImpl roleServiceImpl = new RoleServiceImpl();
139
140         @Mock
141         SearchServiceImpl searchServiceImpl = new SearchServiceImpl();
142
143         @Mock
144         EPRoleServiceImpl epRoleServiceImpl = new EPRoleServiceImpl();
145
146         @Mock
147         RestTemplate template = new RestTemplate();
148
149         @Mock
150         SessionFactory sessionFactory;
151
152         @Mock
153         Session session;
154
155         @Mock
156         Transaction transaction;
157
158         @InjectMocks
159         UserRolesCommonServiceImpl userRolesCommonServiceImpl = new UserRolesCommonServiceImpl();
160
161         @Before
162         public void setup() {
163                 MockitoAnnotations.initMocks(this);
164                 Mockito.when(sessionFactory.openSession()).thenReturn(session);
165                 Mockito.when(session.beginTransaction()).thenReturn(transaction);
166         }
167
168         @After
169         public void after() {
170                 session.close();
171         }
172
173         MockEPUser mockUser = new MockEPUser();
174
175         public EPApp mockApp() {
176                 EPApp app = new EPApp();
177                 app.setName("Test");
178                 app.setImageUrl("test");
179                 app.setDescription("test");
180                 app.setNotes("test");
181                 app.setUrl("test");
182                 app.setId((long) 1);
183                 app.setAppRestEndpoint("test");
184                 app.setAlternateUrl("test");
185                 app.setName("test");
186                 app.setMlAppName("test");
187                 app.setMlAppAdminId("test");
188                 app.setUsername("test");
189                 app.setAppPassword("test");
190                 app.setOpen(false);
191                 app.setEnabled(false);
192                 app.setCentralAuth(true);
193                 app.setUebKey("test");
194                 app.setUebSecret("test");
195                 app.setUebTopicName("test");
196                 app.setAppType(1);
197                 return app;
198         }
199
200         @SuppressWarnings("unchecked")
201         @Test
202         public void getAppRolesForUserCentralizedForPortal() throws Exception {
203                 EPUser user = mockUser.mockEPUser();
204                 EPApp mockApp = mockApp();
205                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
206                 List<RoleInAppForUser> mockRoleInAppForUserList = getMockedRoleInAppUserList();
207                 List<CentralV2Role> mockCenV2Role = new ArrayList<>();
208                 CentralV2Role cenV2Role = new CentralV2Role(1l, null, null, null, null, null, "test1", true, null,
209                                 new TreeSet<>(), new TreeSet<>(), new TreeSet<>());
210                 CentralV2Role cenV2Role2 = new CentralV2Role(16l, null, null, null, null, null, "test2", true, null,
211                                 new TreeSet<>(), new TreeSet<>(), new TreeSet<>());
212                 mockCenV2Role.add(cenV2Role);
213                 mockCenV2Role.add(cenV2Role2);
214                 Mockito.when(externalAccessRolesServiceImpl.getRolesForApp(mockApp.getUebKey())).thenReturn(mockCenV2Role);
215                 List<EPUser> mockUserList = new ArrayList<>();
216                 mockUserList.add(user);
217                 Mockito.when((List<EPUser>) dataAccessService
218                                 .executeQuery("from EPUser where orgUserId='" + user.getOrgUserId() + "'", null))
219                                 .thenReturn(mockUserList);
220                 Mockito.when(userRolesCommonServiceImpl.getAppRolesForUser(1l, user.getOrgUserId(), true, user))
221                                 .thenReturn(mockRoleInAppForUserList);
222                 List<RoleInAppForUser> roleInAppForUser = userRolesCommonServiceImpl.getAppRolesForUser(1l, "test", true, user);
223                 assertEquals(roleInAppForUser, mockRoleInAppForUserList);
224         }
225
226         private List<RoleInAppForUser> getMockedRoleInAppUserList() {
227                 List<RoleInAppForUser> mockRoleInAppForUserList = new ArrayList<>();
228                 RoleInAppForUser mockRoleInAppForUser = new RoleInAppForUser();
229                 mockRoleInAppForUser.setIsApplied(false);
230                 mockRoleInAppForUser.setRoleId(1l);
231                 mockRoleInAppForUser.setRoleName("test1");
232                 RoleInAppForUser mockRoleInAppForUser2 = new RoleInAppForUser();
233                 mockRoleInAppForUser2.setIsApplied(false);
234                 mockRoleInAppForUser2.setRoleId(16l);
235                 mockRoleInAppForUser2.setRoleName("test2");
236                 mockRoleInAppForUserList.add(mockRoleInAppForUser);
237                 mockRoleInAppForUserList.add(mockRoleInAppForUser2);
238                 return mockRoleInAppForUserList;
239         }
240
241         @SuppressWarnings("unchecked")
242         @Test
243         public void checkTheProtectionAgainstSQLInjection() throws Exception {
244                 EPUser user = mockUser.mockEPUser();
245                 user.setId(1l);
246                 user.setOrgId(2l);
247                 Query epUserQuery = Mockito.mock(Query.class);
248                 List<EPUser> mockEPUserList = new ArrayList<>();
249                 mockEPUserList.add(user);
250
251                 Mockito.when(session.createQuery("from :name where orgUserId=:userId")).thenReturn(epUserQuery);
252                 Mockito.when(epUserQuery.setParameter("name",EPUser.class.getName())).thenReturn(epUserQuery);
253                 Mockito.when(epUserQuery.setParameter("userId",user.getOrgUserId() + "; select * from " + EPUser.class.getName() +";")).thenReturn(epUserQuery);
254                 userRolesCommonServiceImpl.createLocalUserIfNecessary(user.getOrgUserId(),true);
255
256                 Mockito.when(session.createQuery("from :name where orgUserId=:userId")).thenReturn(epUserQuery);
257                 Mockito.when(epUserQuery.setParameter("name",EPUser.class.getName())).thenReturn(epUserQuery);
258                 Mockito.when(epUserQuery.setParameter("userId",user.getOrgUserId())).thenReturn(epUserQuery);
259                 userRolesCommonServiceImpl.createLocalUserIfNecessary(user.getOrgUserId(),true);
260         }
261
262         @SuppressWarnings("unchecked")
263         @Test
264         public void getAppRolesForUserNonCentralizedForPortal() throws Exception {
265                 EPUser user = mockUser.mockEPUser();
266                 user.setId(1l);
267                 EPApp mockApp = mockApp();
268                 mockApp.setCentralAuth(false);
269                 EPRole mockEPRole = new EPRole();
270                 mockEPRole.setId(1l);
271                 mockEPRole.setName("test1");
272                 mockEPRole.setActive(true);
273                 SortedSet<EPUserApp> mockUserApps = new TreeSet<EPUserApp>();
274                 EPUserApp mockEPUserApp = new EPUserApp();
275                 mockEPUserApp.setApp(mockApp);
276                 mockEPUserApp.setRole(mockEPRole);
277                 mockEPUserApp.setUserId(1l);
278                 mockUserApps.add(mockEPUserApp);
279                 user.setEPUserApps(mockUserApps);
280                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
281                 List<RoleInAppForUser> mockRoleInAppForUserListNonCentralizedList = getMockedRoleInAppUserList();
282                 List<Role> mockRole = new ArrayList<>();
283                 Role role = new Role();
284                 role.setId(1l);
285                 role.setName("test1");
286                 role.setActive(true);
287                 Role role2 = new Role();
288                 role.setId(16l);
289                 role.setName("test2");
290                 role.setActive(true);
291                 mockRole.add(role);
292                 mockRole.add(role2);
293                 Mockito.when(roleServiceImpl.getAvailableRoles(user.getOrgUserId())).thenReturn(mockRole);
294                 List<EPUser> mockUserList = new ArrayList<>();
295                 mockUserList.add(user);
296                 Mockito.when((List<EPUser>) dataAccessService
297                                 .executeQuery("from EPUser where orgUserId='" + user.getOrgUserId() + "'", null))
298                                 .thenReturn(mockUserList);
299                 Mockito.when(userRolesCommonServiceImpl.getAppRolesForUser(1l, user.getOrgUserId(), true, user))
300                                 .thenReturn(mockRoleInAppForUserListNonCentralizedList);
301                 List<RoleInAppForUser> roleInAppForUserNonCentralized = userRolesCommonServiceImpl.getAppRolesForUser(1l,
302                                 user.getOrgUserId(), true, user);
303                 assertNull(roleInAppForUserNonCentralized);
304         }
305
306         @Test
307         public void getAppRolesForCentralizedPartnerAppTest() throws Exception {
308                 EPUser user = mockUser.mockEPUser();
309                 EPApp mockApp = mockApp();
310                 mockApp.setId(2l);
311                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
312                 List<RoleInAppForUser> mockRoleInAppForUserList = getMockedRoleInAppUserList();
313                 List<EPRole> mockEPRoleList = new ArrayList<>();
314                 EPRole mockEpRole = new EPRole();
315                 mockEpRole.setActive(true);
316                 mockEpRole.setAppId(2l);
317                 mockEpRole.setName("test1");
318                 mockEpRole.setAppRoleId(333l);
319                 mockEpRole.setId(1l);
320                 EPRole mockEpRole2 = new EPRole();
321                 mockEpRole2.setActive(true);
322                 mockEpRole2.setAppId(2l);
323                 mockEpRole2.setName("test2");
324                 mockEpRole2.setAppRoleId(444l);
325                 mockEpRole2.setId(16l);
326                 mockEPRoleList.add(mockEpRole);
327                 mockEPRoleList.add(mockEpRole2);
328                 final Map<String, Long> appParams = new HashMap<>();
329                 appParams.put("appId", 2l);
330                 Mockito.when(dataAccessService.executeNamedQuery("getActiveRolesOfApplication", appParams, null))
331                                 .thenReturn(mockEPRoleList);
332                 final Map<String, String> params = new HashMap<>();
333                 params.put("orgUserIdValue", "guestT");
334                 List<EPUser> mockEPUserList = new ArrayList<>();
335                 mockEPUserList.add(user);
336                 Mockito.when(dataAccessService.executeNamedQuery("epUserAppId", params, null)).thenReturn(mockEPUserList);
337                 final Map<String, Long> userParams = new HashMap<>();
338                 userParams.put("appId", mockApp.getId());
339                 userParams.put("userId", mockEPUserList.get(0).getId());
340                 List<EPUserAppCurrentRoles> epUserAppCurrentRolesList = new ArrayList<>();
341                 EPUserAppCurrentRoles epUserAppCurrentRoles = new EPUserAppCurrentRoles();
342                 epUserAppCurrentRoles.setRoleId(444l);
343                 epUserAppCurrentRoles.setRoleName("TestPartnerRole2");
344                 epUserAppCurrentRoles.setUserId(mockEPUserList.get(0).getId());
345                 epUserAppCurrentRolesList.add(epUserAppCurrentRoles);
346                 Mockito.when(dataAccessService.executeNamedQuery("getUserAppCurrentRoles", userParams, null))
347                                 .thenReturn(epUserAppCurrentRolesList);
348                 Mockito.when(userRolesCommonServiceImpl.getAppRolesForUser(2l, user.getOrgUserId(), true, user))
349                                 .thenReturn(mockRoleInAppForUserList);
350                 List<RoleInAppForUser> roleInAppForUser = userRolesCommonServiceImpl.getAppRolesForUser(2l, user.getOrgUserId(),
351                                 true, user);
352                 assertNotEquals(roleInAppForUser, mockRoleInAppForUserList);
353         }
354
355         @Test
356         public void getAppRolesForNonCentralizedPartnerAppTest() throws Exception {
357                 EPUser user = mockUser.mockEPUser();
358                 user.setId(2l);
359                 List<EPUser> mockEpUserList = new ArrayList<>();
360                 mockEpUserList.add(user);
361                 EPApp mockApp = mockApp();
362                 mockApp.setId(2l);
363                 mockApp.setCentralAuth(false);
364                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
365                 List<RoleInAppForUser> mockRoleInAppForUserList = new ArrayList<>();
366                 RoleInAppForUser mockRoleInAppForUser = new RoleInAppForUser();
367                 mockRoleInAppForUser.setIsApplied(true);
368                 mockRoleInAppForUser.setRoleId(333l);
369                 mockRoleInAppForUser.setRoleName("test1");
370                 RoleInAppForUser mockRoleInAppForUser2 = new RoleInAppForUser();
371                 mockRoleInAppForUser2.setIsApplied(true);
372                 mockRoleInAppForUser2.setRoleId(777l);
373                 mockRoleInAppForUser2.setRoleName("test2");
374                 RoleInAppForUser mockRoleInAppForUser3 = new RoleInAppForUser();
375                 mockRoleInAppForUser3.setIsApplied(false);
376                 mockRoleInAppForUser3.setRoleId(888l);
377                 mockRoleInAppForUser3.setRoleName("test5");
378                 mockRoleInAppForUserList.add(mockRoleInAppForUser);
379                 mockRoleInAppForUserList.add(mockRoleInAppForUser2);
380                 mockRoleInAppForUserList.add(mockRoleInAppForUser3);
381                 List<EcompRole> mockEcompRoleList = new ArrayList<>();
382                 EcompRole mockEcompRole = new EcompRole();
383                 mockEcompRole.setId(333l);
384                 mockEcompRole.setName("test1");
385                 EcompRole mockEcompRole2 = new EcompRole();
386                 mockEcompRole2.setId(777l);
387                 mockEcompRole2.setName("test2");
388                 EcompRole mockEcompRole3 = new EcompRole();
389                 mockEcompRole3.setId(888l);
390                 mockEcompRole3.setName("test5");
391                 mockEcompRoleList.add(mockEcompRole);
392                 mockEcompRoleList.add(mockEcompRole2);
393                 mockEcompRoleList.add(mockEcompRole3);
394                 EcompRole[] mockEcompRoleArray = mockEcompRoleList.toArray(new EcompRole[mockEcompRoleList.size()]);
395                 List<EPRole> mockEPRoleList = new ArrayList<>();
396                 EPRole mockEpRole = new EPRole();
397                 mockEpRole.setActive(true);
398                 mockEpRole.setAppId(2l);
399                 mockEpRole.setName("test1");
400                 mockEpRole.setAppRoleId(333l);
401                 mockEpRole.setId(16l);
402                 EPRole mockEpRole2 = new EPRole();
403                 mockEpRole2.setActive(true);
404                 mockEpRole2.setAppId(2l);
405                 mockEpRole2.setName("test3");
406                 mockEpRole2.setAppRoleId(555l);
407                 mockEpRole2.setId(15l);
408                 EPRole mockEpRole3 = new EPRole();
409                 mockEpRole3.setActive(true);
410                 mockEpRole3.setAppId(2l);
411                 mockEpRole3.setName("test4");
412                 mockEpRole3.setAppRoleId(888l);
413                 mockEpRole3.setId(17l);
414                 mockEPRoleList.add(mockEpRole);
415                 mockEPRoleList.add(mockEpRole2);
416                 mockEPRoleList.add(mockEpRole3);
417                 List<EPUserApp> mockUserRolesList = new ArrayList<>();
418                 EPUserApp mockEpUserApp = new EPUserApp();
419                 mockEpUserApp.setApp(mockApp);
420                 mockEpUserApp.setRole(mockEpRole2);
421                 mockEpUserApp.setUserId(user.getId());
422                 mockUserRolesList.add(mockEpUserApp);
423                 List<FunctionalMenuRole> mockFunctionalMenuRolesList = new ArrayList<>();
424                 FunctionalMenuRole mockFunctionalMenuRole = new FunctionalMenuRole();
425                 mockFunctionalMenuRole.setAppId((int) (long) mockApp.getId());
426                 mockFunctionalMenuRole.setRoleId((int) (long) 15l);
427                 mockFunctionalMenuRole.setMenuId(10l);
428                 mockFunctionalMenuRole.setId(10);
429                 mockFunctionalMenuRolesList.add(mockFunctionalMenuRole);
430                 List<FunctionalMenuItem> mockFunctionalMenuItemList = new ArrayList<>();
431                 FunctionalMenuItem mockFunctionalMenuItem = new FunctionalMenuItem();
432                 List<Integer> mockRolesList = new ArrayList<>();
433                 Integer role1 = 1;
434                 mockRolesList.add(role1);
435                 mockFunctionalMenuItem.setRestrictedApp(false);
436                 mockFunctionalMenuItem.setRoles(mockRolesList);
437                 mockFunctionalMenuItem.setUrl("http://test.com");
438                 mockFunctionalMenuItemList.add(mockFunctionalMenuItem);
439                 Query epRoleQuery = Mockito.mock(Query.class);
440                 Query epUserAppsQuery = Mockito.mock(Query.class);
441                 Query epFunctionalMenuQuery = Mockito.mock(Query.class);
442                 Query epFunctionalMenuQuery2 = Mockito.mock(Query.class);
443                 Query epFunctionalMenuItemQuery = Mockito.mock(Query.class);
444                 Query epUserListQuery = Mockito.mock(Query.class);
445                 Query epUserRolesListQuery = Mockito.mock(Query.class);
446                 Mockito.when(applicationsRestClientService.get(EcompRole[].class, mockApp.getId(), "/roles"))
447                                 .thenReturn(mockEcompRoleArray);
448                 // syncAppRolesTest
449
450                 Mockito.when(session.createQuery("from :name where appId = :appId"))
451                                 .thenReturn(epRoleQuery);
452
453                 Mockito.when(epRoleQuery.setParameter("name",EPRole.class.getName())).thenReturn(epRoleQuery);
454                 Mockito.when(epRoleQuery.setParameter("appId",mockApp.getId())).thenReturn(epRoleQuery);
455
456                 Mockito.doReturn(mockEPRoleList).when(epRoleQuery).list();
457                 Mockito.when(session.createQuery("from :name where app.id=:appId and role_id=:roleId"))
458                                 .thenReturn(epUserAppsQuery);
459                 Mockito.when(epUserAppsQuery.setParameter("name",EPUserApp.class.getName())).thenReturn(epUserAppsQuery);
460                 Mockito.when(epUserAppsQuery.setParameter("appId",mockApp.getId())).thenReturn(epUserAppsQuery);
461                 Mockito.when(epUserAppsQuery.setParameter("roleId",15l)).thenReturn(epUserAppsQuery);
462                 Mockito.doReturn(mockUserRolesList).when(epUserAppsQuery).list();
463
464                 Mockito.when(session.createQuery("from " + FunctionalMenuRole.class.getName() + " where roleId=" + 15l))
465                                 .thenReturn(epFunctionalMenuQuery);
466                 Mockito.doReturn(mockFunctionalMenuRolesList).when(epFunctionalMenuQuery).list();
467
468                 Mockito.when(session.createQuery("from " + FunctionalMenuRole.class.getName() + " where menuId=" + 10l))
469                                 .thenReturn(epFunctionalMenuQuery2);
470                 Mockito.doReturn(mockFunctionalMenuRolesList).when(epFunctionalMenuQuery2).list();
471
472                 Mockito.when(session.createQuery("from " + FunctionalMenuItem.class.getName() + " where menuId=" + 10l))
473                                 .thenReturn(epFunctionalMenuItemQuery);
474                 Mockito.doReturn(mockFunctionalMenuItemList).when(epFunctionalMenuItemQuery).list();
475                 List<EcompRole> mockEcompRoleList2 = new ArrayList<>();
476                 EcompRole mockUserAppRoles = new EcompRole();
477                 mockUserAppRoles.setId(333l);
478                 mockUserAppRoles.setName("test1");
479                 EcompRole mockUserAppRoles2 = new EcompRole();
480                 mockUserAppRoles2.setId(777l);
481                 mockUserAppRoles2.setName("test2");
482                 mockEcompRoleList2.add(mockUserAppRoles);
483                 mockEcompRoleList2.add(mockUserAppRoles2);
484                 EcompRole[] mockEcompRoleArray2 = mockEcompRoleList2.toArray(new EcompRole[mockEcompRoleList2.size()]);
485                 Mockito.when(applicationsRestClientService.get(EcompRole[].class, mockApp.getId(),
486                                 String.format("/user/%s/roles", user.getOrgUserId()))).thenReturn(mockEcompRoleArray2);
487                 // SyncUserRoleTest
488                 Mockito.when(session
489                                 .createQuery("from " + EPUser.class.getName() + " where orgUserId='" + user.getOrgUserId() + "'"))
490                                 .thenReturn(epUserListQuery);
491                 Mockito.doReturn(mockEpUserList).when(epUserListQuery).list();
492
493                 List<EPUserApp> mockUserRolesList2 = new ArrayList<>();
494                 EPUserApp mockEpUserAppRoles = new EPUserApp();
495                 mockEpUserAppRoles.setApp(mockApp);
496                 mockEpUserAppRoles.setRole(mockEpRole3);
497                 mockEpUserAppRoles.setUserId(user.getId());
498                 mockUserRolesList2.add(mockEpUserAppRoles);
499                 Mockito.when(session.createQuery(
500                                 "from org.onap.portalapp.portal.domain.EPUserApp where app.id=2 and role.active = 'Y' and userId=2"))
501                                 .thenReturn(epUserRolesListQuery);
502                 Mockito.doReturn(mockUserRolesList2).when(epUserRolesListQuery).list();
503                 List<RoleInAppForUser> roleInAppForUser = userRolesCommonServiceImpl.getAppRolesForUser(2l, user.getOrgUserId(),
504                                 true, user);
505                 assertEquals(roleInAppForUser, mockRoleInAppForUserList);
506         }
507
508         @SuppressWarnings("unchecked")
509         @Test
510         public void setAppWithUserRoleStateForUserTestForCentralizedAppForPortal() throws Exception {
511                 PowerMockito.mockStatic(SystemProperties.class);
512                 PowerMockito.mockStatic(EcompPortalUtils.class);
513                 PowerMockito.mockStatic(EPCommonSystemProperties.class);
514                 PowerMockito.mockStatic(PortalConstants.class);
515                 EPUser user = mockUser.mockEPUser();
516                 user.setId(2l);
517                 List<EPUser> mockEpUserList = new ArrayList<>();
518                 mockEpUserList.add(user);
519                 EPApp mockApp = mockApp();
520                 mockApp.setNameSpace("com.test.com");
521                 mockApp.setId(1l);
522                 mockApp.setCentralAuth(true);
523                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
524                 Mockito.when(EcompPortalUtils.checkIfRemoteCentralAccessAllowed()).thenReturn(true);
525                 AppWithRolesForUser mockWithRolesForUser = new AppWithRolesForUser();
526                 List<RoleInAppForUser> mockRoleInAppForUserList = new ArrayList<>();
527                 RoleInAppForUser mockRoleInAppForUser = new RoleInAppForUser();
528                 mockRoleInAppForUser.setIsApplied(true);
529                 mockRoleInAppForUser.setRoleId(1l);
530                 mockRoleInAppForUser.setRoleName("test1");
531                 RoleInAppForUser mockRoleInAppForUser2 = new RoleInAppForUser();
532                 mockRoleInAppForUser2.setIsApplied(true);
533                 mockRoleInAppForUser2.setRoleId(1000l);
534                 mockRoleInAppForUser2.setRoleName("test3");
535                 mockRoleInAppForUserList.add(mockRoleInAppForUser);
536                 mockRoleInAppForUserList.add(mockRoleInAppForUser2);
537                 mockWithRolesForUser.setAppId(mockApp.getId());
538                 mockWithRolesForUser.setAppName(mockApp.getName());
539                 mockWithRolesForUser.setOrgUserId(user.getOrgUserId());
540                 mockWithRolesForUser.setAppRoles(mockRoleInAppForUserList);
541                 List<EPUserAppRolesRequest> mockEpRequestIdValList = new ArrayList<EPUserAppRolesRequest>();
542                 Set<EPUserAppRolesRequestDetail> mockEpUserAppRolesRequestDetailList = new TreeSet<>();
543                 EPUserAppRolesRequestDetail mockEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
544                 mockEpUserAppRolesRequestDetail.setId(2l);
545                 mockEpUserAppRolesRequestDetail.setReqType("P");
546                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
547                 EPUserAppRolesRequest mockEPUserAppRolesRequest = new EPUserAppRolesRequest();
548                 mockEPUserAppRolesRequest.setAppId(mockApp.getId());
549                 mockEPUserAppRolesRequest.setId(1l);
550                 mockEPUserAppRolesRequest.setRequestStatus("P");
551                 mockEPUserAppRolesRequest.setUserId(user.getId());
552                 mockEPUserAppRolesRequest.setEpRequestIdDetail(mockEpUserAppRolesRequestDetailList);
553                 mockEpRequestIdValList.add(mockEPUserAppRolesRequest);
554                 mockEpUserAppRolesRequestDetail.setEpRequestIdData(mockEPUserAppRolesRequest);
555                 mockEpUserAppRolesRequestDetailList.add(mockEpUserAppRolesRequestDetail);
556
557                 // Update Requests if any requests are pending
558                 final Map<String, Long> params = new HashMap<>();
559                 params.put("appId", mockApp.getId());
560                 params.put("userId", user.getId());
561                 Mockito.when((List<EPUserAppRolesRequest>) dataAccessService.executeNamedQuery("userAppRolesRequestList",
562                                 params, null)).thenReturn(mockEpRequestIdValList);
563                 mockEPUserAppRolesRequest.setUpdatedDate(new Date());
564                 mockEPUserAppRolesRequest.setRequestStatus("O");
565                 HashMap<String, Long> additionalUpdateParam = new HashMap<String, Long>();
566                 Mockito.doNothing().when(dataAccessService).saveDomainObject(mockEPUserAppRolesRequest, additionalUpdateParam);
567                 List<EPUserAppRolesRequestDetail> mockGetEpUserAppRolesRequestDetailList = new ArrayList<EPUserAppRolesRequestDetail>();
568                 EPUserAppRolesRequestDetail mockGetEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
569                 mockEpUserAppRolesRequestDetail.setId(2l);
570                 mockEpUserAppRolesRequestDetail.setReqType("P");
571                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
572                 mockGetEpUserAppRolesRequestDetailList.add(mockGetEpUserAppRolesRequestDetail);
573                 // Updates in External Auth System
574                 final Map<String, String> userParams = new HashMap<>();
575                 userParams.put("orgUserIdValue", user.getOrgUserId());
576                 Mockito.when((List<EPUser>) dataAccessService.executeNamedQuery("epUserAppId", userParams, null))
577                                 .thenReturn(mockEpUserList);
578                 PowerMockito
579                                 .when(EPCommonSystemProperties
580                                                 .containsProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
581                                 .thenReturn(true);
582                 PowerMockito.when(SystemProperties.getProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
583                                 .thenReturn("@test.com");
584                 HttpHeaders headers = new HttpHeaders();
585                 Mockito.when(EcompPortalUtils.base64encodeKeyForAAFBasicAuth()).thenReturn(headers);
586                 JSONObject mockJsonObject1 = new JSONObject();
587                 JSONObject mockJsonObject2 = new JSONObject();
588                 JSONObject mockJsonObject3 = new JSONObject();
589                 mockJsonObject1.put("name", "com.test.com.test1");
590                 mockJsonObject2.put("name", "com.test.com.test2");
591                 List<JSONObject> mockJson = new ArrayList<>();
592                 mockJson.add(mockJsonObject1);
593                 mockJson.add(mockJsonObject2);
594                 mockJsonObject3.put("role", mockJson);
595                 ResponseEntity<String> getResponse = new ResponseEntity<>(mockJsonObject3.toString(), HttpStatus.OK);
596                 Mockito.when(externalAccessRolesServiceImpl.getUserRolesFromExtAuthSystem(Matchers.anyString(), Matchers.any(HttpEntity.class))).thenReturn(getResponse);
597                 EPRole mockEPRole = new EPRole();
598                 mockEPRole.setActive(true);
599                 mockEPRole.setAppId(null);
600                 mockEPRole.setAppRoleId(null);
601                 mockEPRole.setId(1l);
602                 mockEPRole.setName("test1");
603                 EPRole mockEPRole2 = new EPRole();
604                 mockEPRole2.setActive(true);
605                 mockEPRole2.setAppId(null);
606                 mockEPRole2.setAppRoleId(null);
607                 mockEPRole2.setId(16l);
608                 mockEPRole2.setName("test2");
609                 EPRole mockEPRole3 = new EPRole();
610                 mockEPRole3.setActive(true);
611                 mockEPRole3.setAppId(null);
612                 mockEPRole3.setAppRoleId(null);
613                 mockEPRole3.setId(1000l);
614                 mockEPRole3.setName("test3");
615                 Map<String, EPRole> mockEPRoleList = new HashMap<>();
616                 mockEPRoleList.put("test1", mockEPRole);
617                 mockEPRoleList.put("test2", mockEPRole2);
618                 mockEPRoleList.put("test3", mockEPRole3);
619                 Mockito.when(externalAccessRolesServiceImpl.getAppRoleNamesWithUnderscoreMap(mockApp)).thenReturn(mockEPRoleList);
620                 final Map<String, Long> params2 = new HashMap<>();
621                 params2.put("appId", mockApp.getId());
622                 params2.put("userId", user.getId());
623                 List<EcompUserAppRoles> mockEPuserAppList = getCurrentUserRoles(user, mockApp);
624                 Mockito.when(dataAccessService.executeNamedQuery("getUserAppExistingRoles", params2, null))
625                                 .thenReturn(mockEPuserAppList);
626                 final Map<String, Long> epDetailParams = new HashMap<>();
627                 epDetailParams.put("reqId", mockEPUserAppRolesRequest.getId());
628                 Mockito.when(dataAccessService.executeNamedQuery("userAppRolesRequestDetailList", epDetailParams, null))
629                                 .thenReturn(mockGetEpUserAppRolesRequestDetailList);
630
631                 ResponseEntity<String> addResponse = new ResponseEntity<>(HttpStatus.CREATED);
632                 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.POST),
633                                 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(addResponse);
634
635                 ResponseEntity<String> deleteResponse = new ResponseEntity<>(HttpStatus.OK);
636                 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.DELETE),
637                                 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(deleteResponse);
638
639                 // Updates in EP DB
640                 Query epsetAppWithUserRoleGetUserQuery = Mockito.mock(Query.class);
641                 Query epsetAppWithUserRoleGetUserAppsQuery = Mockito.mock(Query.class);
642                 Query epsetAppWithUserRoleGetRolesQuery = Mockito.mock(Query.class);
643                 SQLQuery epsetAppWithUserRoleUpdateEPRoleQuery = Mockito.mock(SQLQuery.class);
644                 Mockito.when(session.get(EPApp.class, mockApp.getId())).thenReturn(mockApp);
645                 Mockito.when(session
646                                 .createQuery("from " + EPUser.class.getName() + " where orgUserId='" + user.getOrgUserId() + "'"))
647                                 .thenReturn(epsetAppWithUserRoleGetUserQuery);
648                 Mockito.doReturn(mockEpUserList).when(epsetAppWithUserRoleGetUserQuery).list();
649                 List<EPUserApp> mockUserRolesList2 = new ArrayList<>();
650                 EPUserApp mockEpUserAppRoles = new EPUserApp();
651                 mockEpUserAppRoles.setApp(mockApp);
652                 mockEpUserAppRoles.setRole(mockEPRole);
653                 mockEpUserAppRoles.setUserId(user.getId());
654                 mockUserRolesList2.add(mockEpUserAppRoles);
655                 Mockito.when(session.createQuery(
656                                 "from org.onap.portalapp.portal.domain.EPUserApp where app.id=1 and role.active = 'Y' and userId=2"))
657                                 .thenReturn(epsetAppWithUserRoleGetUserAppsQuery);
658                 Mockito.doReturn(mockUserRolesList2).when(epsetAppWithUserRoleGetUserAppsQuery).list();
659                 List<EPRole> mockEPRoles = new ArrayList<>();
660                 mockEPRoles.add(mockEPRole2);
661                 mockEPRoles.add(mockEPRole3);
662                 Mockito.when(session.createQuery("from " + EPRole.class.getName() + " where appId is null and id != 1"))
663                                 .thenReturn(epsetAppWithUserRoleGetRolesQuery);
664                 Mockito.doReturn(mockEPRoles).when(epsetAppWithUserRoleGetRolesQuery).list();
665                 Mockito.when(session.createSQLQuery("update fn_role set app_id = null where app_id = 1 "))
666                                 .thenReturn(epsetAppWithUserRoleUpdateEPRoleQuery);
667                 ExternalRequestFieldsValidator actual = userRolesCommonServiceImpl.setAppWithUserRoleStateForUser(user, mockWithRolesForUser);
668                 assertTrue(actual.isResult());
669         }
670
671         private List<EcompUserAppRoles> getCurrentUserRoles(EPUser user, EPApp mockApp) {
672                 List<EcompUserAppRoles> mockEPuserAppList = new ArrayList<>();
673                 EcompUserAppRoles mockEcompUserAppRoles = new EcompUserAppRoles();
674                 mockEcompUserAppRoles.setAppId(String.valueOf(mockApp.getId()));
675                 mockEcompUserAppRoles.setRoleId(1l);
676                 mockEcompUserAppRoles.setRoleName("test1");
677                 mockEcompUserAppRoles.setUserId(user.getId());
678                 mockEPuserAppList.add(mockEcompUserAppRoles);
679                 return mockEPuserAppList;
680         }
681
682         @SuppressWarnings("unchecked")
683         @Test
684         public void setAppWithUserRoleStateForUserTestForNonCentralizedApp() throws Exception {
685                 PowerMockito.mockStatic(SystemProperties.class);
686                 PowerMockito.mockStatic(EcompPortalUtils.class);
687                 PowerMockito.mockStatic(EPCommonSystemProperties.class);
688                 PowerMockito.mockStatic(PortalConstants.class);
689                 EPUser user = mockUser.mockEPUser();
690                 user.setId(2l);
691                 List<EPUser> mockEpUserList = new ArrayList<>();
692                 mockEpUserList.add(user);
693                 EPApp mockApp = mockApp();
694                 mockApp.setNameSpace("com.test.com");
695                 mockApp.setId(2l);
696                 mockApp.setCentralAuth(false);
697                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
698                 Mockito.when(EcompPortalUtils.checkIfRemoteCentralAccessAllowed()).thenReturn(true);
699                 AppWithRolesForUser mockWithRolesForUser = new AppWithRolesForUser();
700                 List<RoleInAppForUser> mockRoleInAppForUserList = new ArrayList<>();
701                 RoleInAppForUser mockRoleInAppForUser = new RoleInAppForUser();
702                 mockRoleInAppForUser.setIsApplied(true);
703                 mockRoleInAppForUser.setRoleId(1l);
704                 mockRoleInAppForUser.setRoleName("test1");
705                 RoleInAppForUser mockRoleInAppForUser2 = new RoleInAppForUser();
706                 mockRoleInAppForUser2.setIsApplied(true);
707                 mockRoleInAppForUser2.setRoleId(1000l);
708                 mockRoleInAppForUser2.setRoleName("test3");
709                 mockRoleInAppForUserList.add(mockRoleInAppForUser);
710                 mockRoleInAppForUserList.add(mockRoleInAppForUser2);
711                 mockWithRolesForUser.setAppId(mockApp.getId());
712                 mockWithRolesForUser.setAppName(mockApp.getName());
713                 mockWithRolesForUser.setOrgUserId(user.getOrgUserId());
714                 mockWithRolesForUser.setAppRoles(mockRoleInAppForUserList);
715                 List<EPUserAppRolesRequest> mockEpRequestIdValList = new ArrayList<EPUserAppRolesRequest>();
716                 Set<EPUserAppRolesRequestDetail> mockEpUserAppRolesRequestDetailList = new TreeSet<>();
717                 EPUserAppRolesRequestDetail mockEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
718                 mockEpUserAppRolesRequestDetail.setId(2l);
719                 mockEpUserAppRolesRequestDetail.setReqType("P");
720                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
721                 EPUserAppRolesRequest mockEPUserAppRolesRequest = new EPUserAppRolesRequest();
722                 mockEPUserAppRolesRequest.setAppId(mockApp.getId());
723                 mockEPUserAppRolesRequest.setId(1l);
724                 mockEPUserAppRolesRequest.setRequestStatus("P");
725                 mockEPUserAppRolesRequest.setUserId(user.getId());
726                 mockEPUserAppRolesRequest.setEpRequestIdDetail(mockEpUserAppRolesRequestDetailList);
727                 mockEpRequestIdValList.add(mockEPUserAppRolesRequest);
728                 mockEpUserAppRolesRequestDetail.setEpRequestIdData(mockEPUserAppRolesRequest);
729                 mockEpUserAppRolesRequestDetailList.add(mockEpUserAppRolesRequestDetail);
730
731                 // Update Requests if any requests are pending
732                 final Map<String, Long> params = new HashMap<>();
733                 params.put("appId", mockApp.getId());
734                 params.put("userId", user.getId());
735                 Mockito.when((List<EPUserAppRolesRequest>) dataAccessService.executeNamedQuery("userAppRolesRequestList",
736                                 params, null)).thenReturn(mockEpRequestIdValList);
737                 mockEPUserAppRolesRequest.setUpdatedDate(new Date());
738                 mockEPUserAppRolesRequest.setRequestStatus("O");
739                 HashMap<String, Long> additionalUpdateParam = new HashMap<String, Long>();
740                 Mockito.doNothing().when(dataAccessService).saveDomainObject(mockEPUserAppRolesRequest, additionalUpdateParam);
741                 List<EPUserAppRolesRequestDetail> mockGetEpUserAppRolesRequestDetailList = new ArrayList<EPUserAppRolesRequestDetail>();
742                 EPUserAppRolesRequestDetail mockGetEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
743                 mockEpUserAppRolesRequestDetail.setId(2l);
744                 mockEpUserAppRolesRequestDetail.setReqType("P");
745                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
746                 mockGetEpUserAppRolesRequestDetailList.add(mockGetEpUserAppRolesRequestDetail);
747                 final Map<String, Long> epDetailParams = new HashMap<>();
748                 epDetailParams.put("reqId", mockEPUserAppRolesRequest.getId());
749
750                 final Map<String, String> userParams = new HashMap<>();
751                 userParams.put("orgUserIdValue", user.getOrgUserId());
752                 Mockito.when((List<EPUser>) dataAccessService.executeNamedQuery("epUserAppId", userParams, null))
753                                 .thenReturn(mockEpUserList);
754
755                 PowerMockito
756                                 .when(EPCommonSystemProperties
757                                                 .containsProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
758                                 .thenReturn(true);
759                 PowerMockito.when(SystemProperties.getProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
760                                 .thenReturn("@test.com");
761                 HttpHeaders headers = new HttpHeaders();
762                 Mockito.when(EcompPortalUtils.base64encodeKeyForAAFBasicAuth()).thenReturn(headers);
763                 EPRole mockEPRole = new EPRole();
764                 mockEPRole.setActive(true);
765                 mockEPRole.setAppId(2l);
766                 mockEPRole.setAppRoleId(null);
767                 mockEPRole.setId(10l);
768                 mockEPRole.setAppRoleId(1l);
769                 mockEPRole.setName("test1");
770                 EPRole mockEPRole2 = new EPRole();
771                 mockEPRole2.setActive(true);
772                 mockEPRole2.setAppId(2l);
773                 mockEPRole2.setAppRoleId(null);
774                 mockEPRole2.setId(160l);
775                 mockEPRole2.setName("test2");
776                 mockEPRole2.setAppRoleId(16l);
777                 EPRole mockEPRole3 = new EPRole();
778                 mockEPRole3.setActive(true);
779                 mockEPRole3.setAppId(2l);
780                 mockEPRole3.setAppRoleId(null);
781                 mockEPRole3.setId(1100l);
782                 mockEPRole3.setAppRoleId(100l);
783                 mockEPRole3.setName("test3");
784                 Mockito.when(applicationsRestClientService.get(EPUser.class, mockApp.getId(),
785                                 String.format("/user/%s", user.getOrgUserId()), true)).thenReturn(user);
786                 // Updates in EP DB
787                 Query epsetAppWithUserRoleNonCentralizedGetUserQuery = Mockito.mock(Query.class);
788                 Query epsetAppWithUserRoleNonCentralizedGetUserAppsQuery = Mockito.mock(Query.class);
789                 Query epsetAppWithUserRoleNonCentralizedGetRolesQuery = Mockito.mock(Query.class);
790                 Mockito.when(session.get(EPApp.class, mockApp.getId())).thenReturn(mockApp);
791                 Mockito.when(session
792                                 .createQuery("from " + EPUser.class.getName() + " where orgUserId='" + user.getOrgUserId() + "'"))
793                                 .thenReturn(epsetAppWithUserRoleNonCentralizedGetUserQuery);
794                 Mockito.doReturn(mockEpUserList).when(epsetAppWithUserRoleNonCentralizedGetUserQuery).list();
795                 List<EPUserApp> mockUserRolesList2 = new ArrayList<>();
796                 EPUserApp mockEpUserAppRoles = new EPUserApp();
797                 mockEpUserAppRoles.setApp(mockApp);
798                 mockEpUserAppRoles.setRole(mockEPRole);
799                 mockEpUserAppRoles.setUserId(user.getId());
800                 mockUserRolesList2.add(mockEpUserAppRoles);
801                 Mockito.when(session.createQuery(
802                                 "from org.onap.portalapp.portal.domain.EPUserApp where app.id=2 and role.active = 'Y' and userId=2"))
803                                 .thenReturn(epsetAppWithUserRoleNonCentralizedGetUserAppsQuery);
804                 Mockito.doReturn(mockUserRolesList2).when(epsetAppWithUserRoleNonCentralizedGetUserAppsQuery).list();
805                 List<EPRole> mockEPRoles = new ArrayList<>();
806                 mockEPRoles.add(mockEPRole2);
807                 mockEPRoles.add(mockEPRole3);
808                 Mockito.when(session.createQuery("from " + EPRole.class.getName() + " where appId=2"))
809                                 .thenReturn(epsetAppWithUserRoleNonCentralizedGetRolesQuery);
810                 Mockito.doReturn(mockEPRoles).when(epsetAppWithUserRoleNonCentralizedGetRolesQuery).list();
811                 ExternalRequestFieldsValidator expected = userRolesCommonServiceImpl.setAppWithUserRoleStateForUser(user, mockWithRolesForUser);
812                 assertEquals(expected.isResult(), false);
813         }
814
815         /*@SuppressWarnings("unchecked")
816         @Test
817         public void setExternalRequestUserAppRoleMerdianCentralizedAppTest() throws Exception {
818                 PowerMockito.mockStatic(SystemProperties.class);
819                 PowerMockito.mockStatic(EcompPortalUtils.class);
820                 PowerMockito.mockStatic(EPCommonSystemProperties.class);
821                 PowerMockito.mockStatic(PortalConstants.class);
822                 EPUser user = mockUser.mockEPUser();
823                 user.setId(2l);
824                 List<EPUser> mockEpUserList = new ArrayList<>();
825                 mockEpUserList.add(user);
826                 EPApp mockApp = mockApp();
827                 mockApp.setNameSpace("com.test.com");
828                 mockApp.setId(1l);
829                 mockApp.setCentralAuth(true);
830                 Mockito.when(EcompPortalUtils.checkIfRemoteCentralAccessAllowed()).thenReturn(true);
831                 ExternalSystemUser externalSystemUser = new ExternalSystemUser();
832                 List<ExternalSystemRoleApproval> mockExternalSystemRoleApprovalList = new ArrayList<>();
833                 ExternalSystemRoleApproval mockExternalSystemRoleApproval = new ExternalSystemRoleApproval();
834                 mockExternalSystemRoleApproval.setRoleName("test1");
835                 ExternalSystemRoleApproval mockExternalSystemRoleApproval2 = new ExternalSystemRoleApproval();
836                 mockExternalSystemRoleApproval2.setRoleName("test2");
837                 mockExternalSystemRoleApprovalList.add(mockExternalSystemRoleApproval);
838                 mockExternalSystemRoleApprovalList.add(mockExternalSystemRoleApproval2);
839                 externalSystemUser.setApplicationName(mockApp.getMlAppName());
840                 externalSystemUser.setLoginId(user.getOrgUserId());
841                 externalSystemUser.setRoles(mockExternalSystemRoleApprovalList);
842                 EPRole mockEPRole = new EPRole();
843                 mockEPRole.setActive(true);
844                 mockEPRole.setAppId(null);
845                 mockEPRole.setAppRoleId(null);
846                 mockEPRole.setId(1l);
847                 mockEPRole.setName("test1");
848                 EPRole mockEPRole2 = new EPRole();
849                 mockEPRole2.setActive(true);
850                 mockEPRole2.setAppId(null);
851                 mockEPRole2.setAppRoleId(null);
852                 mockEPRole2.setId(16l);
853                 mockEPRole2.setName("test2");
854                 EPRole mockEPRole3 = new EPRole();
855                 mockEPRole3.setActive(true);
856                 mockEPRole3.setAppId(null);
857                 mockEPRole3.setAppRoleId(null);
858                 mockEPRole3.setId(1000l);
859                 mockEPRole3.setName("test3");
860
861                 Mockito.when(epAppCommonServiceImpl.getAppDetail(mockApp.getMlAppName())).thenReturn(mockApp);
862                 final Map<String, String> userParams = new HashMap<>();
863                 userParams.put("orgUserIdValue", user.getOrgUserId());
864                 Mockito.when((List<EPUser>) dataAccessService.executeNamedQuery("epUserAppId", userParams, null))
865                                 .thenReturn(mockEpUserList);
866
867                 List<EPUserAppRolesRequest> mockMerdianEpRequestIdValList = new ArrayList<EPUserAppRolesRequest>();
868                 Set<EPUserAppRolesRequestDetail> mockEpUserAppRolesRequestDetailList = new TreeSet<>();
869                 EPUserAppRolesRequestDetail mockEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
870                 mockEpUserAppRolesRequestDetail.setId(2l);
871                 mockEpUserAppRolesRequestDetail.setReqType("P");
872                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
873                 EPUserAppRolesRequest mockEPUserAppRolesRequest = new EPUserAppRolesRequest();
874                 mockEPUserAppRolesRequest.setAppId(mockApp.getId());
875                 mockEPUserAppRolesRequest.setId(1l);
876                 mockEPUserAppRolesRequest.setRequestStatus("P");
877                 mockEPUserAppRolesRequest.setUserId(user.getId());
878                 mockEPUserAppRolesRequest.setEpRequestIdDetail(mockEpUserAppRolesRequestDetailList);
879                 mockMerdianEpRequestIdValList.add(mockEPUserAppRolesRequest);
880                 mockEpUserAppRolesRequestDetail.setEpRequestIdData(mockEPUserAppRolesRequest);
881                 mockEpUserAppRolesRequestDetailList.add(mockEpUserAppRolesRequestDetail);
882
883                 final Map<String, Long> params = new HashMap<>();
884                 params.put("appId", mockApp.getId());
885                 params.put("userId", user.getId());
886                 Mockito.when((List<EPUserAppRolesRequest>) dataAccessService.executeNamedQuery("userAppRolesRequestList",
887                                 params, null)).thenReturn(mockMerdianEpRequestIdValList);
888                 RoleInAppForUser mockRoleInAppForUser1 = new RoleInAppForUser();
889                 mockRoleInAppForUser1.setIsApplied(true);
890                 mockRoleInAppForUser1.setRoleId(1l);
891                 mockRoleInAppForUser1.setRoleName("test1");
892                 RoleInAppForUser mockRoleInAppForUser2 = new RoleInAppForUser();
893                 mockRoleInAppForUser2.setIsApplied(true);
894                 mockRoleInAppForUser2.setRoleId(16l);
895                 mockRoleInAppForUser2.setRoleName("test2");
896                 Mockito.when(epRoleServiceImpl.getAppRole(mockExternalSystemRoleApproval.getRoleName(), mockApp.getId()))
897                                 .thenReturn(mockEPRole);
898                 Mockito.when(epRoleServiceImpl.getAppRole(mockExternalSystemRoleApproval2.getRoleName(), mockApp.getId()))
899                                 .thenReturn(mockEPRole2);
900                 List<EcompUserAppRoles> mockEPuserAppList = getCurrentUserRoles(user, mockApp);
901                 final Map<String, Long> params2 = new HashMap<>();
902                 params2.put("userId", user.getId());
903                 params2.put("appId", mockApp.getId());
904                 Mockito.when(dataAccessService.executeNamedQuery("getUserAppExistingRoles", params2, null))
905                                 .thenReturn(mockEPuserAppList);
906                 // Updates in External Auth System
907                 List<EPUserAppRolesRequestDetail> mockGetEpUserAppRolesRequestDetailList = new ArrayList<EPUserAppRolesRequestDetail>();
908                 EPUserAppRolesRequestDetail mockGetEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
909                 mockEpUserAppRolesRequestDetail.setId(2l);
910                 mockEpUserAppRolesRequestDetail.setReqType("P");
911                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
912                 mockGetEpUserAppRolesRequestDetailList.add(mockGetEpUserAppRolesRequestDetail);
913                 final Map<String, String> userParams2 = new HashMap<>();
914                 userParams2.put("orgUserIdValue", user.getOrgUserId());
915                 Mockito.when((List<EPUser>) dataAccessService.executeNamedQuery("epUserAppId", userParams2, null))
916                                 .thenReturn(mockEpUserList);
917                 PowerMockito
918                                 .when(EPCommonSystemProperties
919                                                 .containsProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
920                                 .thenReturn(true);
921                 PowerMockito.when(SystemProperties.getProperty(EPCommonSystemProperties.EXTERNAL_CENTRAL_ACCESS_USER_DOMAIN))
922                                 .thenReturn("@test.com");
923                 HttpHeaders headers = new HttpHeaders();
924                 Mockito.when(EcompPortalUtils.base64encodeKeyForAAFBasicAuth()).thenReturn(headers);
925                 JSONObject mockJsonObject1 = new JSONObject();
926                 JSONObject mockJsonObject2 = new JSONObject();
927                 JSONObject mockJsonObject3 = new JSONObject();
928                 mockJsonObject1.put("name", "com.test.com.test1");
929                 mockJsonObject2.put("name", "com.test.com.test2");
930                 List<JSONObject> mockJson = new ArrayList<>();
931                 mockJson.add(mockJsonObject1);
932                 mockJson.add(mockJsonObject2);
933                 mockJsonObject3.put("role", mockJson);
934                 ResponseEntity<String> getResponse = new ResponseEntity<>(mockJsonObject3.toString(), HttpStatus.OK);
935                 Mockito.when(externalAccessRolesServiceImpl.getUserRolesFromExtAuthSystem(Matchers.anyString(), Matchers.any(HttpEntity.class))).thenReturn(getResponse);
936                 Map<String, EPRole> mockEPRoleList = new HashMap<>();
937                 mockEPRoleList.put("test1", mockEPRole);
938                 mockEPRoleList.put("test2", mockEPRole2);
939                 mockEPRoleList.put("test3", mockEPRole3);
940                 Mockito.when(externalAccessRolesServiceImpl.getAppRoleNamesWithUnderscoreMap(mockApp)).thenReturn(mockEPRoleList);
941                 ResponseEntity<String> addResponse = new ResponseEntity<>(HttpStatus.CREATED);
942                 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.POST),
943                                 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(addResponse);
944
945                 ResponseEntity<String> deleteResponse = new ResponseEntity<>(HttpStatus.OK);
946                 Mockito.when(template.exchange(Matchers.anyString(), Matchers.eq(HttpMethod.DELETE),
947                                 Matchers.<HttpEntity<String>>any(), Matchers.eq(String.class))).thenReturn(deleteResponse);
948                 // Updated in EP DB
949                 Query epsetExternalRequestUserAppRoleGetUserQuery = Mockito.mock(Query.class);
950                 Query epsetExternalRequestUserAppRoleGetUserAppsQuery = Mockito.mock(Query.class);
951                 Query epsetExternalRequestUserAppRoleGetRolesQuery = Mockito.mock(Query.class);
952                 SQLQuery epsetAppWithUserRoleUpdateEPRoleQuery = Mockito.mock(SQLQuery.class);
953                 Mockito.when(session.get(EPApp.class, mockApp.getId())).thenReturn(mockApp);
954                 Mockito.when(session
955                                 .createQuery("from " + EPUser.class.getName() + " where orgUserId='" + user.getOrgUserId() + "'"))
956                                 .thenReturn(epsetExternalRequestUserAppRoleGetUserQuery);
957                 Mockito.doReturn(mockEpUserList).when(epsetExternalRequestUserAppRoleGetUserQuery).list();
958                 List<EPUserApp> mockUserRolesList2 = new ArrayList<>();
959                 EPUserApp mockEpUserAppRoles = new EPUserApp();
960                 mockEpUserAppRoles.setApp(mockApp);
961                 mockEpUserAppRoles.setRole(mockEPRole);
962                 mockEpUserAppRoles.setUserId(user.getId());
963                 mockUserRolesList2.add(mockEpUserAppRoles);
964                 Mockito.when(session.createQuery(
965                                 "from org.onap.portalapp.portal.domain.EPUserApp where app.id=1 and role.active = 'Y' and userId=2"))
966                                 .thenReturn(epsetExternalRequestUserAppRoleGetUserAppsQuery);
967                 Mockito.doReturn(mockUserRolesList2).when(epsetExternalRequestUserAppRoleGetUserAppsQuery).list();
968                 List<EPRole> mockEPRoles = new ArrayList<>();
969                 mockEPRoles.add(mockEPRole2);
970                 mockEPRoles.add(mockEPRole3);
971                 Mockito.when(session.createQuery("from org.onap.portalapp.portal.domain.EPRole where appId is null "))
972                                 .thenReturn(epsetExternalRequestUserAppRoleGetRolesQuery);
973                 Mockito.doReturn(mockEPRoles).when(epsetExternalRequestUserAppRoleGetRolesQuery).list();
974                 Mockito.when(session.createSQLQuery("update fn_role set app_id = null where app_id = 1 "))
975                                 .thenReturn(epsetAppWithUserRoleUpdateEPRoleQuery);
976
977                 ExternalRequestFieldsValidator mockExternalRequestFieldsValidator = new ExternalRequestFieldsValidator(true,
978                                 "Updated Successfully");
979                 ExternalRequestFieldsValidator externalRequestFieldsValidator = userRolesCommonServiceImpl
980                                 .setExternalRequestUserAppRole(externalSystemUser, "POST");
981                 assertTrue(mockExternalRequestFieldsValidator.equals(externalRequestFieldsValidator));
982         }
983 */
984         @SuppressWarnings("unchecked")
985         @Test
986         public void setExternalRequestUserAppRoleMerdianNonCentralizedAppTest() throws Exception {
987                 PowerMockito.mockStatic(SystemProperties.class);
988                 PowerMockito.mockStatic(EPCommonSystemProperties.class);
989                 PowerMockito.mockStatic(PortalConstants.class);
990                 EPUser user = mockUser.mockEPUser();
991                 user.setId(2l);
992                 List<EPUser> mockEpUserList = new ArrayList<>();
993                 mockEpUserList.add(user);
994                 EPApp mockApp = mockApp();
995                 mockApp.setId(2l);
996                 mockApp.setEnabled(true);
997                 mockApp.setCentralAuth(false);
998                 ExternalSystemUser externalSystemUser = new ExternalSystemUser();
999                 List<ExternalSystemRoleApproval> mockExternalSystemRoleApprovalList = new ArrayList<>();
1000                 ExternalSystemRoleApproval mockExternalSystemRoleApproval = new ExternalSystemRoleApproval();
1001                 mockExternalSystemRoleApproval.setRoleName("test1");
1002                 ExternalSystemRoleApproval mockExternalSystemRoleApproval2 = new ExternalSystemRoleApproval();
1003                 mockExternalSystemRoleApproval2.setRoleName("test2");
1004                 mockExternalSystemRoleApprovalList.add(mockExternalSystemRoleApproval);
1005                 mockExternalSystemRoleApprovalList.add(mockExternalSystemRoleApproval2);
1006                 externalSystemUser.setApplicationName(mockApp.getMlAppName());
1007                 externalSystemUser.setLoginId(user.getOrgUserId());
1008                 externalSystemUser.setRoles(mockExternalSystemRoleApprovalList);
1009
1010                 EPRole mockEPRole = new EPRole();
1011                 mockEPRole.setActive(true);
1012                 mockEPRole.setAppId(2l);
1013                 mockEPRole.setAppRoleId(1l);
1014                 mockEPRole.setId(1000l);
1015                 mockEPRole.setName("test1");
1016                 EPRole mockEPRole2 = new EPRole();
1017                 mockEPRole2.setActive(true);
1018                 mockEPRole2.setAppId(2l);
1019                 mockEPRole2.setAppRoleId(16l);
1020                 mockEPRole2.setId(160l);
1021                 mockEPRole2.setName("test2");
1022                 EPRole mockEPRole3 = new EPRole();
1023                 mockEPRole3.setActive(true);
1024                 mockEPRole3.setAppId(2l);
1025                 mockEPRole3.setAppRoleId(10l);
1026                 mockEPRole3.setId(100l);
1027                 mockEPRole3.setName("test3");
1028
1029                 Mockito.when(epAppCommonServiceImpl.getAppDetail(mockApp.getMlAppName())).thenReturn(mockApp);
1030                 final Map<String, String> userParams = new HashMap<>();
1031                 userParams.put("orgUserIdValue", user.getOrgUserId());
1032                 Mockito.when((List<EPUser>) dataAccessService.executeNamedQuery("epUserAppId", userParams, null))
1033                                 .thenReturn(mockEpUserList);
1034
1035                 List<EPUserAppRolesRequest> mockMerdianEpRequestIdValList = new ArrayList<EPUserAppRolesRequest>();
1036                 Set<EPUserAppRolesRequestDetail> mockEpUserAppRolesRequestDetailList = new TreeSet<>();
1037                 EPUserAppRolesRequestDetail mockEpUserAppRolesRequestDetail = new EPUserAppRolesRequestDetail();
1038                 mockEpUserAppRolesRequestDetail.setId(2l);
1039                 mockEpUserAppRolesRequestDetail.setReqType("P");
1040                 mockEpUserAppRolesRequestDetail.setReqRoleId(16l);
1041                 EPUserAppRolesRequest mockEPUserAppRolesRequest = new EPUserAppRolesRequest();
1042                 mockEPUserAppRolesRequest.setAppId(mockApp.getId());
1043                 mockEPUserAppRolesRequest.setId(1l);
1044                 mockEPUserAppRolesRequest.setRequestStatus("P");
1045                 mockEPUserAppRolesRequest.setUserId(user.getId());
1046                 mockEPUserAppRolesRequest.setEpRequestIdDetail(mockEpUserAppRolesRequestDetailList);
1047                 mockMerdianEpRequestIdValList.add(mockEPUserAppRolesRequest);
1048                 mockEpUserAppRolesRequestDetail.setEpRequestIdData(mockEPUserAppRolesRequest);
1049                 mockEpUserAppRolesRequestDetailList.add(mockEpUserAppRolesRequestDetail);
1050
1051                 final Map<String, Long> params = new HashMap<>();
1052                 params.put("appId", mockApp.getId());
1053                 params.put("userId", user.getId());
1054                 Mockito.when((List<EPUserAppRolesRequest>) dataAccessService.executeNamedQuery("userAppRolesRequestList",
1055                                 params, null)).thenReturn(mockMerdianEpRequestIdValList);
1056                 RoleInAppForUser mockRoleInAppForUser1 = new RoleInAppForUser();
1057                 mockRoleInAppForUser1.setIsApplied(true);
1058                 mockRoleInAppForUser1.setRoleId(1l);
1059                 mockRoleInAppForUser1.setRoleName("test1");
1060                 RoleInAppForUser mockRoleInAppForUser2 = new RoleInAppForUser();
1061                 mockRoleInAppForUser2.setIsApplied(true);
1062                 mockRoleInAppForUser2.setRoleId(16l);
1063                 mockRoleInAppForUser2.setRoleName("test2");
1064                 Mockito.when(epRoleServiceImpl.getAppRole(mockExternalSystemRoleApproval.getRoleName(), mockApp.getId()))
1065                                 .thenReturn(mockEPRole);
1066                 Mockito.when(epRoleServiceImpl.getAppRole(mockExternalSystemRoleApproval2.getRoleName(), mockApp.getId()))
1067                                 .thenReturn(mockEPRole2);
1068                 List<EcompUserAppRoles> mockEPuserAppList = new ArrayList<>();
1069                 EcompUserAppRoles mockEcompUserAppRoles = new EcompUserAppRoles();
1070                 mockEcompUserAppRoles.setAppId(String.valueOf(mockApp.getId()));
1071                 mockEcompUserAppRoles.setRoleId(100l);
1072                 mockEcompUserAppRoles.setRoleName("test1");
1073                 mockEcompUserAppRoles.setUserId(user.getId());
1074                 mockEPuserAppList.add(mockEcompUserAppRoles);
1075                 final Map<String, Long> params2 = new HashMap<>();
1076                 params2.put("userId", user.getId());
1077                 params2.put("appId", mockApp.getId());
1078                 Mockito.when(dataAccessService.executeNamedQuery("getUserAppExistingRoles", params2, null))
1079                                 .thenReturn(mockEPuserAppList);
1080                 List<EcompRole> mockEcompRoleList = new ArrayList<>();
1081                 EcompRole mockEcompRole = new EcompRole();
1082                 mockEcompRole.setId(1l);
1083                 mockEcompRole.setName("test1");
1084                 EcompRole mockEcompRole2 = new EcompRole();
1085                 mockEcompRole2.setId(16l);
1086                 mockEcompRole2.setName("test2");
1087                 mockEcompRoleList.add(mockEcompRole);
1088                 mockEcompRoleList.add(mockEcompRole2);
1089                 EcompRole[] mockEcompRoleArray = mockEcompRoleList.toArray(new EcompRole[mockEcompRoleList.size()]);
1090                 Mockito.when(applicationsRestClientService.get(EcompRole[].class, mockApp.getId(), "/roles"))
1091                                 .thenReturn(mockEcompRoleArray);
1092
1093                 // SyncAppRoles
1094                 List<EPUserApp> mockUserRolesList = new ArrayList<>();
1095                 EPUserApp mockEpUserApp = new EPUserApp();
1096                 mockEpUserApp.setApp(mockApp);
1097                 mockEpUserApp.setRole(mockEPRole2);
1098                 mockEpUserApp.setUserId(user.getId());
1099                 mockUserRolesList.add(mockEpUserApp);
1100                 List<FunctionalMenuRole> mockFunctionalMenuRolesList = new ArrayList<>();
1101                 FunctionalMenuRole mockFunctionalMenuRole = new FunctionalMenuRole();
1102                 mockFunctionalMenuRole.setAppId((int) (long) mockApp.getId());
1103                 mockFunctionalMenuRole.setRoleId((int) (long) 15l);
1104                 mockFunctionalMenuRole.setMenuId(10l);
1105                 mockFunctionalMenuRole.setId(10);
1106                 mockFunctionalMenuRolesList.add(mockFunctionalMenuRole);
1107                 List<FunctionalMenuItem> mockFunctionalMenuItemList = new ArrayList<>();
1108                 FunctionalMenuItem mockFunctionalMenuItem = new FunctionalMenuItem();
1109                 List<Integer> mockRolesList = new ArrayList<>();
1110                 Integer role1 = 1;
1111                 mockRolesList.add(role1);
1112                 mockFunctionalMenuItem.setRestrictedApp(false);
1113                 mockFunctionalMenuItem.setRoles(mockRolesList);
1114                 mockFunctionalMenuItem.setUrl("http://test.com");
1115                 mockFunctionalMenuItemList.add(mockFunctionalMenuItem);
1116                 Query epRoleQuery = Mockito.mock(Query.class);
1117                 Query epUserAppsQuery = Mockito.mock(Query.class);
1118                 Query epFunctionalMenuQuery = Mockito.mock(Query.class);
1119                 Query epFunctionalMenuQuery2 = Mockito.mock(Query.class);
1120                 Query epFunctionalMenuItemQuery = Mockito.mock(Query.class);
1121                 Mockito.when(applicationsRestClientService.get(EcompRole[].class, mockApp.getId(), "/roles"))
1122                                 .thenReturn(mockEcompRoleArray);
1123                 // syncAppRolesTest
1124                 Mockito.when(session.createQuery("from " + EPRole.class.getName() + " where appId=" + mockApp.getId()))
1125                                 .thenReturn(epRoleQuery);
1126                 Mockito.doReturn(mockEcompRoleList).when(epRoleQuery).list();
1127                 Mockito.when(session.createQuery(
1128                                 "from " + EPUserApp.class.getName() + " where app.id=" + mockApp.getId() + " and role_id=" + 100l))
1129                                 .thenReturn(epUserAppsQuery);
1130                 Mockito.doReturn(mockUserRolesList).when(epUserAppsQuery).list();
1131
1132                 Mockito.when(session.createQuery("from " + FunctionalMenuRole.class.getName() + " where roleId=" + 100l))
1133                                 .thenReturn(epFunctionalMenuQuery);
1134                 Mockito.doReturn(mockFunctionalMenuRolesList).when(epFunctionalMenuQuery).list();
1135
1136                 Mockito.when(session.createQuery("from " + FunctionalMenuRole.class.getName() + " where menuId=" + 10l))
1137                                 .thenReturn(epFunctionalMenuQuery2);
1138                 Mockito.doReturn(mockFunctionalMenuRolesList).when(epFunctionalMenuQuery2).list();
1139
1140                 Mockito.when(session.createQuery("from " + FunctionalMenuItem.class.getName() + " where menuId=" + 10l))
1141                                 .thenReturn(epFunctionalMenuItemQuery);
1142                 Mockito.doReturn(mockFunctionalMenuItemList).when(epFunctionalMenuItemQuery).list();
1143
1144                 Mockito.when(applicationsRestClientService.get(EPUser.class, mockApp.getId(),
1145                                 String.format("/user/%s", user.getOrgUserId()), true)).thenReturn(user);
1146                 // Updated in EP DB
1147                 Query epsetExternalRequestUserAppRoleGetUserQuery = Mockito.mock(Query.class);
1148                 Query epsetExternalRequestUserAppRoleGetUserAppsQuery = Mockito.mock(Query.class);
1149                 Query epsetExternalRequestUserAppRoleGetRolesQuery = Mockito.mock(Query.class);
1150                 Mockito.when(session.get(EPApp.class, mockApp.getId())).thenReturn(mockApp);
1151                 Mockito.when(session
1152                                 .createQuery("from " + EPUser.class.getName() + " where orgUserId='" + user.getOrgUserId() + "'"))
1153                                 .thenReturn(epsetExternalRequestUserAppRoleGetUserQuery);
1154                 Mockito.doReturn(mockEpUserList).when(epsetExternalRequestUserAppRoleGetUserQuery).list();
1155                 List<EPUserApp> mockUserRolesList2 = new ArrayList<>();
1156                 EPUserApp mockEpUserAppRoles = new EPUserApp();
1157                 mockEpUserAppRoles.setApp(mockApp);
1158                 mockEpUserAppRoles.setRole(mockEPRole);
1159                 mockEpUserAppRoles.setUserId(user.getId());
1160                 mockUserRolesList2.add(mockEpUserAppRoles);
1161                 Mockito.when(session.createQuery(
1162                                 "from org.onap.portalapp.portal.domain.EPUserApp where app.id=2 and role.active = 'Y' and userId=2"))
1163                                 .thenReturn(epsetExternalRequestUserAppRoleGetUserAppsQuery);
1164                 Mockito.doReturn(mockUserRolesList2).when(epsetExternalRequestUserAppRoleGetUserAppsQuery).list();
1165                 List<EPRole> mockEPRoles = new ArrayList<>();
1166                 mockEPRoles.add(mockEPRole2);
1167                 mockEPRoles.add(mockEPRole3);
1168                 Mockito.when(session.createQuery("from org.onap.portalapp.portal.domain.EPRole where appId=2"))
1169                                 .thenReturn(epsetExternalRequestUserAppRoleGetRolesQuery);
1170                 Mockito.doReturn(mockEPRoles).when(epsetExternalRequestUserAppRoleGetRolesQuery).list();
1171
1172                 ExternalRequestFieldsValidator mockExternalRequestFieldsValidator = new ExternalRequestFieldsValidator(true,
1173                                 "Updated Successfully");
1174                 ExternalRequestFieldsValidator externalRequestFieldsValidator = userRolesCommonServiceImpl
1175                                 .setExternalRequestUserAppRole(externalSystemUser, "POST");
1176                 assertFalse(mockExternalRequestFieldsValidator.equals(externalRequestFieldsValidator));
1177         }
1178
1179         @SuppressWarnings("unchecked")
1180         @Test
1181         public void getUsersFromAppEndpointCentralizedAppTest() throws HTTPException {
1182                 EPApp mockApp = mockApp();
1183                 mockApp.setId(1l);
1184                 mockApp.setEnabled(true);
1185                 mockApp.setCentralAuth(true);
1186                 EPUser user = mockUser.mockEPUser();
1187                 EPUser user2 = mockUser.mockEPUser();
1188                 user2.setActive(true);
1189                 user2.setOrgUserId("guestT2");
1190                 user2.setId(2l);
1191                 user2.setFirstName("Guest2");
1192                 user2.setLastName("Test2");
1193                 user.setId(1l);
1194                 user.setFirstName("Guest");
1195                 user.setLastName("Test");
1196                 EPRole mockEPRole1 = new EPRole();
1197                 mockEPRole1.setId(1l);
1198                 mockEPRole1.setName("test1");
1199                 mockEPRole1.setActive(true);
1200                 EPRole mockEPRole2 = new EPRole();
1201                 mockEPRole2.setId(16l);
1202                 mockEPRole2.setName("test2");
1203                 mockEPRole2.setActive(true);
1204                 SortedSet<EPUserApp> mockUserApps1 = new TreeSet<EPUserApp>();
1205                 EPUserApp mockEPUserApp1 = new EPUserApp();
1206                 mockEPUserApp1.setApp(mockApp);
1207                 mockEPUserApp1.setRole(mockEPRole1);
1208                 mockEPUserApp1.setUserId(1l);
1209                 mockUserApps1.add(mockEPUserApp1);
1210                 user.setEPUserApps(mockUserApps1);
1211                 SortedSet<EPUserApp> mockUserApps2 = new TreeSet<EPUserApp>();
1212                 EPUserApp mockEPUserApp2 = new EPUserApp();
1213                 mockEPUserApp2.setApp(mockApp);
1214                 mockEPUserApp2.setRole(mockEPRole2);
1215                 mockEPUserApp2.setUserId(2l);
1216                 mockUserApps2.add(mockEPUserApp2);
1217                 user2.setEPUserApps(mockUserApps2);
1218                 List<EPUser> mockEpUserList = new ArrayList<>();
1219                 mockEpUserList.add(user);
1220                 mockEpUserList.add(user2);
1221                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
1222                 List<UserApplicationRoles> mockUserApplicationRolesList = new ArrayList<>();
1223                 UserApplicationRoles mockUserApplicationRoles = new UserApplicationRoles();
1224                 List<RemoteRole> mockRemoteRoleList = new ArrayList<>();
1225                 RemoteRole mockRemoteRole = new RemoteRole();
1226                 mockRemoteRole.setId(1l);
1227                 mockRemoteRole.setName("test1");
1228                 mockRemoteRoleList.add(mockRemoteRole);
1229                 mockUserApplicationRoles.setAppId(mockApp.getId());
1230                 mockUserApplicationRoles.setFirstName("Guest");
1231                 mockUserApplicationRoles.setLastName("Test");
1232                 mockUserApplicationRoles.setOrgUserId("guestT");
1233                 mockUserApplicationRoles.setRoles(mockRemoteRoleList);
1234                 UserApplicationRoles mockUserApplicationRoles2 = new UserApplicationRoles();
1235                 List<RemoteRole> mockRemoteRoleList2 = new ArrayList<>();
1236                 RemoteRole mockRemoteRole2 = new RemoteRole();
1237                 mockRemoteRole2.setId(16l);
1238                 mockRemoteRole2.setName("test2");
1239                 mockRemoteRoleList2.add(mockRemoteRole2);
1240                 mockUserApplicationRoles2.setAppId(mockApp.getId());
1241                 mockUserApplicationRoles2.setFirstName("Guest2");
1242                 mockUserApplicationRoles2.setLastName("Test2");
1243                 mockUserApplicationRoles2.setOrgUserId("guestT2");
1244                 mockUserApplicationRoles2.setRoles(mockRemoteRoleList2);
1245                 mockUserApplicationRolesList.add(mockUserApplicationRoles);
1246                 mockUserApplicationRolesList.add(mockUserApplicationRoles2);
1247                 Mockito.when((List<EPUser>) dataAccessService.executeNamedQuery("getActiveUsers", null, null))
1248                                 .thenReturn(mockEpUserList);
1249                 assertEquals(userRolesCommonServiceImpl.getUsersFromAppEndpoint(1l).size(),
1250                                 mockUserApplicationRolesList.size());
1251         }
1252
1253         @Test
1254         public void getUsersFromAppEndpointNonCentralizedAppTest() throws HTTPException, JsonProcessingException {
1255                 EPApp mockApp = mockApp();
1256                 mockApp.setId(2l);
1257                 mockApp.setEnabled(true);
1258                 mockApp.setCentralAuth(false);
1259                 Mockito.when(epAppCommonServiceImpl.getApp(mockApp.getId())).thenReturn(mockApp);
1260                 List<UserApplicationRoles> mockUserApplicationRolesNonCentralizedList = new ArrayList<>();
1261                 UserApplicationRoles mockUserApplicationRoles = new UserApplicationRoles();
1262                 List<RemoteRole> mockRemoteRoleList = new ArrayList<>();
1263                 RemoteRole mockRemoteRole = new RemoteRole();
1264                 mockRemoteRole.setId(1l);
1265                 mockRemoteRole.setName("test1");
1266                 mockRemoteRoleList.add(mockRemoteRole);
1267                 mockUserApplicationRoles.setAppId(mockApp.getId());
1268                 mockUserApplicationRoles.setFirstName("Guest");
1269                 mockUserApplicationRoles.setLastName("Test");
1270                 mockUserApplicationRoles.setOrgUserId("guestT");
1271                 mockUserApplicationRoles.setRoles(mockRemoteRoleList);
1272                 UserApplicationRoles mockUserApplicationRoles2 = new UserApplicationRoles();
1273                 List<RemoteRole> mockRemoteRoleList2 = new ArrayList<>();
1274                 RemoteRole mockRemoteRole2 = new RemoteRole();
1275                 mockRemoteRole2.setId(16l);
1276                 mockRemoteRole2.setName("test2");
1277                 mockRemoteRoleList2.add(mockRemoteRole2);
1278                 mockUserApplicationRoles2.setAppId(mockApp.getId());
1279                 mockUserApplicationRoles2.setFirstName("Guest2");
1280                 mockUserApplicationRoles2.setLastName("Test2");
1281                 mockUserApplicationRoles2.setOrgUserId("guestT2");
1282                 mockUserApplicationRoles2.setRoles(mockRemoteRoleList2);
1283                 mockUserApplicationRolesNonCentralizedList.add(mockUserApplicationRoles);
1284                 mockUserApplicationRolesNonCentralizedList.add(mockUserApplicationRoles2);
1285                 RemoteUserWithRoles mockRemoteUserWithRoles1 = new RemoteUserWithRoles();
1286                 mockRemoteUserWithRoles1.setFirstName("Guest1");
1287                 mockRemoteUserWithRoles1.setLastName("Test1");
1288                 mockRemoteUserWithRoles1.setOrgUserId("guestT");
1289                 mockRemoteUserWithRoles1.setRoles(mockRemoteRoleList);
1290                 RemoteUserWithRoles mockRemoteUserWithRoles2 = new RemoteUserWithRoles();
1291                 mockRemoteUserWithRoles2.setFirstName("Guest2");
1292                 mockRemoteUserWithRoles2.setLastName("Test2");
1293                 mockRemoteUserWithRoles2.setOrgUserId("guestT");
1294                 mockRemoteUserWithRoles2.setRoles(mockRemoteRoleList2);
1295                 List<RemoteUserWithRoles> mockRemoteUserWithRolesList = new ArrayList<>();
1296                 mockRemoteUserWithRolesList.add(mockRemoteUserWithRoles1);
1297                 mockRemoteUserWithRolesList.add(mockRemoteUserWithRoles2);
1298                 ObjectMapper mapper = new ObjectMapper();
1299                 String mockGetRemoteUsersWithRoles = mapper.writeValueAsString(mockRemoteUserWithRolesList);
1300                 Mockito.when(applicationsRestClientService.getIncomingJsonString(mockApp.getId(), "/users"))
1301                                 .thenReturn(mockGetRemoteUsersWithRoles);
1302                 List<UserApplicationRoles> userApplicationRolesNonCentralizedList = userRolesCommonServiceImpl
1303                                 .getUsersFromAppEndpoint(2l);
1304                 assertEquals(mockUserApplicationRolesNonCentralizedList.size(), userApplicationRolesNonCentralizedList.size());
1305         }
1306
1307         @SuppressWarnings("unchecked")
1308         @Test
1309         public void putUserAppRolesRequestTest() {
1310                 EPApp mockApp = mockApp();
1311                 mockApp.setId(2l);
1312                 mockApp.setEnabled(true);
1313                 mockApp.setCentralAuth(false);
1314                 EPUser user = mockUser.mockEPUser();
1315                 AppWithRolesForUser appWithRolesForUser = new AppWithRolesForUser();
1316                 List<RoleInAppForUser> mockRoleInAppForUserList = new ArrayList<>();
1317                 RoleInAppForUser roleInAppForUser = new RoleInAppForUser();
1318                 roleInAppForUser.setIsApplied(true);
1319                 roleInAppForUser.setRoleId(1l);
1320                 roleInAppForUser.setRoleName("test1");
1321                 RoleInAppForUser roleInAppForUser2 = new RoleInAppForUser();
1322                 roleInAppForUser2.setIsApplied(true);
1323                 roleInAppForUser2.setRoleId(1000l);
1324                 roleInAppForUser2.setRoleName("test3");
1325                 mockRoleInAppForUserList.add(roleInAppForUser);
1326                 mockRoleInAppForUserList.add(roleInAppForUser2);
1327                 appWithRolesForUser.setAppId(mockApp.getId());
1328                 appWithRolesForUser.setAppName(mockApp.getName());
1329                 appWithRolesForUser.setOrgUserId(user.getOrgUserId());
1330                 appWithRolesForUser.setAppRoles(mockRoleInAppForUserList);
1331                 List<EPUserAppRoles> epUserAppRolesList = new ArrayList<>();
1332                 EPUserAppRoles appRole1 = new EPUserAppRoles();
1333                 appRole1.setAppId(mockApp.getId());
1334                 appRole1.setId(10l);
1335                 appRole1.setRoleId(roleInAppForUser.roleId);
1336                 epUserAppRolesList.add(appRole1);
1337                 List<EPUserAppRoles> epUserAppRolesList2 = new ArrayList<>();
1338                 EPUserAppRoles appRole2 = new EPUserAppRoles();
1339                 appRole2.setAppId(mockApp.getId());
1340                 appRole2.setId(11l);
1341                 appRole2.setRoleId(roleInAppForUser2.roleId);
1342                 epUserAppRolesList2.add(appRole2);
1343                 EPUserAppRolesRequest mockEpAppRolesRequestData = new EPUserAppRolesRequest();
1344                 Mockito.doNothing().when(dataAccessService).saveDomainObject(mockEpAppRolesRequestData, null);
1345                 final Map<String, Long> params = new HashMap<>();
1346                 params.put("appId", appWithRolesForUser.getAppId());
1347                 params.put("appRoleId", roleInAppForUser.roleId);
1348                 Mockito.when((List<EPUserAppRoles>) dataAccessService.executeNamedQuery("appRoles", params, null))
1349                                 .thenReturn(epUserAppRolesList);
1350                 params.put("appRoleId", roleInAppForUser2.roleId);
1351                 Mockito.when((List<EPUserAppRoles>) dataAccessService.executeNamedQuery("appRoles", params, null))
1352                                 .thenReturn(epUserAppRolesList2);
1353                 EPUserAppRolesRequestDetail mockEPAppRoleDetail = new EPUserAppRolesRequestDetail();
1354                 Mockito.doNothing().when(dataAccessService).saveDomainObject(mockEPAppRoleDetail, null);
1355                 FieldsValidator expected = new FieldsValidator();
1356                 expected.setHttpStatusCode(Long.valueOf(HttpServletResponse.SC_OK));
1357                 FieldsValidator actual = userRolesCommonServiceImpl.putUserAppRolesRequest(appWithRolesForUser, user);
1358                 assertEquals(expected, actual);
1359         }
1360
1361         @Test
1362         public void importRolesFromRemoteApplicationTest() throws HTTPException {
1363                 EPApp mockApp = mockApp();
1364                 mockApp.setId(2l);
1365                 mockApp.setEnabled(true);
1366                 mockApp.setCentralAuth(false);
1367                 List<EPRole> expected = new ArrayList<>();
1368                 EPRole epRole = new EPRole();
1369                 epRole.setAppId(mockApp.getId());
1370                 epRole.setActive(true);
1371                 epRole.setId(10l);
1372                 epRole.setName("test1");
1373                 EPRole epRole2 = new EPRole();
1374                 epRole2.setAppId(mockApp.getId());
1375                 epRole2.setActive(true);
1376                 epRole2.setId(11l);
1377                 epRole2.setName("test2");
1378                 expected.add(epRole);
1379                 expected.add(epRole2);
1380                 EPRole[] epRoleArray = expected.toArray(new EPRole[expected.size()]);
1381                 Mockito.when(applicationsRestClientService.get(EPRole[].class, mockApp.getId(), "/rolesFull"))
1382                                 .thenReturn(epRoleArray);
1383                 Mockito.when(epRoleServiceImpl.getRole(mockApp.getId(), epRole.getId())).thenReturn(epRole);
1384                 Mockito.when(epRoleServiceImpl.getRole(mockApp.getId(), epRole2.getId())).thenReturn(epRole2);
1385                 List<EPRole> actual = userRolesCommonServiceImpl.importRolesFromRemoteApplication(mockApp.getId());
1386                 assertEquals(expected.size(), actual.size());
1387         }
1388
1389         @SuppressWarnings("deprecation")
1390         @Test
1391         public void getCachedAppRolesForUserTest() {
1392                 EPApp mockApp = mockApp();
1393                 mockApp.setId(2l);
1394                 mockApp.setEnabled(true);
1395                 mockApp.setCentralAuth(false);
1396                 EPUser user = mockUser.mockEPUser();
1397                 List<EPUserApp> expected = new ArrayList<>();
1398                 EPUserApp epUserApp = new EPUserApp();
1399                 EPRole epRole = new EPRole();
1400                 epRole.setAppId(mockApp.getId());
1401                 epRole.setActive(true);
1402                 epRole.setId(10l);
1403                 epRole.setName("test1");
1404                 epUserApp.setApp(mockApp);
1405                 epUserApp.setRole(epRole);
1406                 epUserApp.setUserId(user.getId());
1407                 expected.add(epUserApp);
1408                 String filter = " where user_id = " + Long.toString(user.getId()) + " and app_id = "
1409                                 + Long.toString(mockApp.getId());
1410                 Mockito.when(dataAccessService.getList(EPUserApp.class, filter, null, null)).thenReturn(expected);
1411                 List<EPUserApp> actual = userRolesCommonServiceImpl.getCachedAppRolesForUser(mockApp.getId(), user.getId());
1412                 assertEquals(expected.size(), actual.size());
1413         }
1414
1415         @SuppressWarnings("unchecked")
1416         @Test
1417         public void getUserAppCatalogRolesTest() {
1418                 EPApp mockApp = mockApp();
1419                 mockApp.setId(2l);
1420                 mockApp.setEnabled(true);
1421                 mockApp.setCentralAuth(false);
1422                 EPUser user = mockUser.mockEPUser();
1423                 List<EPUserAppCatalogRoles> expected = new ArrayList<>();
1424                 EPUserAppCatalogRoles epUserAppCatalogRoles = new EPUserAppCatalogRoles();
1425                 epUserAppCatalogRoles.setAppId(mockApp.getId());
1426                 epUserAppCatalogRoles.setId(2l);
1427                 epUserAppCatalogRoles.setRequestedRoleId(10l);
1428                 epUserAppCatalogRoles.setRequestStatus("S");
1429                 epUserAppCatalogRoles.setRolename("test1");
1430                 expected.add(epUserAppCatalogRoles);
1431                 Map<String, String> params = new HashMap<>();
1432                 params.put("userid", user.getId().toString());
1433                 params.put("appName", mockApp.getName());
1434                 Mockito.when(
1435                                 (List<EPUserAppCatalogRoles>) dataAccessService.executeNamedQuery("userAppCatalogRoles", params, null))
1436                                 .thenReturn(expected);
1437                 List<EPUserAppCatalogRoles> actual = userRolesCommonServiceImpl.getUserAppCatalogRoles(user, mockApp.getName());
1438                 assertEquals(expected.size(), actual.size());
1439         }
1440
1441         @Test
1442         public void getExternalRequestAccessTest() {
1443                 ExternalSystemAccess expected = new ExternalSystemAccess("external_access_enable", false);
1444                 ExternalSystemAccess actual = userRolesCommonServiceImpl.getExternalRequestAccess();
1445                 assertEquals(expected, actual);
1446         }
1447
1448         @Test
1449         public void getEPUserAppListTest() {
1450                 EPApp mockApp = mockApp();
1451                 mockApp.setId(2l);
1452                 mockApp.setEnabled(true);
1453                 mockApp.setCentralAuth(false);
1454                 EPUser user = mockUser.mockEPUser();
1455                 List<EPUserApp> expected = new ArrayList<>();
1456                 EPUserApp epUserApp = new EPUserApp();
1457                 EPRole epRole = new EPRole();
1458                 epRole.setAppId(mockApp.getId());
1459                 epRole.setActive(true);
1460                 epRole.setId(10l);
1461                 epRole.setName("test1");
1462                 epUserApp.setApp(mockApp);
1463                 epUserApp.setRole(epRole);
1464                 epUserApp.setUserId(user.getId());
1465                 expected.add(epUserApp);
1466                 final Map<String, Long> params = new HashMap<>();
1467                 params.put("appId", mockApp.getId());
1468                 params.put("userId", user.getId());
1469                 params.put("roleId", epRole.getId());
1470                 Mockito.when(dataAccessService.executeNamedQuery("getUserRoleOnUserIdAndRoleIdAndAppId", params, null))
1471                                 .thenReturn(expected);
1472                 List<EPUserApp> actual = userRolesCommonServiceImpl.getEPUserAppList(mockApp.getId(), user.getId(),
1473                                 epRole.getId());
1474                 assertEquals(expected.size(), actual.size());
1475         }
1476
1477         @Test
1478         public void updateRemoteUserProfileTest() {
1479                 EPApp mockApp = mockApp();
1480                 EPApp mockApp2 = mockApp();
1481                 mockApp.setId(2l);
1482                 mockApp.setEnabled(true);
1483                 mockApp.setCentralAuth(false);
1484                 EPUser user = mockUser.mockEPUser();
1485                 List<EPApp> mockEpAppList = new ArrayList<>();
1486                 mockEpAppList.add(mockApp);
1487                 mockEpAppList.add(mockApp2);
1488                 Mockito.when(searchServiceImpl.searchUserByUserId(user.getOrgUserId())).thenReturn(user);
1489                 Mockito.when(epAppCommonServiceImpl.getUserRemoteApps(user.getId().toString())).thenReturn(mockEpAppList);
1490                 String expected = "success";
1491                 String actual = userRolesCommonServiceImpl.updateRemoteUserProfile(user.getOrgUserId(), mockApp.getId());
1492                 assertEquals(expected, actual);
1493         }
1494 }