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.test.legacy.soda.arrays.object;
22:
23: import com.db4o.query.*;
24: import com.db4o.test.legacy.soda.*;
25:
26: public class STArrStringO implements STClass {
27:
28: public static transient SodaTest st;
29:
30: Object strArr;
31:
32: public STArrStringO() {
33: }
34:
35: public STArrStringO(Object[] arr) {
36: strArr = arr;
37: }
38:
39: public Object[] store() {
40: return new Object[] {
41: new STArrStringO(),
42: new STArrStringO(new Object[] { null }),
43: new STArrStringO(new Object[] { null, null }),
44: new STArrStringO(new Object[] { "foo", "bar", "fly" }),
45: new STArrStringO(new Object[] { null, "bar", "wohay",
46: "johy" }) };
47: }
48:
49: public void testDefaultContainsOne() {
50: Query q = st.query();
51: Object[] r = store();
52: q.constrain(new STArrStringO(new Object[] { "bar" }));
53: st.expect(q, new Object[] { r[3], r[4] });
54: }
55:
56: public void testDefaultContainsTwo() {
57: Query q = st.query();
58: Object[] r = store();
59: q.constrain(new STArrStringO(new Object[] { "foo", "bar" }));
60: st.expect(q, new Object[] { r[3] });
61: }
62:
63: public void testDescendOne() {
64: Query q = st.query();
65: Object[] r = store();
66: q.constrain(STArrStringO.class);
67: q.descend("strArr").constrain("bar");
68: st.expect(q, new Object[] { r[3], r[4] });
69: }
70:
71: public void testDescendTwo() {
72: Query q = st.query();
73: Object[] r = store();
74: q.constrain(STArrStringO.class);
75: Query qElements = q.descend("strArr");
76: qElements.constrain("foo");
77: qElements.constrain("bar");
78: st.expect(q, new Object[] { r[3] });
79: }
80:
81: public void testDescendOneNot() {
82: Query q = st.query();
83: Object[] r = store();
84: q.constrain(STArrStringO.class);
85: q.descend("strArr").constrain("bar").not();
86: st.expect(q, new Object[] { r[0], r[1], r[2] });
87: }
88:
89: public void testDescendTwoNot() {
90: Query q = st.query();
91: Object[] r = store();
92: q.constrain(STArrStringO.class);
93: Query qElements = q.descend("strArr");
94: qElements.constrain("foo").not();
95: qElements.constrain("bar").not();
96: st.expect(q, new Object[] { r[0], r[1], r[2] });
97: }
98:
99: }
|