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