<?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>
