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.service; 017 018 import org.junit.Test; 019 import org.kuali.rice.krad.test.document.bo.Account; 020 import org.kuali.rice.krad.test.document.bo.AccountManager; 021 import org.kuali.rice.test.BaselineTestCase; 022 import org.kuali.rice.test.data.PerTestUnitTestData; 023 import org.kuali.rice.test.data.UnitTestData; 024 import org.kuali.rice.test.data.UnitTestFile; 025 import org.kuali.rice.test.data.UnitTestSql; 026 import org.kuali.test.KRADTestCase; 027 028 import java.util.Collection; 029 import java.util.HashMap; 030 import java.util.Map; 031 032 import static org.junit.Assert.assertEquals; 033 import static org.junit.Assert.assertTrue; 034 035 /** 036 * This class tests KULRICE-984: Lookups - Relative Limit Gap 037 * making sure that lookup resultSetLimits set in the DD for 038 * a BO will override the system wide default. 039 * 040 * @author Kuali Rice Team (rice.collab@kuali.org) 041 * 042 */ 043 044 @PerTestUnitTestData( 045 value = @UnitTestData( 046 order = {UnitTestData.Type.SQL_STATEMENTS, UnitTestData.Type.SQL_FILES}, 047 sqlStatements = { 048 @UnitTestSql("delete from trv_acct where acct_fo_id between 101 and 301") 049 ,@UnitTestSql("delete from trv_acct_fo where acct_fo_id between 101 and 301") 050 }, 051 sqlFiles = { 052 @UnitTestFile(filename = "classpath:testAccountManagers.sql", delimiter = ";") 053 , @UnitTestFile(filename = "classpath:testAccounts.sql", delimiter = ";") 054 } 055 ), 056 tearDown = @UnitTestData( 057 sqlStatements = { 058 @UnitTestSql("delete from trv_acct where acct_fo_id between 101 and 301") 059 ,@UnitTestSql("delete from trv_acct_fo where acct_fo_id between 101 and 301") 060 } 061 ) 062 ) 063 @BaselineTestCase.BaselineMode(BaselineTestCase.Mode.NONE) 064 public class LookupServiceTest extends KRADTestCase { 065 066 public LookupServiceTest() {} 067 068 /** 069 * This method tests lookup return limits 070 * 071 * @throws Exception 072 */ 073 @Test 074 public void testLookupReturnLimits() throws Exception { 075 LookupService lookupService = KRADServiceLocatorWeb.getLookupService(); 076 Map formProps = new HashMap(); 077 Collection accountManagers = lookupService.findCollectionBySearchHelper(AccountManager.class, formProps, false); 078 assertEquals(90, accountManagers.size()); 079 080 accountManagers = null; 081 accountManagers = lookupService.findCollectionBySearch(AccountManager.class, formProps); 082 assertEquals(90, accountManagers.size()); 083 } 084 085 /** 086 * This method tests a lookup with the default limit 087 * 088 * @throws Exception 089 */ 090 @Test 091 public void testLookupReturnDefaultLimit() throws Exception { 092 LookupService lookupService = KRADServiceLocatorWeb.getLookupService(); 093 Map formProps = new HashMap(); 094 Collection travelAccounts = lookupService.findCollectionBySearchHelper(Account.class, formProps, false); 095 assertEquals(200, travelAccounts.size()); 096 097 travelAccounts = null; 098 travelAccounts = lookupService.findCollectionBySearch(Account.class, formProps); 099 assertEquals(200, travelAccounts.size()); 100 } 101 102 /** 103 * This method tests an unbounded lookup 104 * 105 * @throws Exception 106 */ 107 @Test 108 public void testLookupReturnDefaultUnbounded() throws Exception { 109 LookupService lookupService = KRADServiceLocatorWeb.getLookupService(); 110 Map formProps = new HashMap(); 111 Collection accountManagers = lookupService.findCollectionBySearchHelper(AccountManager.class, formProps, true); 112 int size = accountManagers.size(); 113 assertTrue("# of Fiscal Officers should be > 200", size > 200); 114 115 accountManagers = null; 116 accountManagers = lookupService.findCollectionBySearchUnbounded(AccountManager.class, formProps); 117 size = accountManagers.size(); 118 assertTrue("# of Fiscal Officers should be > 200", size > 200); 119 } 120 121 /** 122 * This method tests an unbounded lookup 123 * 124 * @throws Exception 125 */ 126 @Test 127 public void testLookupReturnDefaultUnbounded2() throws Exception { 128 LookupService lookupService = KRADServiceLocatorWeb.getLookupService(); 129 Map formProps = new HashMap(); 130 Collection travelAccounts = lookupService.findCollectionBySearchHelper(Account.class, formProps, true); 131 int size = travelAccounts.size(); 132 assertTrue("# of Travel Accounts should be > 200", size > 200); 133 134 travelAccounts = null; 135 travelAccounts = lookupService.findCollectionBySearchUnbounded(Account.class, formProps); 136 size = travelAccounts.size(); 137 assertTrue("# of Travel Accounts should be > 200", size > 200); 138 } 139 140 }