blob: bea9e0c716c7ab520171124726bf938805b03d6d [file] [log] [blame]
<?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="sdbc_XResultSetUpdate" 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.
'
'*************************************************************************
'*************************************************************************
' This Interface/Service test depends on the following GLOBAL variables,
' which must be specified in the object creation:
' - Global textColumn As String
'*************************************************************************
Sub RunTest()
'*************************************************************************
' INTERFACE:
' com.sun.star.sdbc.XResultSetUpdate
'*************************************************************************
On Error Goto ErrHndl
Dim bOK As Boolean
Dim iCount As Integer
Dim cString As String
Dim colIdx As Integer
colIdx = oObj.findColumn(textColumn)
Test.StartMethod("insertRow()")
bOK = true
iCount = countRows()
Out.Log("Initially " + countRows() + " records")
oObj.moveToInsertRow()
oObj.updateString(colIdx, "New string")
oObj.insertRow()
Out.Log("After inserting " + countRows() + " records")
oObj.last()
bOK = bOK AND oObj.getString(colIdx) = "New string"
bOK = bOK AND iCount = countRows() - 1
Test.MethodTested("insertRow()", bOK)
Test.StartMethod("cancelRowUpdates()")
bOK = true
oObj.last()
oObj.updateString(colIdx, "Changed string")
oObj.cancelRowUpdates()
bOK = bOK AND oObj.getString(colIdx) = "New string"
bOK = bOK AND iCount = countRows() - 1
Test.MethodTested("cancelRowUpdates()", bOK)
Test.StartMethod("updateRow()")
bOK = true
oObj.last()
oObj.updateString(colIdx, "Changed string")
oObj.updateRow()
bOK = bOK AND oObj.getString(colIdx) = "Changed string"
bOK = bOK AND iCount = countRows() - 1
Test.MethodTested("updateRow()", bOK)
Test.StartMethod("deleteRow()")
Dim rowsBefore As Integer, rowsAfter As Integer
bOK = true
rowsBefore = countRows()
oObj.Last()
oObj.deleteRow()
rowsAfter = countRows()
Out.Log("Rows before: " + rowsBefore + ", rows after: " + rowsAfter)
bOK = bOK AND iCount = rowsAfter
oObj.Last()
Out.Log(oObj.getString(colIdx))
Test.MethodTested("deleteRow()", bOK)
Test.StartMethod("moveToInsertRow()")
bOK = true
oObj.moveToInsertRow()
bOK = bOK AND oObj.getString(colIdx) = ""
Test.MethodTested("moveToInsertRow()", bOK)
Test.StartMethod("moveToCurrentRow()")
bOK = true
oObj.first()
oObj.next()
cString = oObj.getString(colIdx)
oObj.moveToInsertRow()
oObj.moveToCurrentRow()
bOK = bOK AND oObj.getString(colIdx) = cString
Test.MethodTested("moveToCurrentRow()", bOK)
Exit Sub
ErrHndl:
Test.Exception()
bOK = false
resume next
End Sub
Function countRows() As Integer
Dim iCount As Integer
iCount = 0
oObj.first()
while NOT oObj.isAfterLast()
iCount = iCount + 1
oObj.next()
wend
countRows() = iCount
End Function
</script:module>