1*cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="frame_XModel" script:language="StarBasic">
4*cdf0e10cSrcweir
5*cdf0e10cSrcweir
6*cdf0e10cSrcweir'*************************************************************************
7*cdf0e10cSrcweir'
8*cdf0e10cSrcweir' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*cdf0e10cSrcweir'
10*cdf0e10cSrcweir' Copyright 2000, 2010 Oracle and/or its affiliates.
11*cdf0e10cSrcweir'
12*cdf0e10cSrcweir' OpenOffice.org - a multi-platform office productivity suite
13*cdf0e10cSrcweir'
14*cdf0e10cSrcweir' This file is part of OpenOffice.org.
15*cdf0e10cSrcweir'
16*cdf0e10cSrcweir' OpenOffice.org is free software: you can redistribute it and/or modify
17*cdf0e10cSrcweir' it under the terms of the GNU Lesser General Public License version 3
18*cdf0e10cSrcweir' only, as published by the Free Software Foundation.
19*cdf0e10cSrcweir'
20*cdf0e10cSrcweir' OpenOffice.org is distributed in the hope that it will be useful,
21*cdf0e10cSrcweir' but WITHOUT ANY WARRANTY; without even the implied warranty of
22*cdf0e10cSrcweir' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23*cdf0e10cSrcweir' GNU Lesser General Public License version 3 for more details
24*cdf0e10cSrcweir' (a copy is included in the LICENSE file that accompanied this code).
25*cdf0e10cSrcweir'
26*cdf0e10cSrcweir' You should have received a copy of the GNU Lesser General Public License
27*cdf0e10cSrcweir' version 3 along with OpenOffice.org.  If not, see
28*cdf0e10cSrcweir' <http://www.openoffice.org/license.html>
29*cdf0e10cSrcweir' for a copy of the LGPLv3 License.
30*cdf0e10cSrcweir'
31*cdf0e10cSrcweir'*************************************************************************
32*cdf0e10cSrcweir'*************************************************************************
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir
36*cdf0e10cSrcweir' Be sure that all variables are dimensioned:
37*cdf0e10cSrcweiroption explicit
38*cdf0e10cSrcweir
39*cdf0e10cSrcweir'*************************************************************************
40*cdf0e10cSrcweir' This Interface/Service test depends on the following GLOBAL variables,
41*cdf0e10cSrcweir' which must be specified in the object creation:
42*cdf0e10cSrcweir
43*cdf0e10cSrcweir'     - Global oXModelController as Object
44*cdf0e10cSrcweir'     - Global oXModelSel as Object
45*cdf0e10cSrcweir'     - Global oXModelToSel as Object
46*cdf0e10cSrcweir
47*cdf0e10cSrcweir'*************************************************************************
48*cdf0e10cSrcweir
49*cdf0e10cSrcweir
50*cdf0e10cSrcweir
51*cdf0e10cSrcweir
52*cdf0e10cSrcweir
53*cdf0e10cSrcweir
54*cdf0e10cSrcweirSub RunTest()
55*cdf0e10cSrcweir
56*cdf0e10cSrcweir'*************************************************************************
57*cdf0e10cSrcweir' INTERFACE:
58*cdf0e10cSrcweir' com.sun.star.frame.XModel
59*cdf0e10cSrcweir'*************************************************************************
60*cdf0e10cSrcweirOn Error Goto ErrHndl
61*cdf0e10cSrcweir    Dim bOK As Boolean
62*cdf0e10cSrcweir
63*cdf0e10cSrcweir    Dim oController As Object
64*cdf0e10cSrcweir    Dim oSelection As Object
65*cdf0e10cSrcweir    Dim aArgs(0 to 0) As Variant
66*cdf0e10cSrcweir    Dim oCursor As Object
67*cdf0e10cSrcweir    Dim cURL As String
68*cdf0e10cSrcweir    Dim i As Integer
69*cdf0e10cSrcweir	Dim args1(0) As New com.sun.star.beans.PropertyValue
70*cdf0e10cSrcweir
71*cdf0e10cSrcweir    Test.StartMethod("attachResource()")
72*cdf0e10cSrcweir    args1(0).Name = "XModel"
73*cdf0e10cSrcweir    bOK = oObj.attachResource(".component:DB/DataSourceBrowser", args1())
74*cdf0e10cSrcweir    Test.MethodTested("attachResource()", bOK)
75*cdf0e10cSrcweir
76*cdf0e10cSrcweir    Test.StartMethod("getURL()")
77*cdf0e10cSrcweir    bOK = true
78*cdf0e10cSrcweir    cURL = oObj.getURL()
79*cdf0e10cSrcweir    bOK = bOK AND (cURL = ".component:DB/DataSourceBrowser")
80*cdf0e10cSrcweir    Test.MethodTested("getURL()", bOK)
81*cdf0e10cSrcweir
82*cdf0e10cSrcweir    Test.StartMethod("getArgs()")
83*cdf0e10cSrcweir    bOK = true
84*cdf0e10cSrcweir    aArgs() = oObj.Args
85*cdf0e10cSrcweir    bOK = bOK AND NOT isNull(aArgs()) '(0).Name = "XModel"
86*cdf0e10cSrcweir    Test.MethodTested("getArgs()", bOK)
87*cdf0e10cSrcweir
88*cdf0e10cSrcweir    Test.StartMethod("getCurrentController()")
89*cdf0e10cSrcweir    bOK = true
90*cdf0e10cSrcweir    Dim oCurrCtrl As Object
91*cdf0e10cSrcweir    oCurrCtrl = oObj.getCurrentController()
92*cdf0e10cSrcweir    bOK = bOK AND isObject(oCurrCtrl)
93*cdf0e10cSrcweir    bOK = bOK AND hasUnoInterfaces(oCurrCtrl, "com.sun.star.frame.XController")
94*cdf0e10cSrcweir    Test.MethodTested("getCurrentController()", bOK)
95*cdf0e10cSrcweir
96*cdf0e10cSrcweir    Test.StartMethod("getCurrentSelection()")
97*cdf0e10cSrcweir    bOK = true
98*cdf0e10cSrcweir    Dim oCurrSelection As Object
99*cdf0e10cSrcweir    oXModelSel.select(oXModelToSel)
100*cdf0e10cSrcweir    oCurrSelection = oObj.getCurrentSelection()
101*cdf0e10cSrcweir    bOK = bOK AND hasUnoInterfaces(oCurrSelection, "com.sun.star.uno.XInterface")
102*cdf0e10cSrcweir    Test.MethodTested("getCurrentSelection()", bOK)
103*cdf0e10cSrcweir
104*cdf0e10cSrcweir    Test.StartMethod("hasControllersLocked()")
105*cdf0e10cSrcweir    bOK = true
106*cdf0e10cSrcweir    ' there should no controllers be locked
107*cdf0e10cSrcweir    bOK = bOK AND NOT oObj.hasControllersLocked()
108*cdf0e10cSrcweir    Test.MethodTested("hasControllersLocked()", bOK)
109*cdf0e10cSrcweir
110*cdf0e10cSrcweir    ' now lock controllers
111*cdf0e10cSrcweir    Test.StartMethod("lockControllers()")
112*cdf0e10cSrcweir    bOK = true
113*cdf0e10cSrcweir    oObj.lockControllers()
114*cdf0e10cSrcweir    ' controllers should be locked
115*cdf0e10cSrcweir    bOK = bOK AND oObj.hasControllersLocked()
116*cdf0e10cSrcweir    Test.MethodTested("lockControllers()", bOK)
117*cdf0e10cSrcweir
118*cdf0e10cSrcweir    ' unlock controllers and check success
119*cdf0e10cSrcweir    Test.StartMethod("unlockControllers()")
120*cdf0e10cSrcweir    bOK = true
121*cdf0e10cSrcweir    oObj.unlockControllers()
122*cdf0e10cSrcweir    bOK = bOK AND NOT oObj.hasControllersLocked()
123*cdf0e10cSrcweir    Test.MethodTested("unlockControllers()", bOK)
124*cdf0e10cSrcweir
125*cdf0e10cSrcweir    Test.StartMethod("connectController()")
126*cdf0e10cSrcweir    oObj.connectController(oXModelController)
127*cdf0e10cSrcweir    Test.MethodTested("connectController()", bOK)
128*cdf0e10cSrcweir
129*cdf0e10cSrcweir    Test.StartMethod("disconnectController()")
130*cdf0e10cSrcweir    oObj.disconnectController(oXModelController)
131*cdf0e10cSrcweir    oObj.connectController(oCurrCtrl)
132*cdf0e10cSrcweir    Test.MethodTested("disconnectController()", bOK)
133*cdf0e10cSrcweir
134*cdf0e10cSrcweir    Test.StartMethod("setCurrentController()")
135*cdf0e10cSrcweir    oObj.setCurrentController(oCurrCtrl)
136*cdf0e10cSrcweir    Test.MethodTested("setCurrentController()", bOK)
137*cdf0e10cSrcweir
138*cdf0e10cSrcweir
139*cdf0e10cSrcweirExit Sub
140*cdf0e10cSrcweirErrHndl:
141*cdf0e10cSrcweir    Test.Exception()
142*cdf0e10cSrcweir    bOK = false
143*cdf0e10cSrcweir    resume next
144*cdf0e10cSrcweirEnd Sub
145*cdf0e10cSrcweir</script:module>
146