1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sdbc_XResultSetUpdate" script:language="StarBasic">
4cdf0e10cSrcweir
5cdf0e10cSrcweir
6cdf0e10cSrcweir'*************************************************************************
7cdf0e10cSrcweir'
8*eebed415SAndrew Rist'  Licensed to the Apache Software Foundation (ASF) under one
9*eebed415SAndrew Rist'  or more contributor license agreements.  See the NOTICE file
10*eebed415SAndrew Rist'  distributed with this work for additional information
11*eebed415SAndrew Rist'  regarding copyright ownership.  The ASF licenses this file
12*eebed415SAndrew Rist'  to you under the Apache License, Version 2.0 (the
13*eebed415SAndrew Rist'  "License"); you may not use this file except in compliance
14*eebed415SAndrew Rist'  with the License.  You may obtain a copy of the License at
15*eebed415SAndrew Rist'
16*eebed415SAndrew Rist'    http://www.apache.org/licenses/LICENSE-2.0
17*eebed415SAndrew Rist'
18*eebed415SAndrew Rist'  Unless required by applicable law or agreed to in writing,
19*eebed415SAndrew Rist'  software distributed under the License is distributed on an
20*eebed415SAndrew Rist'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*eebed415SAndrew Rist'  KIND, either express or implied.  See the License for the
22*eebed415SAndrew Rist'  specific language governing permissions and limitations
23*eebed415SAndrew Rist'  under the License.
24cdf0e10cSrcweir'
25cdf0e10cSrcweir'*************************************************************************
26cdf0e10cSrcweir
27cdf0e10cSrcweir
28cdf0e10cSrcweir
29*eebed415SAndrew Rist
30*eebed415SAndrew Rist
31cdf0e10cSrcweir'*************************************************************************
32cdf0e10cSrcweir' This Interface/Service test depends on the following GLOBAL variables,
33cdf0e10cSrcweir' which must be specified in the object creation:
34cdf0e10cSrcweir
35cdf0e10cSrcweir'     - Global textColumn As String
36cdf0e10cSrcweir
37cdf0e10cSrcweir'*************************************************************************
38cdf0e10cSrcweir
39cdf0e10cSrcweir
40cdf0e10cSrcweir
41cdf0e10cSrcweir
42cdf0e10cSrcweir
43cdf0e10cSrcweirSub RunTest()
44cdf0e10cSrcweir
45cdf0e10cSrcweir'*************************************************************************
46cdf0e10cSrcweir' INTERFACE:
47cdf0e10cSrcweir' com.sun.star.sdbc.XResultSetUpdate
48cdf0e10cSrcweir'*************************************************************************
49cdf0e10cSrcweirOn Error Goto ErrHndl
50cdf0e10cSrcweir    Dim bOK As Boolean
51cdf0e10cSrcweir    Dim iCount As Integer
52cdf0e10cSrcweir    Dim cString As String
53cdf0e10cSrcweir    Dim colIdx As Integer
54cdf0e10cSrcweir
55cdf0e10cSrcweir    colIdx = oObj.findColumn(textColumn)
56cdf0e10cSrcweir
57cdf0e10cSrcweir    Test.StartMethod("insertRow()")
58cdf0e10cSrcweir    bOK = true
59cdf0e10cSrcweir    iCount = countRows()
60cdf0e10cSrcweir    Out.Log("Initially " + countRows() + " records")
61cdf0e10cSrcweir    oObj.moveToInsertRow()
62cdf0e10cSrcweir    oObj.updateString(colIdx, "New string")
63cdf0e10cSrcweir    oObj.insertRow()
64cdf0e10cSrcweir    Out.Log("After inserting " + countRows() + " records")
65cdf0e10cSrcweir    oObj.last()
66cdf0e10cSrcweir    bOK = bOK AND oObj.getString(colIdx) = "New string"
67cdf0e10cSrcweir    bOK = bOK AND iCount = countRows() - 1
68cdf0e10cSrcweir    Test.MethodTested("insertRow()", bOK)
69cdf0e10cSrcweir
70cdf0e10cSrcweir    Test.StartMethod("cancelRowUpdates()")
71cdf0e10cSrcweir    bOK = true
72cdf0e10cSrcweir    oObj.last()
73cdf0e10cSrcweir    oObj.updateString(colIdx, "Changed string")
74cdf0e10cSrcweir    oObj.cancelRowUpdates()
75cdf0e10cSrcweir    bOK = bOK AND oObj.getString(colIdx) = "New string"
76cdf0e10cSrcweir    bOK = bOK AND iCount = countRows() - 1
77cdf0e10cSrcweir    Test.MethodTested("cancelRowUpdates()", bOK)
78cdf0e10cSrcweir
79cdf0e10cSrcweir    Test.StartMethod("updateRow()")
80cdf0e10cSrcweir    bOK = true
81cdf0e10cSrcweir    oObj.last()
82cdf0e10cSrcweir    oObj.updateString(colIdx, "Changed string")
83cdf0e10cSrcweir    oObj.updateRow()
84cdf0e10cSrcweir    bOK = bOK AND oObj.getString(colIdx) = "Changed string"
85cdf0e10cSrcweir    bOK = bOK AND iCount = countRows() - 1
86cdf0e10cSrcweir    Test.MethodTested("updateRow()", bOK)
87cdf0e10cSrcweir
88cdf0e10cSrcweir    Test.StartMethod("deleteRow()")
89cdf0e10cSrcweir    Dim rowsBefore As Integer, rowsAfter As Integer
90cdf0e10cSrcweir    bOK = true
91cdf0e10cSrcweir    rowsBefore = countRows()
92cdf0e10cSrcweir    oObj.Last()
93cdf0e10cSrcweir    oObj.deleteRow()
94cdf0e10cSrcweir    rowsAfter = countRows()
95cdf0e10cSrcweir    Out.Log("Rows before: " + rowsBefore + ", rows after: " + rowsAfter)
96cdf0e10cSrcweir    bOK = bOK AND iCount = rowsAfter
97cdf0e10cSrcweir    oObj.Last()
98cdf0e10cSrcweir    Out.Log(oObj.getString(colIdx))
99cdf0e10cSrcweir    Test.MethodTested("deleteRow()", bOK)
100cdf0e10cSrcweir
101cdf0e10cSrcweir    Test.StartMethod("moveToInsertRow()")
102cdf0e10cSrcweir    bOK = true
103cdf0e10cSrcweir    oObj.moveToInsertRow()
104cdf0e10cSrcweir    bOK = bOK AND oObj.getString(colIdx) = ""
105cdf0e10cSrcweir    Test.MethodTested("moveToInsertRow()", bOK)
106cdf0e10cSrcweir
107cdf0e10cSrcweir    Test.StartMethod("moveToCurrentRow()")
108cdf0e10cSrcweir    bOK = true
109cdf0e10cSrcweir    oObj.first()
110cdf0e10cSrcweir    oObj.next()
111cdf0e10cSrcweir    cString = oObj.getString(colIdx)
112cdf0e10cSrcweir    oObj.moveToInsertRow()
113cdf0e10cSrcweir    oObj.moveToCurrentRow()
114cdf0e10cSrcweir    bOK = bOK AND oObj.getString(colIdx) = cString
115cdf0e10cSrcweir    Test.MethodTested("moveToCurrentRow()", bOK)
116cdf0e10cSrcweir
117cdf0e10cSrcweirExit Sub
118cdf0e10cSrcweirErrHndl:
119cdf0e10cSrcweir    Test.Exception()
120cdf0e10cSrcweir    bOK = false
121cdf0e10cSrcweir    resume next
122cdf0e10cSrcweirEnd Sub
123cdf0e10cSrcweirFunction countRows() As Integer
124cdf0e10cSrcweir    Dim iCount As Integer
125cdf0e10cSrcweir    iCount = 0
126cdf0e10cSrcweir    oObj.first()
127cdf0e10cSrcweir    while NOT oObj.isAfterLast()
128cdf0e10cSrcweir        iCount = iCount + 1
129cdf0e10cSrcweir        oObj.next()
130cdf0e10cSrcweir    wend
131cdf0e10cSrcweir    countRows() = iCount
132cdf0e10cSrcweirEnd Function
133cdf0e10cSrcweir</script:module>
134