1*cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sdbcx_XRowLocate" script:language="StarBasic">
4*cdf0e10cSrcweir
5*cdf0e10cSrcweir
6*cdf0e10cSrcweir'*************************************************************************
7*cdf0e10cSrcweir'
8*cdf0e10cSrcweir' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*cdf0e10cSrcweir'
10*cdf0e10cSrcweir' Copyright 2000, 2010 Oracle and/or its affiliates.
11*cdf0e10cSrcweir'
12*cdf0e10cSrcweir' OpenOffice.org - a multi-platform office productivity suite
13*cdf0e10cSrcweir'
14*cdf0e10cSrcweir' This file is part of OpenOffice.org.
15*cdf0e10cSrcweir'
16*cdf0e10cSrcweir' OpenOffice.org is free software: you can redistribute it and/or modify
17*cdf0e10cSrcweir' it under the terms of the GNU Lesser General Public License version 3
18*cdf0e10cSrcweir' only, as published by the Free Software Foundation.
19*cdf0e10cSrcweir'
20*cdf0e10cSrcweir' OpenOffice.org is distributed in the hope that it will be useful,
21*cdf0e10cSrcweir' but WITHOUT ANY WARRANTY; without even the implied warranty of
22*cdf0e10cSrcweir' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23*cdf0e10cSrcweir' GNU Lesser General Public License version 3 for more details
24*cdf0e10cSrcweir' (a copy is included in the LICENSE file that accompanied this code).
25*cdf0e10cSrcweir'
26*cdf0e10cSrcweir' You should have received a copy of the GNU Lesser General Public License
27*cdf0e10cSrcweir' version 3 along with OpenOffice.org.  If not, see
28*cdf0e10cSrcweir' <http://www.openoffice.org/license.html>
29*cdf0e10cSrcweir' for a copy of the LGPLv3 License.
30*cdf0e10cSrcweir'
31*cdf0e10cSrcweir'*************************************************************************
32*cdf0e10cSrcweir'*************************************************************************
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir
36*cdf0e10cSrcweir
37*cdf0e10cSrcweir
38*cdf0e10cSrcweirSub RunTest()
39*cdf0e10cSrcweir
40*cdf0e10cSrcweir'*************************************************************************
41*cdf0e10cSrcweir' INTERFACE:
42*cdf0e10cSrcweir' com.sun.star.sdbcx.XRowLocate
43*cdf0e10cSrcweir'*************************************************************************
44*cdf0e10cSrcweirOn Error Goto ErrHndl
45*cdf0e10cSrcweir    Dim bOK As Boolean
46*cdf0e10cSrcweir    Dim oBM1 As Variant
47*cdf0e10cSrcweir    Dim oBM2 As Variant
48*cdf0e10cSrcweir    Dim oBM3 As Variant
49*cdf0e10cSrcweir    Dim oBM4 As Variant
50*cdf0e10cSrcweir    Dim cDscr1 As String
51*cdf0e10cSrcweir    Dim cDscr2 As String
52*cdf0e10cSrcweir
53*cdf0e10cSrcweir    ReCreateObj()
54*cdf0e10cSrcweir
55*cdf0e10cSrcweir    oObj.first()
56*cdf0e10cSrcweir
57*cdf0e10cSrcweir    Test.StartMethod("getBookmark()")
58*cdf0e10cSrcweir    bOK = true
59*cdf0e10cSrcweir    oBM1 = oObj.getBookmark()
60*cdf0e10cSrcweir    cDscr1 = oObj.getString(1)
61*cdf0e10cSrcweir    Out.Log("Set bookmark to row " + cDscr1)
62*cdf0e10cSrcweir    bOK = bOK AND NOT isNULL(oBM1)
63*cdf0e10cSrcweir    Test.MethodTested("getBookmark()", bOK)
64*cdf0e10cSrcweir
65*cdf0e10cSrcweir    Test.StartMethod("moveToBookmark()")
66*cdf0e10cSrcweir    bOK = true
67*cdf0e10cSrcweir    oObj.next()
68*cdf0e10cSrcweir    cDscr2 = oObj.getString(1)
69*cdf0e10cSrcweir    Out.Log("Now on " + cDscr2)
70*cdf0e10cSrcweir    oObj.moveToBookmark(oBM1)
71*cdf0e10cSrcweir    Out.Log("After movment on " + oObj.getString(1))
72*cdf0e10cSrcweir    bOK = bOK AND oObj.getString(1) = cDscr1
73*cdf0e10cSrcweir    Test.MethodTested("moveToBookmark()", bOK)
74*cdf0e10cSrcweir
75*cdf0e10cSrcweir    Test.StartMethod("moveRelativeToBookmark()")
76*cdf0e10cSrcweir    bOK = true
77*cdf0e10cSrcweir    oObj.moveRelativeToBookmark(oBM1, 1)
78*cdf0e10cSrcweir    Out.Log("After movment on " + oObj.getString(1))
79*cdf0e10cSrcweir    bOK = bOK AND oObj.getString(1) = cDscr2
80*cdf0e10cSrcweir    Test.MethodTested("moveRelativeToBookmark()", bOK)
81*cdf0e10cSrcweir
82*cdf0e10cSrcweir    oBM2 = oObj.getBookmark()
83*cdf0e10cSrcweir
84*cdf0e10cSrcweir    Test.StartMethod("compareBookmarks()")
85*cdf0e10cSrcweir    bOK = true
86*cdf0e10cSrcweir    ' if database driver supports ordered marks then
87*cdf0e10cSrcweir    ' compareBookmarks should return values CompareBookmark::LESS or
88*cdf0e10cSrcweir    ' CompareBookmark::GREATER in case when bookmarks are not equal
89*cdf0e10cSrcweir    ' otherwise this method returnes only CompareBookmark::NOT_EQUAL
90*cdf0e10cSrcweir
91*cdf0e10cSrcweir    if (oObj.hasOrderedBookmarks()) then
92*cdf0e10cSrcweir        bOK = bOK AND oObj.compareBookmarks(oBM1, oBM1) = com.sun.star.sdbcx.CompareBookmark.EQUAL
93*cdf0e10cSrcweir        bOK = bOK AND oObj.compareBookmarks(oBM1, oBM2) = com.sun.star.sdbcx.CompareBookmark.LESS
94*cdf0e10cSrcweir        bOK = bOK AND oObj.compareBookmarks(oBM2, oBM1) = com.sun.star.sdbcx.CompareBookmark.GREATER
95*cdf0e10cSrcweir    else
96*cdf0e10cSrcweir        bOK = bOK AND oObj.compareBookmarks(oBM1, oBM1) = com.sun.star.sdbcx.CompareBookmark.EQUAL
97*cdf0e10cSrcweir        bOK = bOK AND oObj.compareBookmarks(oBM1, oBM2) = com.sun.star.sdbcx.CompareBookmark.NOT_EQUAL
98*cdf0e10cSrcweir        bOK = bOK AND oObj.compareBookmarks(oBM2, oBM1) = com.sun.star.sdbcx.CompareBookmark.NOT_EQUAL
99*cdf0e10cSrcweir    end if
100*cdf0e10cSrcweir    Test.MethodTested("compareBookmarks()", bOK)
101*cdf0e10cSrcweir
102*cdf0e10cSrcweir    Test.StartMethod("hasOrderedBookmarks()")
103*cdf0e10cSrcweir    bOK = true
104*cdf0e10cSrcweir    bOK = bOK AND oObj.hasOrderedBookmarks()
105*cdf0e10cSrcweir    Test.MethodTested("hasOrderedBookmarks()", bOK)
106*cdf0e10cSrcweir
107*cdf0e10cSrcweir    Test.StartMethod("hashBookmark()")
108*cdf0e10cSrcweir    bOK = true
109*cdf0e10cSrcweir
110*cdf0e10cSrcweir    oObj.last()
111*cdf0e10cSrcweir    oBM3 = oObj.getBookmark()
112*cdf0e10cSrcweir    oObj.first()
113*cdf0e10cSrcweir    oBM4 = oObj.getBookmark()
114*cdf0e10cSrcweir
115*cdf0e10cSrcweir    bOK = bOK AND oObj.hashBookmark(oBM1) &lt;&gt; oObj.hashBookmark(oBM2)
116*cdf0e10cSrcweir    bOK = bOK AND oObj.hashBookmark(oBM1) &lt;&gt; oObj.hashBookmark(oBM3)
117*cdf0e10cSrcweir    bOK = bOK AND oObj.hashBookmark(oBM3) &lt;&gt; oObj.hashBookmark(oBM2)
118*cdf0e10cSrcweir    bOK = bOK AND oObj.hashBookmark(oBM1) = oObj.hashBookmark(oBM4)
119*cdf0e10cSrcweir    Test.MethodTested("hashBookmark()", bOK)
120*cdf0e10cSrcweir
121*cdf0e10cSrcweir
122*cdf0e10cSrcweirExit Sub
123*cdf0e10cSrcweirErrHndl:
124*cdf0e10cSrcweir    Test.Exception()
125*cdf0e10cSrcweir    bOK = false
126*cdf0e10cSrcweir    resume next
127*cdf0e10cSrcweirEnd Sub
128*cdf0e10cSrcweir</script:module>
129