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_JoinViewAccessibility" 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 Jagielski
37*b1cdbd2cSJim JagielskiGlobal cancelButton As Object
38*b1cdbd2cSJim JagielskiGlobal queryWindow As Object
39*b1cdbd2cSJim Jagielski
40*b1cdbd2cSJim Jagielski
41*b1cdbd2cSJim JagielskiSub CreateObj()
42*b1cdbd2cSJim Jagielski
43*b1cdbd2cSJim Jagielski'*************************************************************************
44*b1cdbd2cSJim Jagielski' COMPONENT:
45*b1cdbd2cSJim Jagielski' dbaccess.JoinViewAccessibility
46*b1cdbd2cSJim Jagielski'*************************************************************************
47*b1cdbd2cSJim JagielskiOn Error Goto ErrHndl
48*b1cdbd2cSJim Jagielski    Dim oMSF As Object, oWin As Object
49*b1cdbd2cSJim Jagielski    Dim thRunner As Object, xRoot As Object
50*b1cdbd2cSJim Jagielski    Dim tk As Object
51*b1cdbd2cSJim Jagielski
52*b1cdbd2cSJim Jagielski    Dim dbSource As Object
53*b1cdbd2cSJim Jagielski    dbSource = createUnoService("com.sun.star.sdb.DataSource")
54*b1cdbd2cSJim Jagielski
55*b1cdbd2cSJim Jagielski    Dim info(2) As new com.sun.star.beans.PropertyValue
56*b1cdbd2cSJim Jagielski    info(0).Name = "JavaDriverClass"
57*b1cdbd2cSJim Jagielski    info(0).Value = "org.gjt.mm.mysql.Driver"
58*b1cdbd2cSJim Jagielski    info(1).Name = "user"
59*b1cdbd2cSJim Jagielski    info(1).Value = jdbcUser
60*b1cdbd2cSJim Jagielski    info(2).Name = "password"
61*b1cdbd2cSJim Jagielski    info(2).Value = jdbcPassword
62*b1cdbd2cSJim Jagielski    dbSource.info = info()
63*b1cdbd2cSJim Jagielski    dbSource.URL = jdbcUrl
64*b1cdbd2cSJim Jagielski
65*b1cdbd2cSJim Jagielski    Dim dbContext As Object
66*b1cdbd2cSJim Jagielski    dbContext = createUnoService("com.sun.star.sdb.DatabaseContext")
67*b1cdbd2cSJim Jagielski
68*b1cdbd2cSJim Jagielski    Dim sourceName As String
69*b1cdbd2cSJim Jagielski    sourceName = "AAADBSource for dbu-accessibility"
70*b1cdbd2cSJim Jagielski
71*b1cdbd2cSJim Jagielski    if dbContext.hasByName(sourceName) then
72*b1cdbd2cSJim Jagielski        dbContext.revokeObject(sourceName)
73*b1cdbd2cSJim Jagielski    endif
74*b1cdbd2cSJim Jagielski
75*b1cdbd2cSJim Jagielski    dbContext.registerObject(sourceName, dbSource)
76*b1cdbd2cSJim Jagielski
77*b1cdbd2cSJim Jagielski    Dim connection As Object
78*b1cdbd2cSJim Jagielski    connection = dbSource.getIsolatedConnection(jdbcUser, jdbcPassword)
79*b1cdbd2cSJim Jagielski
80*b1cdbd2cSJim Jagielski    Dim statement As Object
81*b1cdbd2cSJim Jagielski    statement = connection.createStatement()
82*b1cdbd2cSJim Jagielski
83*b1cdbd2cSJim Jagielski    statement.executeUpdate("drop table if exists tst_table1")
84*b1cdbd2cSJim Jagielski    statement.executeUpdate("drop table if exists tst_table2")
85*b1cdbd2cSJim Jagielski    statement.executeUpdate("create table tst_table1 (id1 int)")
86*b1cdbd2cSJim Jagielski    statement.executeUpdate("create table tst_table2 (id2 int)")
87*b1cdbd2cSJim Jagielski
88*b1cdbd2cSJim Jagielski    Dim defContainer As Object
89*b1cdbd2cSJim Jagielski    defContainer = dbSource.getQueryDefinitions()
90*b1cdbd2cSJim Jagielski
91*b1cdbd2cSJim Jagielski    Dim newQuery As Object
92*b1cdbd2cSJim Jagielski    newQuery = createUnoService("com.sun.star.sdb.QueryDefinition")
93*b1cdbd2cSJim Jagielski    newQuery.Command = "select * from tst_table1, tst_table2 where " + _
94*b1cdbd2cSJim Jagielski                       "tst_table1.id1=tst_table2.id2"
95*b1cdbd2cSJim Jagielski
96*b1cdbd2cSJim Jagielski    defContainer.insertByName("Query1", newQuery)
97*b1cdbd2cSJim Jagielski
98*b1cdbd2cSJim Jagielski    oMSF = getProcessServiceManager()
99*b1cdbd2cSJim Jagielski    thRunner = oMSF.createInstance("basichelper.ThreadRunner")
100*b1cdbd2cSJim Jagielski    tk = createUNOService("com.sun.star.awt.Toolkit")
101*b1cdbd2cSJim Jagielski    wait(500)
102*b1cdbd2cSJim Jagielski    thRunner.initialize(Array("ExecuteDialog", "com.sun.star.sdb.DatasourceAdministrationDialog"))
103*b1cdbd2cSJim Jagielski    wait(3000)
104*b1cdbd2cSJim Jagielski
105*b1cdbd2cSJim Jagielski    oWin = tk.getActiveTopWindow()
106*b1cdbd2cSJim Jagielski    xRoot = utils.at_getAccessibleObject(oWin)
107*b1cdbd2cSJim Jagielski
108*b1cdbd2cSJim Jagielski    Dim pageTabList As Object
109*b1cdbd2cSJim Jagielski    pageTabList = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PAGE_TAB_LIST)
110*b1cdbd2cSJim Jagielski
111*b1cdbd2cSJim Jagielski    pageTabList.selectAccessibleChild(3)
112*b1cdbd2cSJim Jagielski    wait(500)
113*b1cdbd2cSJim Jagielski
114*b1cdbd2cSJim Jagielski    Dim editQueryButton As Object
115*b1cdbd2cSJim Jagielski    editQueryButton = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PUSH_BUTTON, "Edit Query")
116*b1cdbd2cSJim Jagielski
117*b1cdbd2cSJim Jagielski    cancelButton = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.PUSH_BUTTON, "Cancel")
118*b1cdbd2cSJim Jagielski
119*b1cdbd2cSJim Jagielski    editQueryButton.doAccessibleAction(0)
120*b1cdbd2cSJim Jagielski    wait(1000)
121*b1cdbd2cSJim Jagielski
122*b1cdbd2cSJim Jagielski    oWin = tk.getActiveTopWindow()
123*b1cdbd2cSJim Jagielski    queryWindow = oWin
124*b1cdbd2cSJim Jagielski    xRoot = utils.at_getAccessibleObject(oWin)
125*b1cdbd2cSJim Jagielski
126*b1cdbd2cSJim Jagielski    oObj = utils.at_getAccessibleObjectForRole(xRoot, com.sun.star.accessibility.AccessibleRole.VIEW_PORT)
127*b1cdbd2cSJim Jagielski
128*b1cdbd2cSJim JagielskiExit Sub
129*b1cdbd2cSJim JagielskiErrHndl:
130*b1cdbd2cSJim Jagielski    Test.Exception()
131*b1cdbd2cSJim JagielskiEnd Sub
132*b1cdbd2cSJim Jagielski
133*b1cdbd2cSJim JagielskiSub DisposeObj()
134*b1cdbd2cSJim Jagielski    utils.closeObject(queryWindow)
135*b1cdbd2cSJim Jagielski    if NOT isNull(cancelButton) then
136*b1cdbd2cSJim Jagielski        cancelButton.doAccessibleAction(0)
137*b1cdbd2cSJim Jagielski        wait(1000)
138*b1cdbd2cSJim Jagielski    End If
139*b1cdbd2cSJim JagielskiEnd Sub
140*b1cdbd2cSJim Jagielski
141*b1cdbd2cSJim JagielskiSub fireEvent()
142*b1cdbd2cSJim JagielskiEnd Sub
143*b1cdbd2cSJim Jagielski</script:module>
144