001 /** 002 * Copyright 2005-2011 The Kuali Foundation 003 * 004 * Licensed under the Educational Community License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.opensource.org/licenses/ecl2.php 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 package org.kuali.rice.krad.document; 017 018 import org.junit.Ignore; 019 import org.junit.Test; 020 import org.kuali.test.KRADTestCase; 021 022 @Ignore 023 public class DocumentAuthorizerBaseTest extends KRADTestCase { 024 // TODO rewrite this test 025 // private static final Logger LOG = Logger.getLogger(DocumentAuthorizerBaseTest.class); 026 // 027 // private static final String SUPERVISOR_USER = "ABNEY"; 028 // private static final String SUPERVISOR_UNIVERSAL = "2237202707"; 029 // private static final String NONSUPER_USER = "BARTH"; 030 // private static final String NONSUPER_UNIVERSAL = "5998202207"; 031 // private static final String NONSUPER_2_USER = "COOTER"; 032 // private static final String NONSUPER_2_UNIVERSAL = "598746310"; 033 // 034 // private DocumentAuthorizer documentAuthorizer; 035 // private PessimisticLockService pessimisticLock; 036 // 037 // @Override 038 // public void setUp() throws Exception { 039 // super.setUp(); 040 // documentAuthorizer = new DocumentAuthorizerBase(); 041 // pessimisticLock = KRADServiceLocatorInternal.getPessimisticLockService(); 042 // } 043 // 044 // @Override 045 // public void tearDown() throws Exception { 046 // try { 047 // new ClearDatabaseLifecycle(Arrays.asList(new String[]{"KNS_PESSIMISTIC_LOCK_T"}), null).start(); 048 // } catch (Exception e) { 049 // LOG.warn("Caught exception trying to clear Pessimistic Lock table"); 050 // } 051 // super.tearDown(); 052 // } 053 // 054 // // following is the Supervisor & Initiator grid 055 // 056 // // ## Supervisor? UserIsInitiator? ApprovalRequested? canSupervise Result 057 // // ----------------------------------------------------------------------------------- 058 // // A true true true true 059 // // 060 // // B true true false false 061 // // 062 // // C true false true true 063 // // 064 // // D true false false true 065 // // 066 // // E false * * false 067 // // 068 069 /* This test can no longer use mock objects because the isSupervisor() method is no longer on the Person object. 070 * To check for supervisor status you know must to through the group service and check membership in the supervisor group. 071 */ 072 @Test 073 public void testCanSuperviseAsInitiatorA() { 074 // 075 // DocumentActionFlags flags; 076 // Document document; 077 // 078 // // scenario A 079 // //document = new MockDocument(getSuperUser(), true); 080 // //flags = documentAuthorizer.getDocumentActionFlags(document, getSuperUser()); 081 // //assertTrue(flags.getCanSupervise()); 082 // 083 // // scenario B 084 // document = new MockDocument(getSuperUser(), false); 085 // flags = documentAuthorizer.getDocumentActionFlags(document, getSuperUser()); 086 // assertFalse(flags.getCanSupervise()); 087 // 088 // // scenario C 089 // document = new MockDocument(getNonSuperUser(), true); 090 // flags = documentAuthorizer.getDocumentActionFlags(document, getSuperUser()); 091 // assertTrue(flags.getCanSupervise()); 092 // 093 // // scenario D 094 // document = new MockDocument(getNonSuperUser(), false); 095 // flags = documentAuthorizer.getDocumentActionFlags(document, getSuperUser()); 096 // assertTrue(flags.getCanSupervise()); 097 // 098 } 099 100 // 101 // private void verifyEditModeExists(Map editMode, String editModeToTest, String expectedValue) { 102 // assertNotNull("Edit mode map should have a valid value for " + editModeToTest, editMode.get(editModeToTest)); 103 // assertEquals("Edit mode map should contain entry with key '" + editModeToTest + "' and value '" + expectedValue + "'", expectedValue, editMode.get(editModeToTest)); 104 // } 105 // 106 // private void verifyEditModeDoesNotExist(Map editMode, String editModeToTest) { 107 // assertNull("Edit mode map should not have an entry for " + editModeToTest, editMode.get(editModeToTest)); 108 // } 109 // 110 // protected Person getWorkflowPessimisticLockOwnerUser() { 111 // Person person = KimImplServiceLocator.getPersonService().getPersonByPrincipalName(KNSConstants.SYSTEM_USER); 112 // if (person == null) { 113 // throw new RuntimeException("Cannot find user with network id '" + KNSConstants.SYSTEM_USER); 114 // } 115 // return person; 116 // } 117 // 118 // /** 119 // * This method tests the Pessimistic locking mechanism when no custom lock descriptors are being used by the document in 120 // * the default manner (locks are unique to user and document) 121 // * 122 // * @throws Exception 123 // */ 124 @Test 125 public void testEstablishLocks_DefaultDocumentAuthorizerBase() throws Exception { 126 // PessimisticLockService lockService = KRADServiceLocatorInternal.getPessimisticLockService(); 127 // 128 // // test no lock creation needed 129 // Document document = new MockDocument(getNonSuperUser(), false); 130 // int originalExpectedLockCount = 0; 131 // // no lock should be created 132 // int expectedLockCountIncrease = 0; 133 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 134 // Map oldEditMode = getEditMode_ReadOnly(); 135 // String testString = "dummyString"; 136 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 137 // Map newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 138 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 139 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 140 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY); 141 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 142 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 143 // 144 // // test valid lock creation where no user has any locks and edit modes returned are same as passed in 145 // document = new MockDocument(getNonSuperUser(), false); 146 // originalExpectedLockCount = 0; 147 // // one lock should be created 148 // expectedLockCountIncrease = 1; 149 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 150 // oldEditMode = getEditMode_FullEntry(); 151 // testString = "dummyString"; 152 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 153 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 154 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 155 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 156 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 157 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY); 158 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 159 // 160 // // test invalid lock status (2 locks by 2 different users) throws exception 161 // document = new MockDocument(getNonSuperUser(), false); 162 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), getNonSuperUser())); 163 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), getSuperUser())); 164 // try { 165 // this.pessimisticLock.establishLocks(document, getEditMode_FullEntry(), getNonSuperUser()); 166 // fail("Document authorizer should have thrown exception of type PessimisticLockingException"); 167 // } catch (PessimisticLockingException e) { 168 // // expected result 169 // } catch (Exception e) { 170 // fail("Document authorizer threw an exception but it was not of type PessimisticLockingException... it was a " + e.getClass().getName()); 171 // } 172 // 173 // // test valid lock status (2 locks by 2 different users with one user being workflow lock user) does not throw 174 // // exception 175 // document = new MockDocument(getNonSuperUser(), false); 176 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), getNonSuperUser())); 177 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), getWorkflowPessimisticLockOwnerUser())); 178 // try { 179 // this.pessimisticLock.establishLocks(document, getEditMode_FullEntry(), getNonSuperUser()); 180 // } catch (Exception e) { 181 // fail("Document authorizer should not have thrown an exception but did with type '" + e.getClass().getName() + "' and message: " + e.getMessage()); 182 // } 183 // 184 // // test other user already has lock should return editMode of ReadOnly 185 // document = new MockDocument(getNonSuperUser(), false); 186 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), getSuperUser())); 187 // originalExpectedLockCount = 1; 188 // // one lock should be created 189 // expectedLockCountIncrease = 0; 190 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 191 // oldEditMode = getEditMode_FullEntry(); 192 // testString = "dummyString"; 193 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 194 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 195 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 196 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 197 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY); 198 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 199 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 200 // 201 // // test current user already has lock and that edit modes returned are same as passed in 202 // document = new MockDocument(getNonSuperUser(), false); 203 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), getNonSuperUser())); 204 // originalExpectedLockCount = 1; 205 // // one lock should be created 206 // expectedLockCountIncrease = 0; 207 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 208 // oldEditMode = getEditMode_FullEntry(); 209 // testString = "dummyString"; 210 // oldEditMode.put(AuthorizationConstants.EditMode.VIEW_ONLY, testString); 211 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 212 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 213 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 214 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE); 215 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 216 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, testString); 217 // 218 } 219 // 220 // /** 221 // * This method tests the Pessimistic locking mechanism when custom lock descriptors are being used by the document in the 222 // * default manner (locks are unique to user, document, and lock descriptor) 223 // * 224 // * @throws Exception 225 // */ 226 @Test 227 public void testEstablishLocks_CustomDocumentAuthorizerBase() throws Exception { 228 // GlobalVariables.setUserSession(new UserSession("quickstart")); 229 // PessimisticLockService lockService = KRADServiceLocatorInternal.getPessimisticLockService(); 230 // DocumentAuthorizer documentAuthorizer = new TestDocumentAuthorizerBase(); 231 // String lockDescriptor1 = "test the first lock"; 232 // String lockDescriptor2 = "this is the second lock"; 233 // String lockDescriptor3 = "booyah locks"; 234 // 235 // // test no lock creation needed 236 // Document document = new MockDocument(getNonSuperUser(), false); 237 // String expectedLockDescriptor = lockDescriptor1; 238 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 239 // int originalExpectedLockCount = 0; 240 // // no lock should be created 241 // int expectedLockCountIncrease = 0; 242 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 243 // Map oldEditMode = getEditMode_ReadOnly(); 244 // String testString = "dummyString"; 245 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 246 // Map newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 247 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 248 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 249 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY); 250 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 251 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 252 // 253 // // test lock descriptors nullify PessimisticLockingException throwing 254 // document = new MockDocument(getNonSuperUser(), false); 255 // expectedLockDescriptor = lockDescriptor3; 256 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 257 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getNonSuperUser())); 258 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getSuperUser())); 259 // try { 260 // this.pessimisticLock.establishLocks(document, getEditMode_FullEntry(), getNonSuperUser()); 261 // } catch (Exception e) { 262 // fail("Document authorizer should not have thrown an exception but did with type '" + e.getClass().getName() + "' and message: " + e.getMessage()); 263 // } 264 // 265 // // test valid lock status (2 locks by 2 different users with one user being workflow lock user) does not throw 266 // // exception 267 // document = new MockDocument(getNonSuperUser(), false); 268 // expectedLockDescriptor = lockDescriptor3; 269 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 270 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getNonSuperUser())); 271 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getWorkflowPessimisticLockOwnerUser())); 272 // try { 273 // //documentAuthorizer.establishLocks(document, getEditMode_FullEntry(), getNonSuperUser()); 274 // this.pessimisticLock.establishLocks(document,getEditMode_FullEntry(), getNonSuperUser()); 275 // } catch (Exception e) { 276 // fail("Document authorizer should not have thrown an exception but did with type '" + e.getClass().getName() + "' and message: " + e.getMessage()); 277 // } 278 // 279 // // test valid lock creation with descriptor where no user has any locks and edit modes returned are same as passed in 280 // document = new MockDocument(getNonSuperUser(), false); 281 // expectedLockDescriptor = lockDescriptor3; 282 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 283 // originalExpectedLockCount = 0; 284 // // one lock should be created 285 // expectedLockCountIncrease = 1; 286 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 287 // oldEditMode = getEditMode_FullEntry(); 288 // testString = "dummyString"; 289 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 290 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 291 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 292 // assertEquals("Lock descriptor from new lock is incorrect", expectedLockDescriptor, document.getPessimisticLocks().get(0).getLockDescriptor()); 293 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 294 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 295 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY); 296 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 297 // 298 // // test other user already has lock with same descriptor should return editMode of ReadOnly 299 // document = new MockDocument(getNonSuperUser(), false); 300 // expectedLockDescriptor = lockDescriptor1; 301 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 302 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getSuperUser())); 303 // originalExpectedLockCount = 1; 304 // // no lock should be created 305 // expectedLockCountIncrease = 0; 306 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 307 // oldEditMode = getEditMode_FullEntry(); 308 // testString = "dummyString"; 309 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 310 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 311 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 312 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 313 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY); 314 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 315 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 316 // assertNotNull("Establish locks should return a UNVIEWABLE edit mode", newEditMode.get(AuthorizationConstants.EditMode.UNVIEWABLE)); 317 // assertEquals("Establish locks method returned invalid UNVIEWABLE edit mode", testString, newEditMode.get(AuthorizationConstants.EditMode.UNVIEWABLE)); 318 // 319 // // test other user already has lock with different descriptor should return given edit modes 320 // document = new MockDocument(getNonSuperUser(), false); 321 // expectedLockDescriptor = lockDescriptor1; 322 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 323 // PessimisticLock oldLock = lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getNonSuperUser()); 324 // document.addPessimisticLock(oldLock); 325 // originalExpectedLockCount = 1; 326 // // one lock should be created 327 // expectedLockCountIncrease = 1; 328 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 329 // oldEditMode = getEditMode_FullEntry(); 330 // testString = "is this the string"; 331 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 332 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 333 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 334 // for (PessimisticLock lock : document.getPessimisticLocks()) { 335 // if (!lock.getId().equals(oldLock.getId())) { 336 // assertEquals("Lock descriptor of new lock is incorrect", expectedLockDescriptor, lock.getLockDescriptor()); 337 // } 338 // } 339 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 340 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 341 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY); 342 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 343 // 344 // // test current user has lock with same lock descriptor and other users have no locks should return given edit modes 345 // document = new MockDocument(getNonSuperUser(), false); 346 // expectedLockDescriptor = lockDescriptor1; 347 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 348 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), expectedLockDescriptor, getNonSuperUser())); 349 // originalExpectedLockCount = 1; 350 // // no lock should be created 351 // expectedLockCountIncrease = 0; 352 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 353 // oldEditMode = getEditMode_FullEntry(); 354 // testString = "is this the string"; 355 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 356 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 357 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 358 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 359 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 360 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY); 361 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 362 // 363 // // test current user has lock with different lock descriptor and other users have no locks should return given edit 364 // // modes 365 // document = new MockDocument(getNonSuperUser(), false); 366 // expectedLockDescriptor = lockDescriptor1; 367 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 368 // oldLock = lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, getNonSuperUser()); 369 // document.addPessimisticLock(oldLock); 370 // originalExpectedLockCount = 1; 371 // // one lock should be created 372 // expectedLockCountIncrease = 1; 373 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 374 // oldEditMode = getEditMode_FullEntry(); 375 // testString = "is this the string"; 376 // oldEditMode.put(AuthorizationConstants.EditMode.VIEW_ONLY, testString); 377 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 378 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 379 // for (PessimisticLock lock : document.getPessimisticLocks()) { 380 // if (!lock.getId().equals(oldLock.getId())) { 381 // assertEquals("Lock descriptor of new lock is incorrect", expectedLockDescriptor, lock.getLockDescriptor()); 382 // } 383 // } 384 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 385 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 386 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, testString); 387 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE); 388 // 389 // // test invalid lock status (2 locks with same lock descriptor by 2 different users) throws exception 390 // document = new MockDocument(getNonSuperUser(), false); 391 // expectedLockDescriptor = lockDescriptor3; 392 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 393 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getNonSuperUser())); 394 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, getSecondNonSuperUser())); 395 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getSuperUser())); 396 // try { 397 // this.pessimisticLock.establishLocks(document, getEditMode_FullEntry(), getNonSuperUser()); 398 // fail("Document authorizer should have thrown exception of type PessimisticLockingException"); 399 // } catch (PessimisticLockingException e) { 400 // // expected result 401 // } catch (Exception e) { 402 // fail("Document authorizer threw an exception but it was not of type PessimisticLockingException... it was a " + e.getClass().getName()); 403 // } 404 // 405 // // test valid lock status (2 locks by 2 different users with one user being workflow lock user) does not throw 406 // // exception 407 // document = new MockDocument(getNonSuperUser(), false); 408 // expectedLockDescriptor = lockDescriptor3; 409 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 410 // Person user = getWorkflowPessimisticLockOwnerUser(); 411 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, user)); 412 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getSuperUser())); 413 // try { 414 // this.pessimisticLock.establishLocks(document, getEditMode_FullEntry(), getNonSuperUser()); 415 // } catch (Exception e) { 416 // fail("Document authorizer should not have thrown an exception but did with type '" + e.getClass().getName() + "' and message: " + e.getMessage()); 417 // } 418 // 419 // // test current user has lock with different descriptor and other users have locks with same descriptors should 420 // // return read only editmodes 421 // document = new MockDocument(getNonSuperUser(), false); 422 // expectedLockDescriptor = lockDescriptor3; 423 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 424 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getNonSuperUser())); 425 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, getSuperUser())); 426 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getSecondNonSuperUser())); 427 // originalExpectedLockCount = 3; 428 // // no lock should be created 429 // expectedLockCountIncrease = 0; 430 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 431 // oldEditMode = getEditMode_FullEntry(); 432 // testString = "is this the string"; 433 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 434 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 435 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 436 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 437 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY); 438 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 439 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 440 // 441 // // test current user has lock with same descriptor and other users have locks with different descriptors should 442 // // return given editmodes 443 // document = new MockDocument(getNonSuperUser(), false); 444 // expectedLockDescriptor = lockDescriptor3; 445 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 446 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), expectedLockDescriptor, getNonSuperUser())); 447 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getSuperUser())); 448 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getSecondNonSuperUser())); 449 // originalExpectedLockCount = 3; 450 // // no lock should be created 451 // expectedLockCountIncrease = 0; 452 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 453 // oldEditMode = getEditMode_FullEntry(); 454 // testString = "is this the string"; 455 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 456 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 457 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 458 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 459 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 460 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY); 461 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 462 // 463 // // test current user has lock with different lock descriptor and other users have locks with different lock 464 // // descriptor should return given edit modes 465 // document = new MockDocument(getNonSuperUser(), false); 466 // expectedLockDescriptor = lockDescriptor1; 467 // List<Long> existingLockIds = new ArrayList<Long>(); 468 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 469 // oldLock = lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, getSecondNonSuperUser()); 470 // existingLockIds.add(oldLock.getId()); 471 // document.addPessimisticLock(oldLock); 472 // oldLock = lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getSecondNonSuperUser()); 473 // existingLockIds.add(oldLock.getId()); 474 // document.addPessimisticLock(oldLock); 475 // oldLock = lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, getSuperUser()); 476 // existingLockIds.add(oldLock.getId()); 477 // document.addPessimisticLock(oldLock); 478 // originalExpectedLockCount = existingLockIds.size(); 479 // // one lock should be created 480 // expectedLockCountIncrease = 1; 481 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 482 // oldEditMode = getEditMode_FullEntry(); 483 // testString = "is this the string"; 484 // oldEditMode.put(AuthorizationConstants.EditMode.VIEW_ONLY, testString); 485 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 486 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 487 // for (PessimisticLock lock : document.getPessimisticLocks()) { 488 // if (!existingLockIds.contains(lock.getId())) { 489 // // this must be the newly created lock 490 // assertEquals("Lock descriptor of new lock is incorrect", expectedLockDescriptor, lock.getLockDescriptor()); 491 // } 492 // } 493 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 494 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 495 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, testString); 496 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE); 497 // 498 // // test current user has lock with wrong descriptor and no entry edit modes return given editmodes 499 // document = new MockDocument(getNonSuperUser(), false); 500 // expectedLockDescriptor = lockDescriptor3; 501 // GlobalVariables.getUserSession().addObject(TestDocumentAuthorizerBase.USER_SESSION_OBJECT_KEY, (Object) expectedLockDescriptor); 502 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor1, getNonSuperUser())); 503 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor3, getSuperUser())); 504 // document.addPessimisticLock(lockService.generateNewLock(document.getDocumentNumber(), lockDescriptor2, getSecondNonSuperUser())); 505 // originalExpectedLockCount = 3; 506 // // no lock should be created 507 // expectedLockCountIncrease = 0; 508 // assertEquals("Lock count is incorrect", originalExpectedLockCount, document.getPessimisticLocks().size()); 509 // oldEditMode = getEditMode_ReadOnly(); 510 // testString = "is this the string"; 511 // oldEditMode.put(AuthorizationConstants.EditMode.UNVIEWABLE, testString); 512 // newEditMode = this.pessimisticLock.establishLocks(document, oldEditMode, getNonSuperUser()); 513 // assertEquals("Lock count is incorrect", originalExpectedLockCount + expectedLockCountIncrease, document.getPessimisticLocks().size()); 514 // assertEquals("Establish locks method returned invalid number of edit modes", oldEditMode.size(), newEditMode.size()); 515 // verifyEditModeDoesNotExist(newEditMode, AuthorizationConstants.EditMode.FULL_ENTRY); 516 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.VIEW_ONLY, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 517 // verifyEditModeExists(newEditMode, AuthorizationConstants.EditMode.UNVIEWABLE, testString); 518 } 519 // 520 @Test 521 public void testHasPreRouteEditAuthorization() throws Exception { 522 // //TODO: the test for preRouteEditAuthorization should be removed 523 // GlobalVariables.setUserSession(new UserSession("quickstart")); 524 // PessimisticLockTestDocumentAuthorizer lockDocumentAuthorizer = new PessimisticLockTestDocumentAuthorizer(); 525 // lockDocumentAuthorizer.USES_PESSIMISTIC_LOCKING = false; 526 // 527 // Person initiatorUser = getNonSuperUser(); 528 // Person authorizerUser = getNonSuperUser(); 529 // Document document = new MockDocument(initiatorUser, false); 530 // assertTrue(authorizerUser + " should have Initiate Authorization due to initator being " + initiatorUser, lockDocumentAuthorizer.hasInitiateAuthorization(document, authorizerUser)); 531 // //assertTrue(authorizerUser + " should have Pre Route Edit Authorization", lockDocumentAuthorizer.hasPreRouteEditAuthorization(document, authorizerUser)); 532 // 533 // initiatorUser = getNonSuperUser(); 534 // authorizerUser = getSuperUser(); 535 // document = new MockDocument(initiatorUser, false); 536 // assertFalse(authorizerUser + " should not have Initiate Authorization due to initator being " + initiatorUser, lockDocumentAuthorizer.hasInitiateAuthorization(document, authorizerUser)); 537 // //assertFalse(authorizerUser + " should not have Pre Route Edit Authorization", lockDocumentAuthorizer.hasPreRouteEditAuthorization(document, authorizerUser)); 538 // 539 // // switch to using pessimistic locking for the next tests 540 // lockDocumentAuthorizer.USES_PESSIMISTIC_LOCKING = true; 541 // 542 // initiatorUser = getNonSuperUser(); 543 // authorizerUser = getSuperUser(); 544 // document = new MockDocument(initiatorUser, false); 545 // assertFalse(authorizerUser + " should not have Initiate Authorization due to initator being " + initiatorUser, lockDocumentAuthorizer.hasInitiateAuthorization(document, authorizerUser)); 546 // //assertFalse(authorizerUser + " should not have Pre Route Edit Authorization", lockDocumentAuthorizer.hasPreRouteEditAuthorization(document, authorizerUser)); 547 // 548 // initiatorUser = getNonSuperUser(); 549 // authorizerUser = getNonSuperUser(); 550 // document = new MockDocument(initiatorUser, false); 551 // document.addPessimisticLock(KRADServiceLocatorInternal.getPessimisticLockService().generateNewLock(document.getDocumentNumber(), getSecondNonSuperUser())); 552 // assertTrue(authorizerUser + " should have Initiate Authorization due to initator being " + initiatorUser, lockDocumentAuthorizer.hasInitiateAuthorization(document, authorizerUser)); 553 // //assertFalse(authorizerUser + " should not have Pre Route Edit Authorization", lockDocumentAuthorizer.hasPreRouteEditAuthorization(document, authorizerUser)); 554 // 555 // initiatorUser = getNonSuperUser(); 556 // authorizerUser = getNonSuperUser(); 557 // document = new MockDocument(initiatorUser, false); 558 // document.addPessimisticLock(KRADServiceLocatorInternal.getPessimisticLockService().generateNewLock(document.getDocumentNumber(), authorizerUser)); 559 // assertTrue(authorizerUser + " should have Initiate Authorization due to initator being " + initiatorUser, lockDocumentAuthorizer.hasInitiateAuthorization(document, authorizerUser)); 560 // //assertTrue(authorizerUser + " should have Pre Route Edit Authorization", lockDocumentAuthorizer.hasPreRouteEditAuthorization(document, authorizerUser)); 561 } 562 // 563 @Test 564 public void testGetDocumentActionFlagsUsingPessimisticLocking() throws Exception { 565 // GlobalVariables.setUserSession(new UserSession("quickstart")); 566 // String editModeTrueValue = "TRUE"; 567 // String editModeFalseValue = "FALSE"; 568 // PessimisticLockTestDocumentAuthorizer lockDocumentAuthorizer = new PessimisticLockTestDocumentAuthorizer(); 569 // 570 // Person initiatorUser = getNonSuperUser(); 571 // Person authorizerUser = getNonSuperUser(); 572 // Document document = new MockDocument(initiatorUser, false); 573 // lockDocumentAuthorizer.USES_PESSIMISTIC_LOCKING = false; 574 // Map editMode = new HashMap(); 575 // lockDocumentAuthorizer.setEditMode(MapUtils.putAll(editMode, new Map.Entry[]{new DefaultMapEntry(AuthorizationConstants.EditMode.VIEW_ONLY,"TRUE")})); 576 // DocumentFormPlaceholder formDummy = implementDocumentAuthorizerMethods(lockDocumentAuthorizer, document, new MockPerson(GlobalVariables.getUserSession().getPerson())); 577 } 578 // 579 // /** 580 // * This is a stand-in object for a {@link KualiDocumentFormBase} object 581 // */ 582 // private class DocumentFormPlaceholder { 583 // public Map editingMode; 584 // public DocumentActionFlags documentActionFlags; 585 // } 586 // 587 // /** 588 // * This method is a stand-in method to duplicate the behavior of 589 // * {@link KualiDocumentFormBase#populateAuthorizationFields(DocumentAuthorizer)} and 590 // * {@link KualiDocumentFormBase#useDocumentAuthorizer(DocumentAuthorizer)} 591 // * 592 // * @param document - 593 // * document to use for edit modes and action flags 594 // * @param kualiUser - 595 // * user to use in place of what may be in GlobalVariables 596 // * @return a stand-in object for {@link KualiDocumentFormBase} that holds the edit mode map and the 597 // * {@link DocumentActionFlags} object that would be held in the {@link KualiDocumentFormBase} 598 // */ 599 // private DocumentFormPlaceholder implementDocumentAuthorizerMethods(PessimisticLockTestDocumentAuthorizer documentAuthorizer, Document document, Person kualiUser) { 600 // // Person kualiUser = GlobalVariables.getUserSession().getPerson(); 601 // // DocumentAuthorizer documentAuthorizer = KRADServiceLocatorInternal.getDocumentAuthorizationService().getDocumentAuthorizer(document); 602 // Map editMode = documentAuthorizer.getEditMode(document, kualiUser); 603 // if (documentAuthorizer.usesPessimisticLocking(document)) { 604 // editMode = this.pessimisticLock.establishLocks(document, editMode, kualiUser); 605 // } 606 // DocumentFormPlaceholder formPlaceholder = new DocumentFormPlaceholder(); 607 // formPlaceholder.editingMode = editMode; 608 // formPlaceholder.documentActionFlags = documentAuthorizer.getDocumentActionFlags(document, kualiUser); 609 // return formPlaceholder; 610 // } 611 // 612 // private Person getSuperUser() { 613 // return new MockPerson(SUPERVISOR_UNIVERSAL, SUPERVISOR_USER, true); 614 // } 615 // 616 // private Person getNonSuperUser() { 617 // return new MockPerson(NONSUPER_UNIVERSAL, NONSUPER_USER, false); 618 // } 619 // 620 // private Person getSecondNonSuperUser() { 621 // return new MockPerson(NONSUPER_2_UNIVERSAL, NONSUPER_2_USER, false); 622 // } 623 // 624 // private Map getEditMode_ReadOnly() { 625 // return constructEditMode(AuthorizationConstants.EditMode.VIEW_ONLY); 626 // } 627 // 628 // private Map getEditMode_FullEntry() { 629 // return constructEditMode(AuthorizationConstants.EditMode.FULL_ENTRY); 630 // } 631 // 632 // private Map constructEditMode(String editModeValue) { 633 // Map editMode = new HashMap(); 634 // editMode.put(editModeValue, DocumentAuthorizerBase.EDIT_MODE_DEFAULT_TRUE_VALUE); 635 // return editMode; 636 // } 637 // 638 // private class MockDocument extends DocumentBase { 639 // 640 // private MockDocument() { 641 // super(); 642 // } 643 // 644 // public MockDocument(Person initiator, boolean isApprovalRequested) { 645 // this(); 646 // this.documentNumber = "1234567890"; 647 // getDocumentHeader().setWorkflowDocument(new MockWorkflowDocument(initiator, isApprovalRequested)); 648 // } 649 // 650 // @Override 651 // protected LinkedHashMap toStringMapper() { 652 // LinkedHashMap map = new LinkedHashMap(); 653 // map.put("class", "MockDocument"); 654 // map.put(KNSPropertyConstants.DOCUMENT_NUMBER, documentNumber); 655 // map.put("initiator", getDocumentHeader().getWorkflowDocument().getInitiatorNetworkId()); 656 // return map; 657 // } 658 // 659 // public boolean getAllowsCopy() { 660 // return false; 661 // } 662 // 663 // } 664 // 665 // private class MockWorkflowDocument extends MockWorkflowDocument { 666 // 667 // private Person initiator; 668 // private boolean approvalRequested; 669 // 670 // private MockWorkflowDocument() {}; 671 // 672 // public MockWorkflowDocument(Person initiator, boolean isApprovalRequested) { 673 // this.initiator = initiator; 674 // this.approvalRequested = isApprovalRequested; 675 // } 676 // 677 // public String getInitiatorNetworkId() { 678 // return initiator.getPrincipalName(); 679 // } 680 // 681 // public boolean isApprovalRequested() { 682 // return approvalRequested; 683 // } 684 // 685 // public boolean userIsInitiator(Person user) { 686 // return initiator.getPrincipalId().equalsIgnoreCase(user.getPrincipalId()); 687 // } 688 // 689 // /** 690 // * This overridden method ... 691 // * 692 // * @see org.kuali.rice.krad.workflow.service.KualiWorkflowDocument#appSpecificRouteDocumentToGroup(java.lang.String, java.lang.String, int, java.lang.String, org.kuali.rice.kim.bo.group.dto.GroupInfo, java.lang.String, boolean) 693 // */ 694 // public void appSpecificRouteDocumentToGroup(String actionRequested, 695 // String routeTypeName, String annotation, 696 // GroupIdDTO groupId, String responsibilityDesc, 697 // boolean forceAction) throws WorkflowException { 698 // // TODO sp20369 - THIS METHOD NEEDS JAVADOCS 699 // 700 // } 701 // 702 // } 703 // 704 // private class MockPerson extends PersonImpl { 705 // private boolean supervisor; 706 // private String principalId; 707 // private String principalName; 708 // 709 // private MockPerson() {}; 710 // 711 // public MockPerson(Person user) { 712 // this(user.getPrincipalId(), user.getPrincipalName(), KimApiServiceLocator.getIdentityManagementService().isMemberOfGroup(user.getPrincipalId(), org.kuali.rice.kim.util.KimApiConstants.KIM_GROUP_KFS_NAMESPACE_CODE, KRADServiceLocatorInternal.getKualiConfigurationService().getPropertyValueAsString(KNSConstants.KNS_NAMESPACE, KNSConstants.DetailTypes.DOCUMENT_DETAIL_TYPE, KNSConstants.CoreApcParms.SUPERVISOR_WORKGROUP))); 713 // } 714 // 715 // public MockPerson(String universalId, String userId, boolean supervisor) { 716 // this.principalId = universalId; 717 // this.principalName = userId; 718 // this.supervisor = supervisor; 719 // } 720 // 721 // public boolean isSupervisorUser() { 722 // return supervisor; 723 // } 724 // 725 // public String toString() { 726 // return ((supervisor) ? "Supervisor " : "") + "User (" + getPrincipalName() + ")"; 727 // } 728 // 729 // public String getPrincipalId() { 730 // return this.principalId == null ? super.getPrincipalId() : this.principalId; 731 // } 732 // 733 // public String getPrincipalName() { 734 // return this.principalName == null ? super.getPrincipalName() : this.principalName; 735 // } 736 // 737 // } 738 }