01: /* Copyright (C) 2004 - 2007 db4objects Inc. http://www.db4o.com
02:
03: This file is part of the db4o open source object database.
04:
05: db4o is free software; you can redistribute it and/or modify it under
06: the terms of version 2 of the GNU General Public License as published
07: by the Free Software Foundation and as clarified by db4objects' GPL
08: interpretation policy, available at
09: http://www.db4o.com/about/company/legalpolicies/gplinterpretation/
10: Alternatively you can write to db4objects, Inc., 1900 S Norfolk Street,
11: Suite 350, San Mateo, CA 94403, USA.
12:
13: db4o is distributed in the hope that it will be useful, but WITHOUT ANY
14: WARRANTY; without even the implied warranty of MERCHANTABILITY or
15: FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16: for more details.
17:
18: You should have received a copy of the GNU General Public License along
19: with this program; if not, write to the Free Software Foundation, Inc.,
20: 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21: package com.db4o.db4ounit.common.soda.arrays.typed;
22:
23: import com.db4o.query.*;
24:
25: public class STArrIntegerTTestCase extends
26: com.db4o.db4ounit.common.soda.util.SodaBaseTestCase {
27:
28: public int[] intArr;
29:
30: public STArrIntegerTTestCase() {
31: }
32:
33: public STArrIntegerTTestCase(int[] arr) {
34: intArr = arr;
35: }
36:
37: public Object[] createData() {
38: return new Object[] {
39: new STArrIntegerTTestCase(),
40: new STArrIntegerTTestCase(new int[0]),
41: new STArrIntegerTTestCase(new int[] { 0, 0 }),
42: new STArrIntegerTTestCase(new int[] { 1, 17,
43: Integer.MAX_VALUE - 1 }),
44: new STArrIntegerTTestCase(new int[] { 3, 17, 25,
45: Integer.MAX_VALUE - 2 }) };
46: }
47:
48: public void testDefaultContainsOne() {
49: Query q = newQuery();
50:
51: q.constrain(new STArrIntegerTTestCase(new int[] { 17 }));
52: expect(q, new int[] { 3, 4 });
53: }
54:
55: public void testDefaultContainsTwo() {
56: Query q = newQuery();
57:
58: q.constrain(new STArrIntegerTTestCase(new int[] { 17, 25 }));
59: expect(q, new int[] { 4 });
60: }
61:
62: public void testDescendOne() {
63: Query q = newQuery();
64:
65: q.constrain(STArrIntegerTTestCase.class);
66: q.descend("intArr").constrain(new Integer(17));
67: expect(q, new int[] { 3, 4 });
68: }
69:
70: public void testDescendTwo() {
71: Query q = newQuery();
72:
73: q.constrain(STArrIntegerTTestCase.class);
74: Query qElements = q.descend("intArr");
75: qElements.constrain(new Integer(17));
76: qElements.constrain(new Integer(25));
77: expect(q, new int[] { 4 });
78: }
79:
80: public void testDescendSmaller() {
81: Query q = newQuery();
82:
83: q.constrain(STArrIntegerTTestCase.class);
84: Query qElements = q.descend("intArr");
85: qElements.constrain(new Integer(3)).smaller();
86: expect(q, new int[] { 2, 3 });
87: }
88:
89: public void testDescendNotSmaller() {
90: Query q = newQuery();
91:
92: q.constrain(STArrIntegerTTestCase.class);
93: Query qElements = q.descend("intArr");
94: qElements.constrain(new Integer(3)).smaller();
95: expect(q, new int[] { 2, 3 });
96: }
97:
98: }
|