1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski package ifc.sdbc;
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski import ifc.sdb._XRowSetApproveBroadcaster;
27*b1cdbd2cSJim Jagielski import lib.MultiMethodTest;
28*b1cdbd2cSJim Jagielski import lib.StatusException;
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski import com.sun.star.lang.EventObject;
31*b1cdbd2cSJim Jagielski import com.sun.star.sdbc.SQLException;
32*b1cdbd2cSJim Jagielski import com.sun.star.sdbc.XRowSet;
33*b1cdbd2cSJim Jagielski import com.sun.star.sdbc.XRowSetListener;
34*b1cdbd2cSJim Jagielski 
35*b1cdbd2cSJim Jagielski /**
36*b1cdbd2cSJim Jagielski * Testing <code>com.sun.star.sdbc.XRowSet</code>
37*b1cdbd2cSJim Jagielski * interface methods :
38*b1cdbd2cSJim Jagielski * <ul>
39*b1cdbd2cSJim Jagielski *  <li><code> execute()</code></li>
40*b1cdbd2cSJim Jagielski *  <li><code> addRowSetListener()</code></li>
41*b1cdbd2cSJim Jagielski *  <li><code> removeRowSetListener()</code></li>
42*b1cdbd2cSJim Jagielski * </ul> <p>
43*b1cdbd2cSJim Jagielski * Required object relations :
44*b1cdbd2cSJim Jagielski * <ul>
45*b1cdbd2cSJim Jagielski * <li> <code>'XRowSetApproveBroadcaster.ApproveChecker'</code>:
46*b1cdbd2cSJim Jagielski *      implementation of inner interface
47*b1cdbd2cSJim Jagielski *      <code>ifs.sdb._XRowSetApproveBroadcaster.RowSetApproveChecker</code>
48*b1cdbd2cSJim Jagielski *      which can move cursor within a rowset, change row, and change the
49*b1cdbd2cSJim Jagielski *      whole rowset. </li>
50*b1cdbd2cSJim Jagielski * </ul> <p>
51*b1cdbd2cSJim Jagielski * It is better to recreate the object after test, because of unknown
52*b1cdbd2cSJim Jagielski * actions made by <code>RowSetApproveChecker</code> interface implementation.
53*b1cdbd2cSJim Jagielski * @see com.sun.star.sdbc.XRowSet
54*b1cdbd2cSJim Jagielski * @see ifc.sdb._XRowSetApproveBroadcaster
55*b1cdbd2cSJim Jagielski */
56*b1cdbd2cSJim Jagielski public class _XRowSet extends MultiMethodTest {
57*b1cdbd2cSJim Jagielski 
58*b1cdbd2cSJim Jagielski     // oObj filled by MultiMethodTest
59*b1cdbd2cSJim Jagielski     public XRowSet oObj = null ;
60*b1cdbd2cSJim Jagielski     private _XRowSetApproveBroadcaster.RowSetApproveChecker checker = null ;
61*b1cdbd2cSJim Jagielski     private TestListener listener = new TestListener() ;
62*b1cdbd2cSJim Jagielski 
63*b1cdbd2cSJim Jagielski     private class TestListener implements XRowSetListener {
64*b1cdbd2cSJim Jagielski         public boolean cursorMoved = false ;
65*b1cdbd2cSJim Jagielski         public boolean rowChanged = false ;
66*b1cdbd2cSJim Jagielski         public boolean rowSetChanged = false ;
67*b1cdbd2cSJim Jagielski 
reset()68*b1cdbd2cSJim Jagielski         public void reset() {
69*b1cdbd2cSJim Jagielski             cursorMoved = false ;
70*b1cdbd2cSJim Jagielski             rowChanged = false ;
71*b1cdbd2cSJim Jagielski             rowSetChanged = false ;
72*b1cdbd2cSJim Jagielski         }
cursorMoved(EventObject ev)73*b1cdbd2cSJim Jagielski         public void cursorMoved(EventObject ev) {
74*b1cdbd2cSJim Jagielski             cursorMoved = true ;
75*b1cdbd2cSJim Jagielski         }
rowChanged(EventObject ev)76*b1cdbd2cSJim Jagielski         public void rowChanged(EventObject ev) {
77*b1cdbd2cSJim Jagielski             rowChanged = true ;
78*b1cdbd2cSJim Jagielski         }
rowSetChanged(EventObject ev)79*b1cdbd2cSJim Jagielski         public void rowSetChanged(EventObject ev) {
80*b1cdbd2cSJim Jagielski             rowSetChanged = true ;
81*b1cdbd2cSJim Jagielski         }
disposing(EventObject ev)82*b1cdbd2cSJim Jagielski         public void disposing(EventObject ev) {}
83*b1cdbd2cSJim Jagielski     }
84*b1cdbd2cSJim Jagielski 
85*b1cdbd2cSJim Jagielski     /**
86*b1cdbd2cSJim Jagielski     * Retrieves relation.
87*b1cdbd2cSJim Jagielski     * @throw StatusException If relation not found.
88*b1cdbd2cSJim Jagielski     */
before()89*b1cdbd2cSJim Jagielski     public void before() throws StatusException {
90*b1cdbd2cSJim Jagielski         checker = (_XRowSetApproveBroadcaster.RowSetApproveChecker)
91*b1cdbd2cSJim Jagielski             tEnv.getObjRelation("XRowSetApproveBroadcaster.ApproveChecker") ;
92*b1cdbd2cSJim Jagielski 
93*b1cdbd2cSJim Jagielski         if (checker == null) {
94*b1cdbd2cSJim Jagielski             log.println("Required relation not found !!!") ;
95*b1cdbd2cSJim Jagielski             throw new StatusException("Required relation not found !!!",
96*b1cdbd2cSJim Jagielski                 new NullPointerException()) ;
97*b1cdbd2cSJim Jagielski         }
98*b1cdbd2cSJim Jagielski     }
99*b1cdbd2cSJim Jagielski 
100*b1cdbd2cSJim Jagielski     /**
101*b1cdbd2cSJim Jagielski     * Reexecutes the RowSet and checks that listener was called. <p>
102*b1cdbd2cSJim Jagielski     * Has OK status if no exceptions were rised and listener was called.
103*b1cdbd2cSJim Jagielski     */
_execute()104*b1cdbd2cSJim Jagielski     public void _execute() {
105*b1cdbd2cSJim Jagielski         requiredMethod("addRowSetListener()");
106*b1cdbd2cSJim Jagielski         listener.reset();
107*b1cdbd2cSJim Jagielski         boolean result = true ;
108*b1cdbd2cSJim Jagielski 
109*b1cdbd2cSJim Jagielski         try {
110*b1cdbd2cSJim Jagielski             oObj.execute() ;
111*b1cdbd2cSJim Jagielski         } catch (SQLException e) {
112*b1cdbd2cSJim Jagielski             log.println("Exception occured :" + e) ;
113*b1cdbd2cSJim Jagielski             result = false ;
114*b1cdbd2cSJim Jagielski         }
115*b1cdbd2cSJim Jagielski 
116*b1cdbd2cSJim Jagielski         tRes.tested("execute()", listener.rowSetChanged);
117*b1cdbd2cSJim Jagielski     }
118*b1cdbd2cSJim Jagielski 
119*b1cdbd2cSJim Jagielski     /**
120*b1cdbd2cSJim Jagielski     * Adds listener and calls methods moveCursor, changeRow,
121*b1cdbd2cSJim Jagielski     * changeRowSet of the relation and then checks if appropriate
122*b1cdbd2cSJim Jagielski     * methods of the listener were called. <p>
123*b1cdbd2cSJim Jagielski     * Has OK status if all listener methods were called.
124*b1cdbd2cSJim Jagielski     */
_addRowSetListener()125*b1cdbd2cSJim Jagielski     public void _addRowSetListener() {
126*b1cdbd2cSJim Jagielski         boolean result = true ;
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski         oObj.addRowSetListener(listener) ;
129*b1cdbd2cSJim Jagielski 
130*b1cdbd2cSJim Jagielski         checker.moveCursor() ;
131*b1cdbd2cSJim Jagielski         result &= listener.cursorMoved ;
132*b1cdbd2cSJim Jagielski         if (!listener.cursorMoved)
133*b1cdbd2cSJim Jagielski             log.println("cursorMoved event wasn't called") ;
134*b1cdbd2cSJim Jagielski         listener.reset() ;
135*b1cdbd2cSJim Jagielski 
136*b1cdbd2cSJim Jagielski         checker.changeRow() ;
137*b1cdbd2cSJim Jagielski         result &= listener.rowChanged ;
138*b1cdbd2cSJim Jagielski         if (!listener.rowChanged)
139*b1cdbd2cSJim Jagielski             log.println("rowChanged event wasn't called") ;
140*b1cdbd2cSJim Jagielski         listener.reset() ;
141*b1cdbd2cSJim Jagielski 
142*b1cdbd2cSJim Jagielski         checker.changeRowSet() ;
143*b1cdbd2cSJim Jagielski         result &= listener.rowSetChanged ;
144*b1cdbd2cSJim Jagielski         if (!listener.rowSetChanged)
145*b1cdbd2cSJim Jagielski             log.println("rowSetChanged event wasn't called") ;
146*b1cdbd2cSJim Jagielski         listener.reset() ;
147*b1cdbd2cSJim Jagielski 
148*b1cdbd2cSJim Jagielski         tRes.tested("addRowSetListener()", result) ;
149*b1cdbd2cSJim Jagielski     }
150*b1cdbd2cSJim Jagielski 
151*b1cdbd2cSJim Jagielski     /*
152*b1cdbd2cSJim Jagielski     * Removes listener added before, and checks for no listener
153*b1cdbd2cSJim Jagielski     * methods were called on response to rowSet manipulations. <p>
154*b1cdbd2cSJim Jagielski     * Methods to be successfully completed before :
155*b1cdbd2cSJim Jagielski     * <ul>
156*b1cdbd2cSJim Jagielski     * <li> <code>addRowSetListener()</code> </li>
157*b1cdbd2cSJim Jagielski     * </ul> <p>
158*b1cdbd2cSJim Jagielski     * Has OK status if no listeners methods were called.
159*b1cdbd2cSJim Jagielski     */
_removeRowSetListener()160*b1cdbd2cSJim Jagielski     public void _removeRowSetListener() {
161*b1cdbd2cSJim Jagielski         requiredMethod("addRowSetListener()") ;
162*b1cdbd2cSJim Jagielski 
163*b1cdbd2cSJim Jagielski         boolean result = true ;
164*b1cdbd2cSJim Jagielski 
165*b1cdbd2cSJim Jagielski         oObj.removeRowSetListener(listener) ;
166*b1cdbd2cSJim Jagielski 
167*b1cdbd2cSJim Jagielski         checker.moveCursor() ;
168*b1cdbd2cSJim Jagielski         result &= !listener.cursorMoved ;
169*b1cdbd2cSJim Jagielski         listener.reset() ;
170*b1cdbd2cSJim Jagielski 
171*b1cdbd2cSJim Jagielski         checker.changeRow() ;
172*b1cdbd2cSJim Jagielski         result &= !listener.rowChanged ;
173*b1cdbd2cSJim Jagielski         listener.reset() ;
174*b1cdbd2cSJim Jagielski 
175*b1cdbd2cSJim Jagielski         checker.changeRowSet() ;
176*b1cdbd2cSJim Jagielski         result &= !listener.rowSetChanged ;
177*b1cdbd2cSJim Jagielski 
178*b1cdbd2cSJim Jagielski         tRes.tested("removeRowSetListener()", result) ;
179*b1cdbd2cSJim Jagielski     }
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski     /**
182*b1cdbd2cSJim Jagielski     * Disposes test environment.
183*b1cdbd2cSJim Jagielski     */
after()184*b1cdbd2cSJim Jagielski     public void after() {
185*b1cdbd2cSJim Jagielski         disposeEnvironment() ;
186*b1cdbd2cSJim Jagielski     }
187*b1cdbd2cSJim Jagielski 
188*b1cdbd2cSJim Jagielski }  // finish class _XRowSet
189*b1cdbd2cSJim Jagielski 
190