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