1*b1cdbd2cSJim Jagielski<?xml version="1.0" encoding="UTF-8"?>
2*b1cdbd2cSJim Jagielski<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*b1cdbd2cSJim Jagielski<script:module xmlns:script="http://openoffice.org/2000/script" script:name="dbaccess_TableWindowAccessibility" script:language="StarBasic">
4*b1cdbd2cSJim Jagielski
5*b1cdbd2cSJim Jagielski
6*b1cdbd2cSJim Jagielski'*************************************************************************
7*b1cdbd2cSJim Jagielski'
8*b1cdbd2cSJim Jagielski'  Licensed to the Apache Software Foundation (ASF) under one
9*b1cdbd2cSJim Jagielski'  or more contributor license agreements.  See the NOTICE file
10*b1cdbd2cSJim Jagielski'  distributed with this work for additional information
11*b1cdbd2cSJim Jagielski'  regarding copyright ownership.  The ASF licenses this file
12*b1cdbd2cSJim Jagielski'  to you under the Apache License, Version 2.0 (the
13*b1cdbd2cSJim Jagielski'  "License"); you may not use this file except in compliance
14*b1cdbd2cSJim Jagielski'  with the License.  You may obtain a copy of the License at
15*b1cdbd2cSJim Jagielski'
16*b1cdbd2cSJim Jagielski'    http://www.apache.org/licenses/LICENSE-2.0
17*b1cdbd2cSJim Jagielski'
18*b1cdbd2cSJim Jagielski'  Unless required by applicable law or agreed to in writing,
19*b1cdbd2cSJim Jagielski'  software distributed under the License is distributed on an
20*b1cdbd2cSJim Jagielski'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*b1cdbd2cSJim Jagielski'  KIND, either express or implied.  See the License for the
22*b1cdbd2cSJim Jagielski'  specific language governing permissions and limitations
23*b1cdbd2cSJim Jagielski'  under the License.
24*b1cdbd2cSJim Jagielski'
25*b1cdbd2cSJim Jagielski'*************************************************************************
26*b1cdbd2cSJim Jagielski
27*b1cdbd2cSJim Jagielski
28*b1cdbd2cSJim Jagielski
29*b1cdbd2cSJim Jagielski
30*b1cdbd2cSJim Jagielski
31*b1cdbd2cSJim Jagielski' Be sure that all variables are dimensioned:
32*b1cdbd2cSJim Jagielskioption explicit
33*b1cdbd2cSJim Jagielski
34*b1cdbd2cSJim Jagielski
35*b1cdbd2cSJim Jagielski' REQUIRED VARIABLES for interface/service tests:
36*b1cdbd2cSJim JagielskiGlobal cancelButton As Object
37*b1cdbd2cSJim JagielskiGlobal queryWindow As Object
38*b1cdbd2cSJim Jagielski
39*b1cdbd2cSJim Jagielski
40*b1cdbd2cSJim JagielskiSub CreateObj()
41*b1cdbd2cSJim Jagielski
42*b1cdbd2cSJim Jagielski'*************************************************************************
43*b1cdbd2cSJim Jagielski' COMPONENT:
44*b1cdbd2cSJim Jagielski' dbaccess.TableWindowAccessibility
45*b1cdbd2cSJim Jagielski'*************************************************************************
46*b1cdbd2cSJim JagielskiOn Error Goto ErrHndl
47*b1cdbd2cSJim Jagielski    Dim oMSF As Object, oWin As Object
48*b1cdbd2cSJim Jagielski    Dim thRunner As Object, xRoot As Object
49*b1cdbd2cSJim Jagielski    Dim tk As Object
50*b1cdbd2cSJim Jagielski
51*b1cdbd2cSJim Jagielski    Dim dbSource As Object
52*b1cdbd2cSJim Jagielski    dbSource = createUnoService("com.sun.star.sdb.DataSource")
53*b1cdbd2cSJim Jagielski
54*b1cdbd2cSJim Jagielski    Dim info(2) As new com.sun.star.beans.PropertyValue
55*b1cdbd2cSJim Jagielski    info(0).Name = "JavaDriverClass"
56*b1cdbd2cSJim Jagielski    info(0).Value = "org.gjt.mm.mysql.Driver"
57*b1cdbd2cSJim Jagielski    info(1).Name = "user"
58*b1cdbd2cSJim Jagielski    info(1).Value = jdbcUser
59*b1cdbd2cSJim Jagielski    info(2).Name = "password"
60*b1cdbd2cSJim Jagielski    info(2).Value = jdbcPassword
61*b1cdbd2cSJim Jagielski    dbSource.info = info()
62*b1cdbd2cSJim Jagielski    dbSource.URL = jdbcUrl
63*b1cdbd2cSJim Jagielski
64*b1cdbd2cSJim Jagielski    Dim dbContext As Object
65*b1cdbd2cSJim Jagielski    dbContext = createUnoService("com.sun.star.sdb.DatabaseContext")
66*b1cdbd2cSJim Jagielski
67*b1cdbd2cSJim Jagielski    Dim sourceName As String
68*b1cdbd2cSJim Jagielski    sourceName = "AAADBSource for dbu-accessibility"
69*b1cdbd2cSJim Jagielski
70*b1cdbd2cSJim Jagielski    if dbContext.hasByName(sourceName) then
71*b1cdbd2cSJim Jagielski        dbContext.revokeObject(sourceName)
72*b1cdbd2cSJim Jagielski    endif
73*b1cdbd2cSJim Jagielski
74*b1cdbd2cSJim Jagielski    dbContext.registerObject(sourceName, dbSource)
75*b1cdbd2cSJim Jagielski
76*b1cdbd2cSJim Jagielski    Dim connection As Object
77*b1cdbd2cSJim Jagielski    connection = dbSource.getIsolatedConnection(jdbcUser, jdbcPassword)
78*b1cdbd2cSJim Jagielski
79*b1cdbd2cSJim Jagielski    Dim statement As Object
80*b1cdbd2cSJim Jagielski    statement = connection.createStatement()
81*b1cdbd2cSJim Jagielski
82*b1cdbd2cSJim Jagielski    statement.executeUpdate("drop table if exists tst_table1")
83*b1cdbd2cSJim Jagielski    statement.executeUpdate("drop table if exists tst_table2")
84*b1cdbd2cSJim Jagielski    statement.executeUpdate("create table tst_table1 (id1 int)")
85*b1cdbd2cSJim Jagielski    statement.executeUpdate("create table tst_table2 (id2 int)")
86*b1cdbd2cSJim Jagielski
87*b1cdbd2cSJim Jagielski    Dim defContainer As Object
88*b1cdbd2cSJim Jagielski    defContainer = dbSource.getQueryDefinitions()
89*b1cdbd2cSJim Jagielski
90*b1cdbd2cSJim Jagielski    Dim newQuery As Object
91*b1cdbd2cSJim Jagielski    newQuery = createUnoService("com.sun.star.sdb.QueryDefinition")
92*b1cdbd2cSJim Jagielski    newQuery.Command = "select * from tst_table1, tst_table2 where " + _
93*b1cdbd2cSJim Jagielski                       "tst_table1.id1=tst_table2.id2"
94*b1cdbd2cSJim Jagielski
95*b1cdbd2cSJim Jagielski    defContainer.insertByName("Query1", newQuery)
96*b1cdbd2cSJim Jagielski
97*b1cdbd2cSJim Jagielski    oMSF = getProcessServiceManager()
98*b1cdbd2cSJim Jagielski    thRunner = oMSF.createInstance("basichelper.ThreadRunner")
99*b1cdbd2cSJim Jagielski    tk = createUNOService("com.sun.star.awt.Toolkit")
100*b1cdbd2cSJim Jagielski    wait(500)
101*b1cdbd2cSJim Jagielski    thRunner.initialize(Array("ExecuteDialog", "com.sun.star.sdb.DatasourceAdministrationDialog"))
102*b1cdbd2cSJim Jagielski    wait(3000)
103*b1cdbd2cSJim Jagielski
104*b1cdbd2cSJim Jagielski    oWin = tk.getActiveTopWindow()
105*b1cdbd2cSJim Jagielski    xRoot = utils.at_getAccessibleObject(oWin)
106*b1cdbd2cSJim Jagielski
107*b1cdbd2cSJim Jagielski    Dim pageTabList As Object
108*b1cdbd2cSJim Jagielski    pageTabList = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PAGE_TAB_LIST)
109*b1cdbd2cSJim Jagielski
110*b1cdbd2cSJim Jagielski    pageTabList.selectAccessibleChild(3)
111*b1cdbd2cSJim Jagielski    wait(500)
112*b1cdbd2cSJim Jagielski
113*b1cdbd2cSJim Jagielski    Dim editQueryButton As Object
114*b1cdbd2cSJim Jagielski    editQueryButton = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PUSH_BUTTON, "Edit Query")
115*b1cdbd2cSJim Jagielski
116*b1cdbd2cSJim Jagielski    cancelButton = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PUSH_BUTTON, "Cancel")
117*b1cdbd2cSJim Jagielski
118*b1cdbd2cSJim Jagielski    editQueryButton.doAccessibleAction(0)
119*b1cdbd2cSJim Jagielski    wait(1000)
120*b1cdbd2cSJim Jagielski
121*b1cdbd2cSJim Jagielski    oWin = tk.getActiveTopWindow()
122*b1cdbd2cSJim Jagielski    queryWindow = oWin
123*b1cdbd2cSJim Jagielski    xRoot = utils.at_getAccessibleObject(oWin)
124*b1cdbd2cSJim Jagielski
125*b1cdbd2cSJim Jagielski    oObj = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PANEL)
126*b1cdbd2cSJim Jagielski
127*b1cdbd2cSJim JagielskiExit Sub
128*b1cdbd2cSJim JagielskiErrHndl:
129*b1cdbd2cSJim Jagielski    Test.Exception()
130*b1cdbd2cSJim JagielskiEnd Sub
131*b1cdbd2cSJim Jagielski
132*b1cdbd2cSJim JagielskiSub DisposeObj()
133*b1cdbd2cSJim Jagielski    utils.closeObject(queryWindow)
134*b1cdbd2cSJim Jagielski    if NOT isNull(cancelButton) then
135*b1cdbd2cSJim Jagielski        cancelButton.doAccessibleAction(0)
136*b1cdbd2cSJim Jagielski        wait(1000)
137*b1cdbd2cSJim Jagielski    End If
138*b1cdbd2cSJim JagielskiEnd Sub
139*b1cdbd2cSJim Jagielski
140*b1cdbd2cSJim JagielskiSub fireEvent()
141*b1cdbd2cSJim JagielskiEnd Sub
142*b1cdbd2cSJim Jagielski</script:module>
143