/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
package ifc.sdbcx;
import lib.MultiMethodTest;
import com.sun.star.sdbc.SQLException;
import com.sun.star.sdbcx.XRowLocate;
/**
* Testing com.sun.star.sdbcx.XRowLocate
* interface methods :
*
getBookmark()
moveToBookmark()
moveRelativeToBookmark()
compareBookmarks()
hasOrderedBookmarks()
hashBookmark()
* Object relations needed : *
XRowLocate.HasOrderedBookmarks
(optional):
* Boolean
type. If information about bookmark ordering
* of object tested exists it placed in this relation.
* @see com.sun.star.sdbcx.XRowLocate
*/
public class _XRowLocate extends MultiMethodTest {
// oObj filled by MultiMethodTest
public XRowLocate oObj = null ;
private Object bookmark1 = null, bookmark2 = null ;
/**
* Gets the bookmark of the current cursor position and
* stores it for other methods use.
* Has OK status if method returns not null
* XNameAccess
object, FAILED otherwise.
*/
public void _getBookmark() {
try {
bookmark1 = oObj.getBookmark() ;
} catch (SQLException e) {
log.println("Exception occured :" + e) ;
}
tRes.tested("getBookmark()", bookmark1 != null) ;
}
/**
* Moves to bookmark previously created by method _getBookmark
* then creates new bookmark and compare it to the first one. The
* row difference must be equal to 0.
* Method tests to be completed successfully before : *
getBookmark()
: to have a bookmark to move to.moveRelativeToBookmark()
: to move the cursor from
* the initial position, to check if it returns back.
* Has OK status difference between positions of bookmarks (where
* cursor was moved to and created new one) equals to 0 and no
* exceptions occured, FAILED otherwise.
*/
public void _moveToBookmark() {
requiredMethod("getBookmark()") ;
executeMethod("moveRelativeToBookmark()") ;
int comparison = -1 ;
Object tmpBookmark = null ;
try {
synchronized(oObj) {
oObj.moveToBookmark(bookmark1) ;
tmpBookmark = oObj.getBookmark() ;
}
comparison = oObj.compareBookmarks(bookmark1, tmpBookmark) ;
} catch (SQLException e) {
log.println("Exception occured :" + e) ;
}
tRes.tested("moveToBookmark()", comparison == 0) ;
}
/**
* Moves the cursor to the position with offset 2 from the
* bookmark created by _getBookmark()
method and
* then creates a bookmark of new position.
* Method tests to be completed successfully before : *
getBookmark()
: to have a bookmark to move to.
* Has OK status if no exceptions occured while method call.
*/
public void _moveRelativeToBookmark() {
requiredMethod("getBookmark()") ;
boolean result = true ;
try {
synchronized (oObj) {
oObj.moveRelativeToBookmark(bookmark1, 1) ;
bookmark2 = oObj.getBookmark() ;
}
} catch (SQLException e) {
log.println("Exception occured :" + e) ;
result = false ;
}
tRes.tested("moveRelativeToBookmark()", result) ;
}
/**
* Compares bookmarks created in getBookmark()
and
* moveRelativeToBokkmark()
methods.
* Method tests to be completed successfully before :
*
getBookmark()
: to have first bookmark to compare.moveRelativeToBookmark()
: to have second
* bookmark to compare.* Has OK status if difference in bookmark positions equals to 2. */ public void _compareBookmarks() { requiredMethod("getBookmark()") ; requiredMethod("moveRelativeToBookmark()") ; int comparison = 0 ; int comparison1 = 0 ; try { comparison = oObj.compareBookmarks(bookmark1, bookmark2) ; comparison1 = oObj.compareBookmarks(bookmark1, bookmark1) ; } catch (SQLException e) { log.println("Exception occured :" + e) ; } if (comparison != -1) { log.println("! Wrong compare number :" + comparison) ; } tRes.tested("compareBookmarks()", comparison == -1 && comparison1 == 0) ; } /** * Calls method. If relation is not found, returned result is not * checked.
* Has OK status if method returned right value (in case if relation * and value to compare to exist), or just successfully returned * (in case of no relation). */ public void _hasOrderedBookmarks() { boolean result = true ; boolean res = true ; // Optional relation Boolean has = (Boolean) tEnv.getObjRelation ("XRowLocate.HasOrderedBookmarks") ; try { res = oObj.hasOrderedBookmarks() ; } catch (SQLException e) { log.println("Exception occured :" + e) ; result = false ; } if (has == null) { log.println("Optional relation not found - result not checked") ; } else { result &= res == has.booleanValue() ; } tRes.tested("hasOrderedBookmarks()", result) ; } /** * Gets hash values of two previously created bookmarks of different * cursor positions and compares them.
* Method tests to be completed successfully before : *
getBookmark()
: to have first bookmark.moveRelativeToBookmark()
: to have second
* bookmark.* Has OK status if hash values of two bookmarks are different. */ public void _hashBookmark() { requiredMethod("getBookmark()") ; requiredMethod("moveRelativeToBookmark()") ; boolean result = true ; try { int hash1 = oObj.hashBookmark(bookmark1) ; int hash2 = oObj.hashBookmark(bookmark2) ; log.println("1st hash = " + hash1 + ", 2nd = " + hash2) ; result = hash1 != hash2 ; } catch (SQLException e) { log.println("Exception occured :" + e) ; result = false ; } tRes.tested("hashBookmark()", result) ; } } // finish class _XRowLocate