1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 package ifc.sdbc;
25 
26 import lib.MultiMethodTest;
27 
28 import com.sun.star.sdbc.SQLException;
29 import com.sun.star.sdbc.XResultSet;
30 import com.sun.star.sdbc.XRow;
31 import com.sun.star.sdbc.XRowUpdate;
32 import com.sun.star.uno.UnoRuntime;
33 
34 /**
35 /**
36 * Testing <code>com.sun.star.sdbc.XResultSet</code>
37 * interface methods :
38 * <ul>
39 *  <li><code> next()</code></li>
40 *  <li><code> isBeforeFirst()</code></li>
41 *  <li><code> isAfterLast()</code></li>
42 *  <li><code> isFirst()</code></li>
43 *  <li><code> isLast()</code></li>
44 *  <li><code> beforeFirst()</code></li>
45 *  <li><code> afterLast()</code></li>
46 *  <li><code> first()</code></li>
47 *  <li><code> last()</code></li>
48 *  <li><code> getRow()</code></li>
49 *  <li><code> absolute()</code></li>
50 *  <li><code> relative()</code></li>
51 *  <li><code> previous()</code></li>
52 *  <li><code> refreshRow()</code></li>
53 *  <li><code> rowUpdated()</code></li>
54 *  <li><code> rowInserted()</code></li>
55 *  <li><code> rowDeleted()</code></li>
56 *  <li><code> getStatement()</code></li>
57 * </ul> <p>
58 * This test needs the following object relations :
59 * <ul>
60 *  <li> <code>'XResultSet.hasStatement'</code> (<b>optional</b> of type
61 * <code>Object</code>):
62 *  it the relation exists than <code>getStatement</code> method
63 *  must not return <code>null</code> </li>
64 * <ul> <p>
65 * Test places DB cursor to different positions and then checks
66 * its current position. <p>
67 * Test is <b> NOT </b> multithread compilant. <p>
68 * @see com.sun.star.sdbc.XResultSet
69 */
70 public class _XResultSet extends MultiMethodTest {
71 
72     // oObj filled by MultiMethodTest
73     public XResultSet oObj = null ;
74 
75     /**
76      * Positions the cursor to the first row.
77      * Forces method tests to be executed in definite order.
78      */
79     public void before() {
80         try {
81             oObj.last() ;
82             log.println("Totally number of rows is " + oObj.getRow()) ;
83             oObj.first() ;
84         } catch (SQLException e) {
85             log.println("Ignored exception :") ;
86             e.printStackTrace(log);
87         }
88 
89         executeMethod("isBeforeFirst()") ;
90         executeMethod("isAfterLast()") ;
91         executeMethod("isLast()") ;
92         executeMethod("isFirst()") ;
93         executeMethod("next()") ;
94         executeMethod("previous()") ;
95     }
96 
97     /**
98     * Places the cursor before the first row. <p>
99     * Has <b>OK</b> status if no exceptions were thrown.
100     */
101     public void _beforeFirst() {
102         try {
103             oObj.beforeFirst() ;
104         } catch (SQLException e) {
105             log.println("Exception occured :") ;
106             e.printStackTrace(log) ;
107             tRes.tested("beforeFirst()", false) ;
108             return ;
109         }
110         tRes.tested("beforeFirst()", true) ;
111     }
112 
113     /**
114     * The method is called immediatly after <code>beforeFirst</code>
115     * method test. <p>
116     * Has <b>OK</b> status if method returns <code>true</code>. <p>
117     * The following method tests are to be completed successfully before :
118     * <ul>
119     *  <li> <code> beforeFirst </code> : to position cursor before
120     *   the first row. </li>
121     * </ul>
122     */
123     public void _isBeforeFirst() {
124         requiredMethod("beforeFirst()") ;
125 
126         boolean result = true ;
127 
128         try {
129             result = oObj.isBeforeFirst() ;
130         } catch (SQLException e) {
131             log.println("Exception occured :") ;
132             e.printStackTrace(log) ;
133             result = false ;
134         }
135         tRes.tested("isBeforeFirst()", result) ;
136     }
137 
138     /**
139     * Places the cursor after the last row. <p>
140     * Has <b>OK</b> status if no exceptions were thrown.
141     */
142     public void _afterLast() {
143         try {
144             oObj.afterLast() ;
145         } catch (SQLException e) {
146             log.println("Exception occured :") ;
147             e.printStackTrace(log) ;
148             tRes.tested("afterLast()", false) ;
149             return ;
150         }
151         tRes.tested("afterLast()", true) ;
152     }
153 
154     /**
155     * The method is called immediatly after <code>afterLast</code>
156     * method test. <p>
157     * Has <b>OK</b> status if method returns <code>true</code> <p>
158     * The following method tests are to be completed successfully before :
159     * <ul>
160     *  <li> <code> afterLast </code> : to position cursor after
161     *   the last row. </li>
162     * </ul>
163     */
164     public void _isAfterLast() {
165         requiredMethod("afterLast()") ;
166 
167         boolean result = true ;
168 
169         try {
170             result = oObj.isAfterLast() ;
171         } catch (SQLException e) {
172             log.println("Exception occured :") ;
173             e.printStackTrace(log) ;
174             result = false ;
175         }
176         tRes.tested("isAfterLast()", result) ;
177     }
178 
179     /**
180     * Places the cursor on the first row. <p>
181     * Has <b>OK</b> status if no exceptions were thrown.
182     */
183     public void _first() {
184         try {
185             oObj.first() ;
186         } catch (SQLException e) {
187             log.println("Exception occured :") ;
188             e.printStackTrace(log) ;
189             tRes.tested("first()", false) ;
190             return ;
191         }
192         tRes.tested("first()", true) ;
193     }
194 
195     /**
196     * The method is called immediatly after <code>first</code>
197     * method test. <p>
198     * Has <b>OK</b> status if method returns <code>true</code>. <p>
199     * The following method tests are to be completed successfully before :
200     * <ul>
201     *  <li> <code> first </code> : to position cursor on
202     *   the first row. </li>
203     * </ul>
204     */
205     public void _isFirst() {
206         requiredMethod("first()") ;
207 
208         boolean result = true ;
209 
210         try {
211             result = oObj.isFirst() ;
212         } catch (SQLException e) {
213             log.println("Exception occured :") ;
214             e.printStackTrace(log) ;
215             result = false ;
216         }
217         tRes.tested("isFirst()", result) ;
218     }
219 
220     /**
221     * Places the cursor on the last row. <p>
222     * Has <b>OK</b> status if no exceptions were thrown.
223     */
224     public void _last() {
225         try {
226             oObj.last() ;
227         } catch (SQLException e) {
228             log.println("Exception occured :") ;
229             e.printStackTrace(log) ;
230             tRes.tested("last()", false) ;
231             return ;
232         }
233         tRes.tested("last()", true) ;
234     }
235 
236     /**
237     * The method is called immediatly after <code>last</code>
238     * method test. <p>
239     * Has <b>OK</b> status if method returns <code>true</code>. <p>
240     * The following method tests are to be completed successfully before :
241     * <ul>
242     *  <li> <code> last </code> : to position cursor on
243     *   the last row. </li>
244     * </ul>
245     */
246     public void _isLast() {
247         requiredMethod("last()") ;
248         boolean result = true ;
249 
250         try {
251             result = oObj.isLast() ;
252         } catch (SQLException e) {
253             log.println("Exception occured :") ;
254             e.printStackTrace(log) ;
255             result = false ;
256         }
257         tRes.tested("isLast()", result) ;
258     }
259 
260     /**
261     * Places the cursor on the row number 1. <p>
262     * Has <b>OK</b> status if no exceptions were thrown.
263     */
264     public void _absolute() {
265         boolean result = true ;
266 
267         try {
268             oObj.absolute(1) ;
269         } catch (SQLException e) {
270             log.println("Exception occured :") ;
271             e.printStackTrace(log) ;
272             result = false ;
273         }
274         tRes.tested("absolute()", result) ;
275     }
276 
277     /**
278     * The method is called immediatly after <code>absolute</code>
279     * method test. <p>
280     * Has <b>OK</b> status if method returns 1. <p>
281     * The following method tests are to be completed successfully before :
282     * <ul>
283     *  <li> <code> absolute </code> : to position cursor on
284     *   the row number 1. </li>
285     * </ul>
286     */
287     public void _getRow() {
288         requiredMethod("absolute()");
289         boolean result = true;
290 
291         try {
292             result &= oObj.getRow() == 1;
293         } catch (SQLException e) {
294             log.println("Exception occured:");
295             e.printStackTrace(log);
296             result = false;
297         }
298 
299         tRes.tested("getRow()", result);
300     }
301 
302     /**
303     * Positions the cursor to the next row. Current row
304     * number is retrieved before and after method call. <p>
305     * Has <b>OK</b> status if current row number increases
306     * by 1 after method call.
307     */
308     public void _next() {
309         boolean result = true ;
310 
311         try {
312             int prevRow = oObj.getRow() ;
313             oObj.next() ;
314 
315             log.println("Row was : " + prevRow + ", row is : " + oObj.getRow());
316             result &= prevRow + 1 == oObj.getRow() ;
317         } catch (SQLException e) {
318             log.println("Exception occured :") ;
319             e.printStackTrace(log) ;
320             result = false ;
321         }
322         tRes.tested("next()", result) ;
323     }
324 
325     /**
326     * Positions the cursor to the previous row. Current row
327     * number is retrieved before and after method call. <p>
328     * Has <b>OK</b> status if current row number decreases
329     * by 1 after method call.
330     */
331     public void _previous() {
332         boolean result = true ;
333 
334         try {
335             int prevRow = oObj.getRow() ;
336             oObj.previous() ;
337 
338             log.println("Row was : " + prevRow + ", row is : " + oObj.getRow());
339             result &= prevRow - 1 == oObj.getRow() ;
340         } catch (SQLException e) {
341             log.println("Exception occured :") ;
342             e.printStackTrace(log) ;
343             result = false ;
344         }
345         tRes.tested("previous()", result) ;
346     }
347 
348     /**
349     * Positions the cursor relatively by 2 rows forward.
350     * Current row number is retrieved before and after method call. <p>
351     * Has <b>OK</b> status if current row number increases
352     * by 2 after method call.
353     */
354     public void _relative() {
355         boolean result = true ;
356 
357         try {
358             oObj.first() ;
359             int prevRow = oObj.getRow() ;
360             oObj.relative(2) ;
361 
362             log.println("Row was : " + prevRow + ", row is : " + oObj.getRow());
363 
364             result &= prevRow + 2 == oObj.getRow() ;
365         } catch (SQLException e) {
366             log.println("Exception occured :") ;
367             e.printStackTrace(log) ;
368             result = false ;
369         }
370         tRes.tested("relative()", result) ;
371     }
372 
373     /**
374     * If component supports XRow and XRowUpdate then:
375     *   test saves current value of string field, updates string,
376     *   calls refreshRow() and checks that value of
377     *   string field was refetched from DB
378     * else: just calls method.<p>
379     * Has <b>OK</b> status if no exceptions were thrown and value after
380     * refreshRow() equals to saved value.
381     */
382     public void _refreshRow() {
383         XRowUpdate xRowUpdate = (XRowUpdate)
384             UnoRuntime.queryInterface(XRowUpdate.class, oObj);
385         XRow xRow = (XRow)UnoRuntime.queryInterface(XRow.class, oObj);
386 
387         if (xRowUpdate == null || xRow == null) {
388             log.println("Test must be modified because XRow or XRowUpdate is't supported");
389             log.println("Only call method");
390             try {
391                 oObj.refreshRow() ;
392                 tRes.tested("refreshRow()", true) ;
393             } catch (SQLException e) {
394                 log.println("Exception occured :") ;
395                 e.printStackTrace(log) ;
396                 tRes.tested("refreshRow()", false) ;
397             }
398         } else {
399             log.println("Testing of refreshRow()...");
400             try {
401                 String oldValue = xRow.getString(util.DBTools.TST_STRING);
402                 log.println("Old value: " + oldValue);
403                 xRowUpdate.updateString(util.DBTools.TST_STRING,
404                     "Test method refreshRow");
405                 log.println("New value: "
406                     + xRow.getString(util.DBTools.TST_STRING));
407                 oObj.refreshRow();
408                 String valAfterRefresh =
409                     xRow.getString(util.DBTools.TST_STRING);
410                 log.println("Value after refresh: " + valAfterRefresh);
411                 tRes.tested("refreshRow()", valAfterRefresh.equals(oldValue));
412             } catch(SQLException e) {
413                 log.println("Exception occured :");
414                 e.printStackTrace(log);
415                 tRes.tested("refreshRow()", false);
416             }
417         }
418     }
419 
420     /**
421     * Just the method is called. <p>
422     * Has <b>OK</b> status if no exceptions were thrown.
423     */
424     public void _rowUpdated() {
425 
426         try {
427             boolean res = oObj.rowUpdated() ;
428             tRes.tested("rowUpdated()", true) ;
429         } catch (SQLException e) {
430             log.println("Exception occured :") ;
431             e.printStackTrace(log) ;
432             tRes.tested("rowUpdated()", false) ;
433         }
434     }
435 
436     /**
437     * Just the method is called. <p>
438     * Has <b>OK</b> status if no exceptions were thrown.
439     */
440     public void _rowInserted() {
441         try {
442             boolean res = oObj.rowInserted() ;
443             tRes.tested("rowInserted()", true) ;
444         } catch (SQLException e) {
445             log.println("Exception occured :") ;
446             e.printStackTrace(log) ;
447             tRes.tested("rowInserted()", false) ;
448         }
449     }
450 
451     /**
452     * Just the method is called. <p>
453     * Has <b>OK</b> status if no exceptions were thrown.
454     */
455     public void _rowDeleted() {
456         try {
457             boolean res = oObj.rowDeleted() ;
458             tRes.tested("rowDeleted()", true) ;
459         } catch (SQLException e) {
460             log.println("Exception occured :") ;
461             e.printStackTrace(log) ;
462             tRes.tested("rowDeleted()", false) ;
463         }
464     }
465 
466     /**
467     * Just the method is called. <p>
468     * Has <b>OK</b> status if the statement returned isn't null or
469     * the relation exists that informs that statement absent (e.g. for
470     * MetaData row set).
471     */
472     public void _getStatement() {
473         try {
474             boolean hasStatement =
475                 tEnv.getObjRelation("XResultSet.hasStatement") != null ;
476             Object res = oObj.getStatement() ;
477             tRes.tested("getStatement()",
478                 (hasStatement && res != null) || !hasStatement) ;
479         } catch (SQLException e) {
480             log.println("Exception occured :") ;
481             e.printStackTrace(log) ;
482             tRes.tested("getStatement()", false) ;
483         }
484     }
485 
486     /**
487      * Moves the cursor to the first row to avoid affection to
488      * the following interfaces tests
489      */
490     public void after() {
491         log.println("Finally moving cursor to the first row ...");
492         try {
493             oObj.first();
494         } catch (SQLException e) {
495             log.println("Exception occured :") ;
496             e.printStackTrace(log) ;
497         }
498     }
499 
500 }  // finish class _XResultSet
501 
502