1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sheet_XSpreadsheets" script:language="StarBasic">
4cdf0e10cSrcweir
5cdf0e10cSrcweir
6cdf0e10cSrcweir'*************************************************************************
7cdf0e10cSrcweir'
8*eebed415SAndrew Rist'  Licensed to the Apache Software Foundation (ASF) under one
9*eebed415SAndrew Rist'  or more contributor license agreements.  See the NOTICE file
10*eebed415SAndrew Rist'  distributed with this work for additional information
11*eebed415SAndrew Rist'  regarding copyright ownership.  The ASF licenses this file
12*eebed415SAndrew Rist'  to you under the Apache License, Version 2.0 (the
13*eebed415SAndrew Rist'  "License"); you may not use this file except in compliance
14*eebed415SAndrew Rist'  with the License.  You may obtain a copy of the License at
15*eebed415SAndrew Rist'
16*eebed415SAndrew Rist'    http://www.apache.org/licenses/LICENSE-2.0
17*eebed415SAndrew Rist'
18*eebed415SAndrew Rist'  Unless required by applicable law or agreed to in writing,
19*eebed415SAndrew Rist'  software distributed under the License is distributed on an
20*eebed415SAndrew Rist'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21*eebed415SAndrew Rist'  KIND, either express or implied.  See the License for the
22*eebed415SAndrew Rist'  specific language governing permissions and limitations
23*eebed415SAndrew Rist'  under the License.
24cdf0e10cSrcweir'
25cdf0e10cSrcweir'*************************************************************************
26cdf0e10cSrcweir
27cdf0e10cSrcweir
28cdf0e10cSrcweir
29*eebed415SAndrew Rist
30*eebed415SAndrew Rist
31cdf0e10cSrcweir' Be sure that all variables are dimensioned:
32cdf0e10cSrcweiroption explicit
33cdf0e10cSrcweir
34cdf0e10cSrcweir'*************************************************************************
35cdf0e10cSrcweir' This Interface/Service test depends on the following GLOBAL variables,
36cdf0e10cSrcweir' which must be specified in the object creation:
37cdf0e10cSrcweir
38cdf0e10cSrcweir'     - Global nGlobalLong As Long the number of sheets
39cdf0e10cSrcweir
40cdf0e10cSrcweir'*************************************************************************
41cdf0e10cSrcweir
42cdf0e10cSrcweir
43cdf0e10cSrcweir
44cdf0e10cSrcweir
45cdf0e10cSrcweir
46cdf0e10cSrcweir
47cdf0e10cSrcweirSub RunTest()
48cdf0e10cSrcweir
49cdf0e10cSrcweir'*************************************************************************
50cdf0e10cSrcweir' INTERFACE:
51cdf0e10cSrcweir' com.sun.star.sheet.XSpreadsheets
52cdf0e10cSrcweir'*************************************************************************
53cdf0e10cSrcweirOn Error Goto ErrHndl
54cdf0e10cSrcweir    Dim bOK As Boolean
55cdf0e10cSrcweir    Dim l As Integer
56cdf0e10cSrcweir    Dim sname As String
57cdf0e10cSrcweir    Dim oSheet1, oSheet2 As Object
58cdf0e10cSrcweir
59cdf0e10cSrcweir
60cdf0e10cSrcweir    Test.StartMethod("insertNewByName()")
61cdf0e10cSrcweir    bOK = true
62cdf0e10cSrcweir    for l = 1 to nGlobalLong
63cdf0e10cSrcweir        sname = cIfcShortName &amp; CStr(l)
64cdf0e10cSrcweir        oObj.insertNewByName(sname, l)
65cdf0e10cSrcweir        oSheet1 = oObj.getByName(sname)
66cdf0e10cSrcweir        oSheet2 = oObj.getByIndex(l)
67cdf0e10cSrcweir        bOK = bOK AND NOT isNull(oSheet1)
68cdf0e10cSrcweir        bOK = bOK AND NOT isNull(oSheet2)
69cdf0e10cSrcweir        if (bOK) then
70cdf0e10cSrcweir            bOK = bOK and oSheet1.name = oSheet2.name
71cdf0e10cSrcweir        end if
72cdf0e10cSrcweir    next l
73cdf0e10cSrcweir    Test.MethodTested("insertNewByName()", bOK)
74cdf0e10cSrcweir
75cdf0e10cSrcweir    Test.StartMethod("copyByName()")
76cdf0e10cSrcweir    bOK = true
77cdf0e10cSrcweir    l = 1
78cdf0e10cSrcweir    sname = cIfcShortName &amp; "COPY"
79cdf0e10cSrcweir    oObj.copyByName(cIfcShortName &amp; CStr(l), sname, l )
80cdf0e10cSrcweir    oSheet1 = oObj.getByName(sname)
81cdf0e10cSrcweir    oSheet2 = oObj.getByIndex(l)
82cdf0e10cSrcweir    bOK = bOK AND NOT isNull(oSheet1)
83cdf0e10cSrcweir    bOK = bOK AND NOT isNull(oSheet2)
84cdf0e10cSrcweir    if (bOK) then
85cdf0e10cSrcweir        bOK = bOK AND oSheet1.name = oSheet2.name
86cdf0e10cSrcweir    end if
87cdf0e10cSrcweir    Test.MethodTested("copyByName()", bOK)
88cdf0e10cSrcweir
89cdf0e10cSrcweir    Test.StartMethod("moveByName()")
90cdf0e10cSrcweir    bOK = true
91cdf0e10cSrcweir    l = 1
92cdf0e10cSrcweir    sname = cIfcShortName &amp; "2"
93cdf0e10cSrcweir    oObj.moveByName(sname, l)
94cdf0e10cSrcweir    oSheet1 = oObj.getByName(sname)
95cdf0e10cSrcweir    oSheet2 = oObj.getByIndex(l)
96cdf0e10cSrcweir    bOK = bOK AND NOT isNull(oSheet1)
97cdf0e10cSrcweir    bOK = bOK AND NOT isNull(oSheet2)
98cdf0e10cSrcweir    if (bOK) then
99cdf0e10cSrcweir        bOK = bOK AND oSheet1.name = oSheet2.name
100cdf0e10cSrcweir    end if
101cdf0e10cSrcweir    Out.Log(cIfcShortName &amp; ":" &amp; "#1 - " &amp; bOK)
102cdf0e10cSrcweir
103cdf0e10cSrcweir    sname = cIfcShortName &amp; "COPY"
104cdf0e10cSrcweir    l = nGlobalLong + 1
105cdf0e10cSrcweir    oObj.moveByName(sname, l)
106cdf0e10cSrcweir    l = l - 1
107cdf0e10cSrcweir    oSheet1 = oObj.getByName(sname)
108cdf0e10cSrcweir    oSheet2 = oObj.getByIndex(l)
109cdf0e10cSrcweir    bOK = bOK AND NOT isNull(oSheet1)
110cdf0e10cSrcweir    bOK = bOK AND NOT isNull(oSheet2)
111cdf0e10cSrcweir    if (bOK) then
112cdf0e10cSrcweir        bOK = bOK and oSheet1.name =oSheet2.name
113cdf0e10cSrcweir    end if
114cdf0e10cSrcweir    Test.MethodTested("moveByName()", bOK)
115cdf0e10cSrcweir
116cdf0e10cSrcweir    nGlobalLong = nGlobalLong * 2 + 1 ' nGlobalLong : 3 default sheets where already there
117cdf0e10cSrcweir                                      ' nGlobalLong have been inserted
118cdf0e10cSrcweir                                      ' + 1 has been created by Copy
119cdf0e10cSrcweirExit Sub
120cdf0e10cSrcweirErrHndl:
121cdf0e10cSrcweir    Test.Exception()
122cdf0e10cSrcweir    bOK = false
123cdf0e10cSrcweir    resume next
124cdf0e10cSrcweirEnd Sub
125cdf0e10cSrcweir</script:module>
126