litesoft
@ 947
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 |
// This Source Code is in the Public Domain per: http://unlicense.org package org.litesoft.bo.views; import junit.framework.*; import org.litesoft.bo.*; import org.litesoft.bo.BoAttribute.*; public class FilterUtilTest extends TestCase { private MockBoMetaData mMetaData; private BoAccessorFilters mBase; private BoAccessorFilters mCurrent; private static final String FIRST_NAME = "first"; private static final String LAST_NAME = "last"; private static final String DOB = "dob"; private static final String LONG_FIELD = "id2"; private static final String STRING_FIELD = "id1"; public static TestSuite suite() { return new TestSuite( FilterUtilTest.class ); } public FilterUtilTest( String name ) { super( name ); } public static void main( String[] args ) { junit.textui.TestRunner.run( suite() ); } @Override protected void setUp() { mMetaData = new MockBoMetaData(); mMetaData.addAttribute( STRING_FIELD, AttributeType.String ); mMetaData.addAttribute( LONG_FIELD, AttributeType.Long ); mMetaData.addAttribute( FIRST_NAME, AttributeType.String ); mMetaData.addAttribute( LAST_NAME, AttributeType.String ); mMetaData.addAttribute( DOB, AttributeType.CalendarYMD ); mBase = new BoAccessorFilters(); mCurrent = new BoAccessorFilters(); } public void testNeedsRefreshEmpty() { assertFalse(); } public void testNeedsRefreshUFSI() // unique field - string identity { mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); assertTrue(); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "12" ); assertTrue(); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); assertFalse(); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "1234" ); assertFalse(); } public void testNeedsRefreshUFMF() // unique field - multiple fields { mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); assertFalse(); mCurrent.setFilter( BoAccessorFilterType.Unique, LONG_FIELD, "12" ); assertFalse(); mBase.setFilter( BoAccessorFilterType.Unique, LONG_FIELD, "123" ); assertTrue(); mCurrent.setFilter( BoAccessorFilterType.Unique, LONG_FIELD, "1234" ); assertTrue(); mCurrent.setFilter( BoAccessorFilterType.Unique, LONG_FIELD, "123" ); assertFalse(); } public void testNeedsRefreshNUFSM() // non-unique fields - string matching { mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Sm" ); assertTrue(); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Sm" ); assertFalse(); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Smi" ); assertFalse(); mCurrent.setFilter( BoAccessorFilterType.Regular, FIRST_NAME, "G" ); assertFalse(); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "S" ); assertTrue(); } public void testNeedsRefreshNUFFS() // non-unique fields - field switching { mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Sm" ); mCurrent.setFilter( BoAccessorFilterType.Regular, FIRST_NAME, "G" ); assertTrue(); } public void testNeedsRefreshUONU() // unique overrides non-unique { mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Sm" ); assertFalse(); } public void testNeedsRefreshUONU2() // unique overrides non-unique { mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Sm" ); assertFalse(); } public void testNeedsRefreshUONU3() // unique overrides non-unique { mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Smi" ); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "Smi" ); assertFalse(); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); assertTrue(); } public void testNeedsRefreshCI() // case-insensitivity { mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "ABC" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "abc" ); mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "SMITH" ); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "smith" ); assertFalse(); mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "abc" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "ABC" ); mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "smith" ); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "SMITH" ); assertFalse(); } public void testNeedsRefreshEWCLC() // expressions: wild card last character { mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "S" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123*" ); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "S*" ); assertFalse(); mBase.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123*" ); mBase.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "S*" ); mCurrent.setFilter( BoAccessorFilterType.Unique, STRING_FIELD, "123" ); mCurrent.setFilter( BoAccessorFilterType.Regular, LAST_NAME, "S" ); assertFalse(); } private void assertFalse() { assertFalse( FilterUtil.needsRefresh( mMetaData, mBase, mCurrent ) ); } private void assertTrue() { assertTrue( FilterUtil.needsRefresh( mMetaData, mBase, mCurrent ) ); } } |
Commits for litesoft/trunk/Java/core/Anywhere/tests/org/litesoft/bo/views/FilterUtilTest.java
Revision | Author | Commited | Message |
---|---|---|---|
947 Diff | GeorgeS | Fri 06 Jun, 2014 23:36:56 +0000 | Correct Spelling of package! |
863 Diff | GeorgeS | Fri 16 Nov, 2012 22:14:29 +0000 | |
767 Diff | GeorgeS | Sat 14 Jul, 2012 18:19:39 +0000 | |
216 Diff | GeorgeS | Wed 18 May, 2011 13:44:57 +0000 | |
49 Diff | GeorgeS | Mon 12 Apr, 2010 02:59:10 +0000 | License Text |
2 | GeorgeS | Sun 07 Feb, 2010 12:50:58 +0000 |