blob: 3e893d99a32b0e4d1d5e7a8627457ea591cdfef5 [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
<script:module xmlns:script="http://openoffice.org/2000/script" script:name="lang_XMultiServiceFactory" script:language="StarBasic">
'*************************************************************************
'
' Licensed to the Apache Software Foundation (ASF) under one
' or more contributor license agreements. See the NOTICE file
' distributed with this work for additional information
' regarding copyright ownership. The ASF licenses this file
' to you under the Apache License, Version 2.0 (the
' "License"); you may not use this file except in compliance
' with the License. You may obtain a copy of the License at
'
' http://www.apache.org/licenses/LICENSE-2.0
'
' Unless required by applicable law or agreed to in writing,
' software distributed under the License is distributed on an
' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
' KIND, either express or implied. See the License for the
' specific language governing permissions and limitations
' under the License.
'
'*************************************************************************
'*************************************************************************
' This Interface/Service test depends on the following GLOBAL variables,
' which must be specified in the object creation:
' - Global cServiceName As String ie. "com.sun.star.drawing.RectangleShape"
' - Global bCreateInstanceWithoutArguments As Boolean
' - Global aArguments() As Variant
'*************************************************************************
Sub RunTest()
'*************************************************************************
' INTERFACE:
' com.sun.star.lang.XMultiServiceFactory
'*************************************************************************
On Error Goto ErrHndl
Dim bOK As Boolean
Dim oInstance1, oInstance2 As Object
Dim Names
Test.StartMethod("getAvailableServiceNames()")
bOK = true
Names = oObj.getAvailableServiceNames()
Dim bFound As Boolean
bFound = false
for i = 0 to ubound(Names)
if Names(i) = cServiceName then bFound = true
next i
if (NOT bFound) then Out.Log("Can't find '" &amp; cServiceName &amp; "' in returned array.")
bOK = bOK AND bFound
Test.MethodTested("getAvailableServiceNames()", bOK)
Test.StartMethod("createInstance()")
bOK = true
if bCreateInstanceWithoutArguments then
oInstance1 = oObj.createInstance(cServiceName)
bOK = bOK AND NOT isNull(oInstance1)
else
Out.Log("createInstance() skipped for this object.")
end if
Test.MethodTested("createInstance()", bOK)
Test.StartMethod("createInstanceWithArguments()")
bOK = true
if (cObjectName = "sd.SdXImpressDocument") then
Out.Log("Object SdXImpressDocument doesn't suppotr createInstanceWithArguments().")
else
oInstance2 = oObj.createInstanceWithArguments(cServiceName, aArguments())
bOK = bOK AND NOT isNULL(oInstance2)
end if
Test.MethodTested("createInstanceWithArguments()", bOK)
Exit Sub
ErrHndl:
Test.Exception()
bOK = false
resume next
End Sub
</script:module>