| <?xml version="1.0" encoding="UTF-8"?> |
| <!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd"> |
| <script:module xmlns:script="http://openoffice.org/2000/script" script:name="sdbcx_XRowLocate" script:language="StarBasic"> |
| |
| |
| '************************************************************************* |
| ' |
| ' 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. |
| ' |
| '************************************************************************* |
| |
| |
| |
| |
| |
| |
| |
| Sub RunTest() |
| |
| '************************************************************************* |
| ' INTERFACE: |
| ' com.sun.star.sdbcx.XRowLocate |
| '************************************************************************* |
| On Error Goto ErrHndl |
| Dim bOK As Boolean |
| Dim oBM1 As Variant |
| Dim oBM2 As Variant |
| Dim oBM3 As Variant |
| Dim oBM4 As Variant |
| Dim cDscr1 As String |
| Dim cDscr2 As String |
| |
| ReCreateObj() |
| |
| oObj.first() |
| |
| Test.StartMethod("getBookmark()") |
| bOK = true |
| oBM1 = oObj.getBookmark() |
| cDscr1 = oObj.getString(1) |
| Out.Log("Set bookmark to row " + cDscr1) |
| bOK = bOK AND NOT isNULL(oBM1) |
| Test.MethodTested("getBookmark()", bOK) |
| |
| Test.StartMethod("moveToBookmark()") |
| bOK = true |
| oObj.next() |
| cDscr2 = oObj.getString(1) |
| Out.Log("Now on " + cDscr2) |
| oObj.moveToBookmark(oBM1) |
| Out.Log("After movment on " + oObj.getString(1)) |
| bOK = bOK AND oObj.getString(1) = cDscr1 |
| Test.MethodTested("moveToBookmark()", bOK) |
| |
| Test.StartMethod("moveRelativeToBookmark()") |
| bOK = true |
| oObj.moveRelativeToBookmark(oBM1, 1) |
| Out.Log("After movment on " + oObj.getString(1)) |
| bOK = bOK AND oObj.getString(1) = cDscr2 |
| Test.MethodTested("moveRelativeToBookmark()", bOK) |
| |
| oBM2 = oObj.getBookmark() |
| |
| Test.StartMethod("compareBookmarks()") |
| bOK = true |
| ' if database driver supports ordered marks then |
| ' compareBookmarks should return values CompareBookmark::LESS or |
| ' CompareBookmark::GREATER in case when bookmarks are not equal |
| ' otherwise this method returnes only CompareBookmark::NOT_EQUAL |
| |
| if (oObj.hasOrderedBookmarks()) then |
| bOK = bOK AND oObj.compareBookmarks(oBM1, oBM1) = com.sun.star.sdbcx.CompareBookmark.EQUAL |
| bOK = bOK AND oObj.compareBookmarks(oBM1, oBM2) = com.sun.star.sdbcx.CompareBookmark.LESS |
| bOK = bOK AND oObj.compareBookmarks(oBM2, oBM1) = com.sun.star.sdbcx.CompareBookmark.GREATER |
| else |
| bOK = bOK AND oObj.compareBookmarks(oBM1, oBM1) = com.sun.star.sdbcx.CompareBookmark.EQUAL |
| bOK = bOK AND oObj.compareBookmarks(oBM1, oBM2) = com.sun.star.sdbcx.CompareBookmark.NOT_EQUAL |
| bOK = bOK AND oObj.compareBookmarks(oBM2, oBM1) = com.sun.star.sdbcx.CompareBookmark.NOT_EQUAL |
| end if |
| Test.MethodTested("compareBookmarks()", bOK) |
| |
| Test.StartMethod("hasOrderedBookmarks()") |
| bOK = true |
| bOK = bOK AND oObj.hasOrderedBookmarks() |
| Test.MethodTested("hasOrderedBookmarks()", bOK) |
| |
| Test.StartMethod("hashBookmark()") |
| bOK = true |
| |
| oObj.last() |
| oBM3 = oObj.getBookmark() |
| oObj.first() |
| oBM4 = oObj.getBookmark() |
| |
| bOK = bOK AND oObj.hashBookmark(oBM1) <> oObj.hashBookmark(oBM2) |
| bOK = bOK AND oObj.hashBookmark(oBM1) <> oObj.hashBookmark(oBM3) |
| bOK = bOK AND oObj.hashBookmark(oBM3) <> oObj.hashBookmark(oBM2) |
| bOK = bOK AND oObj.hashBookmark(oBM1) = oObj.hashBookmark(oBM4) |
| Test.MethodTested("hashBookmark()", bOK) |
| |
| |
| Exit Sub |
| ErrHndl: |
| Test.Exception() |
| bOK = false |
| resume next |
| End Sub |
| </script:module> |