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.ordered;
22:
23: import com.db4o.query.*;
24:
25: public class STOStringTestCase extends
26: com.db4o.db4ounit.common.soda.util.SodaBaseTestCase {
27:
28: public String foo;
29:
30: public STOStringTestCase() {
31: }
32:
33: public STOStringTestCase(String str) {
34: this .foo = str;
35: }
36:
37: public Object[] createData() {
38: return new Object[] { new STOStringTestCase(null),
39: new STOStringTestCase("bbb"),
40: new STOStringTestCase("bbb"),
41: new STOStringTestCase("dod"),
42: new STOStringTestCase("aaa"),
43: new STOStringTestCase("Xbb"),
44: new STOStringTestCase("bbq") };
45: }
46:
47: public void testAscending() {
48: Query q = newQuery();
49: q.constrain(STOStringTestCase.class);
50: q.descend("foo").orderAscending();
51:
52: expectOrdered(q, new int[] { 5, 4, 1, 2, 6, 3, 0 });
53: }
54:
55: public void testDescending() {
56: Query q = newQuery();
57: q.constrain(STOStringTestCase.class);
58: q.descend("foo").orderDescending();
59:
60: expectOrdered(q, new int[] { 3, 6, 2, 1, 4, 5, 0 });
61: }
62:
63: public void testAscendingLike() {
64: Query q = newQuery();
65: q.constrain(STOStringTestCase.class);
66: Query qStr = q.descend("foo");
67: qStr.constrain("b").like();
68: qStr.orderAscending();
69:
70: expectOrdered(q, new int[] { 5, 1, 2, 6 });
71: }
72:
73: public void testDescendingContains() {
74: Query q = newQuery();
75: q.constrain(STOStringTestCase.class);
76: Query qStr = q.descend("foo");
77: qStr.constrain("b").contains();
78: qStr.orderDescending();
79:
80: expectOrdered(q, new int[] { 6, 2, 1, 5 });
81: }
82: }
|