1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="io_XPersistObject" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8'  Licensed to the Apache Software Foundation (ASF) under one
9'  or more contributor license agreements.  See the NOTICE file
10'  distributed with this work for additional information
11'  regarding copyright ownership.  The ASF licenses this file
12'  to you under the Apache License, Version 2.0 (the
13'  "License"); you may not use this file except in compliance
14'  with the License.  You may obtain a copy of the License at
15'
16'    http://www.apache.org/licenses/LICENSE-2.0
17'
18'  Unless required by applicable law or agreed to in writing,
19'  software distributed under the License is distributed on an
20'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21'  KIND, either express or implied.  See the License for the
22'  specific language governing permissions and limitations
23'  under the License.
24'
25'*************************************************************************
26
27
28
29
30
31' Be sure that all variables are dimensioned:
32option explicit
33
34'*************************************************************************
35' This Interface/Service test depends on the following GLOBAL variables,
36' which must be specified in the object creation:
37
38'     - Global oPersistInstance As Object
39
40'*************************************************************************
41
42
43
44
45
46Sub RunTest()
47
48'*************************************************************************
49' INTERFACE:
50' com.sun.star.io.XPersistObject
51'*************************************************************************
52On Error Goto ErrHndl
53    Dim bOK As Boolean
54    Dim oMarkIn, oMarkOut, oOutStrm, oInStrm As Object
55    Dim oDummy, oCopy, oPipe As Object
56    Dim uuidString As String
57    Dim UUID(), UUIDnew() As Variant
58    Dim i As Integer
59
60    if isNull(oPersistInstance) Then
61        Out.Log("oPersistInstance is Empty! No oPersistInstance in main created?")
62        Exit Sub
63    end if
64
65    Test.StartMethod("getServiceName()")
66    bOK = true
67    bOK = bOK AND (VarType(oObj.getServiceName()) = 8)
68    Test.MethodTested("getServiceName()", bOK)
69
70    if (hasUnoInterfaces(oObj,"com.sun.star.lang.XTypeProvider")) then
71	    'get ImplementationID
72        Out.Log("Before writing object, rememeber it's implementation ID.")
73        uuidString = ""
74        UUID = oObj.getImplementationId()
75        for i = 0 to ubound(UUID())
76            uuidString = uuidString &amp; UUID(i) &amp; "; "
77        next i
78        Out.Log("ImplementationID: " &amp; uuidString)
79    endif
80
81    oDummy = oPersistInstance
82    oPipe = createUNOService("com.sun.star.io.Pipe")
83    oMarkOut = createUNOService("com.sun.star.io.MarkableOutputStream")
84    oMarkIn  = createUNOService("com.sun.star.io.MarkableInputStream")
85    oOutStrm = createUNOService("com.sun.star.io.ObjectOutputStream")
86    oInStrm = createUNOService("com.sun.star.io.ObjectInputStream")
87
88    'made chain
89    oOutStrm.setOutputStream(oMarkOut)
90    oMarkOut.setOutputStream(oPipe)
91    oMarkIn.setInputStream(oPipe)
92    oInStrm.setInputStream(oMarkIn)
93
94    Test.StartMethod("write()")
95    Test.StartMethod("read()")
96    bOK = true
97    'write dummy
98    oOutStrm.writeObject(oDummy)
99    oObj.write(oOutStrm)
100    'read copy
101    oCopy = oInStrm.readObject()
102    oObj.read(oInStrm)
103
104    if (hasUnoInterfaces(oObj,"com.sun.star.lang.XTypeProvider")) then
105        Out.Log("After reading object, get it's implementation ID.")
106        uuidString = ""
107        UUIDnew = oObj.getImplementationId()
108        for i = 0 to ubound(UUID())
109            bOK = bOK AND (UUID(i) = UUIDnew(i))
110            uuidString = uuidString &amp; UUIDnew(i) &amp; "; "
111        next i
112        Out.Log("ImplementationID: " &amp; uuidString)
113    endif
114
115    Test.MethodTested("write()", bOK)
116    Test.MethodTested("read()", bOK)
117
118    ReCreateObj()
119Exit Sub
120ErrHndl:
121    Test.Exception()
122    bOK = false
123    resume next
124End Sub
125</script:module>
126