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="frame_XStorable" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9'
10' Copyright 2000, 2010 Oracle and/or its affiliates.
11'
12' OpenOffice.org - a multi-platform office productivity suite
13'
14' This file is part of OpenOffice.org.
15'
16' OpenOffice.org is free software: you can redistribute it and/or modify
17' it under the terms of the GNU Lesser General Public License version 3
18' only, as published by the Free Software Foundation.
19'
20' OpenOffice.org is distributed in the hope that it will be useful,
21' but WITHOUT ANY WARRANTY; without even the implied warranty of
22' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23' GNU Lesser General Public License version 3 for more details
24' (a copy is included in the LICENSE file that accompanied this code).
25'
26' You should have received a copy of the GNU Lesser General Public License
27' version 3 along with OpenOffice.org.  If not, see
28' <http://www.openoffice.org/license.html>
29' for a copy of the LGPLv3 License.
30'
31'*************************************************************************
32'*************************************************************************
33
34
35
36' Be sure that all variables are dimensioned:
37option explicit
38
39
40
41Sub RunTest()
42
43'*************************************************************************
44' INTERFACE:
45' com.sun.star.frame.XStorable
46'*************************************************************************
47On Error Goto ErrHndl
48    Dim bOK As Boolean
49    Dim cLocation, cLocation1 As String
50    Dim i As Integer
51    Dim oDoc1 As Object
52
53    bOK = true
54    cLocation = utils.getTempFileURL(cObjectName &amp; "." &amp; "XStorable.tmp")
55    if (FileExists(cLocation)) then
56        Kill(cLocation)
57    end if
58
59    if (FileExists(cLocation &amp; ".bak")) then
60        Kill(cLocation &amp; ".bak")
61    end if
62
63    Out.Log("cLocation: "+cLocation)
64
65    Test.StartMethod("storeAsURL()")
66    bOK = true
67    oObj.storeAsURL(cLocation, DimArray())
68    bOK = bOK AND oObj.hasLocation()
69    Test.MethodTested("storeAsURL()", bOK)
70
71    Test.StartMethod("hasLocation()")
72    bOK = true
73    bOK = bOK AND oObj.hasLocation()
74    Test.MethodTested("hasLocation()", bOK)
75
76    Test.StartMethod("isReadonly()")
77    bOK = true
78    bOK = bOK AND NOT oObj.isReadOnly()
79    Test.MethodTested("isReadonly()", bOK)
80
81    Test.StartMethod("getLocation()")
82    bOK = true
83    bOK = bOK AND (oObj.getLocation = cLocation)
84    Out.Log("Location is: " &amp; oObj.getLocation &amp; " It should be: " &amp; cLocation)
85    Test.MethodTested("getLocation()", bOK)
86
87    Test.StartMethod("storeToURL()")
88    bOK = true
89    cLocation1 = cLocation + ".bak"
90    Out.Log("New Location: " + cLocation1)
91    oDoc.getDocumentInfo().setPropertyValue("Title", "frame_XStorable")
92    oObj.storeToURL(cLocation1, DimArray())
93    oDoc1 = StarDesktop.loadComponentFromUrl(cLocation1, "sc.ScModelObj.XStorable.tmp.bak", 40, DimArray() )
94    bOK = bOK AND (oDoc1.getDocumentInfo().getPropertyValue("Title") = "frame_XStorable")
95    if bOK then Out.Log("Document titles are equal")
96    oDoc1.dispose()
97    Test.MethodTested("storeToURL()", bOK)
98
99    Test.StartMethod("store()")
100    bOK = true
101    oObj.storeAsURL(cLocation1, DimArray())
102    oDoc.getDocumentInfo().setPropertyValue("Title", "frame_XStorable12345")
103    oObj.store()
104    oDoc1 = StarDesktop.loadComponentFromUrl(cLocation1, "sc.ScModelObj.XStorable.tmp.bak", 40, DimArray() )
105    bOK = bOK AND (oDoc1.getDocumentInfo().getPropertyValue("Title") = "frame_XStorable12345")
106    if bOK then Out.Log("Document titles are equal")
107    oDoc1.dispose()
108    Test.MethodTested("store()", bOK)
109
110Exit Sub
111ErrHndl:
112    Test.Exception()
113    bOK = false
114    resume next
115End Sub
116</script:module>
117