1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski package complex.ofopxmlstorages;
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski import com.sun.star.uno.XInterface;
25*b1cdbd2cSJim Jagielski import com.sun.star.lang.XMultiServiceFactory;
26*b1cdbd2cSJim Jagielski import com.sun.star.lang.XSingleServiceFactory;
27*b1cdbd2cSJim Jagielski import com.sun.star.lang.DisposedException;
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski import com.sun.star.bridge.XUnoUrlResolver;
30*b1cdbd2cSJim Jagielski import com.sun.star.uno.UnoRuntime;
31*b1cdbd2cSJim Jagielski import com.sun.star.uno.XInterface;
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski import com.sun.star.container.XNameAccess;
34*b1cdbd2cSJim Jagielski 
35*b1cdbd2cSJim Jagielski import com.sun.star.embed.*;
36*b1cdbd2cSJim Jagielski import com.sun.star.beans.StringPair;
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski import share.LogWriter;
39*b1cdbd2cSJim Jagielski import complex.ofopxmlstorages.TestHelper;
40*b1cdbd2cSJim Jagielski import complex.ofopxmlstorages.StorageTest;
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski public class Test04 implements StorageTest {
43*b1cdbd2cSJim Jagielski 
44*b1cdbd2cSJim Jagielski 	XMultiServiceFactory m_xMSF;
45*b1cdbd2cSJim Jagielski 	XSingleServiceFactory m_xStorageFactory;
46*b1cdbd2cSJim Jagielski 	TestHelper m_aTestHelper;
47*b1cdbd2cSJim Jagielski 
Test04( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter )48*b1cdbd2cSJim Jagielski 	public Test04( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter )
49*b1cdbd2cSJim Jagielski 	{
50*b1cdbd2cSJim Jagielski 		m_xMSF = xMSF;
51*b1cdbd2cSJim Jagielski 		m_xStorageFactory = xStorageFactory;
52*b1cdbd2cSJim Jagielski 		m_aTestHelper = new TestHelper( aLogWriter, "Test04: " );
53*b1cdbd2cSJim Jagielski 	}
54*b1cdbd2cSJim Jagielski 
test()55*b1cdbd2cSJim Jagielski     public boolean test()
56*b1cdbd2cSJim Jagielski 	{
57*b1cdbd2cSJim Jagielski 		StringPair[][] aRelations1 =
58*b1cdbd2cSJim Jagielski 			{ { new StringPair( "Id", "Num1" ) },
59*b1cdbd2cSJim Jagielski 			  { new StringPair( "Target", "TargetURLValue1" ), new StringPair( "Id", "Num6" ) },
60*b1cdbd2cSJim Jagielski 			  { new StringPair( "Target", "" ), new StringPair( "Id", "Num7" ) },
61*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num2" ), new StringPair( "TargetMode", "Internal1" ), new StringPair( "Type", "unknown1" ), new StringPair( "Target", "URL value 1" ) },
62*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num3" ), new StringPair( "TargetMode", "Internal1" ), new StringPair( "Type", "unknown1" ), new StringPair( "Target", "URL value 1" ) },
63*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num4" ), new StringPair( "TargetMode", "Internal1" ), new StringPair( "Type", "unknown1" ), new StringPair( "Target", "URL value 1" ) },
64*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num5" ), new StringPair( "TargetMode", "" ), new StringPair( "Type", "unknown1" ), new StringPair( "Target", "URL value1" ) }
65*b1cdbd2cSJim Jagielski 			};
66*b1cdbd2cSJim Jagielski 
67*b1cdbd2cSJim Jagielski 		StringPair[][] aRelations2 =
68*b1cdbd2cSJim Jagielski 			{ { new StringPair( "Id", "Num1" ) },
69*b1cdbd2cSJim Jagielski 			  { new StringPair( "Target", "TargetURLValue2" ), new StringPair( "Id", "Num6" ) },
70*b1cdbd2cSJim Jagielski 			  { new StringPair( "Target", "" ), new StringPair( "Id", "Num7" ) },
71*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num2" ), new StringPair( "TargetMode", "Internal2" ), new StringPair( "Type", "unknown2" ), new StringPair( "Target", "URL value 2" ) },
72*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num3" ), new StringPair( "TargetMode", "Internal2" ), new StringPair( "Type", "unknown2" ), new StringPair( "Target", "URL value 2" ) },
73*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num4" ), new StringPair( "TargetMode", "Internal2" ), new StringPair( "Type", "unknown" ), new StringPair( "Target", "URL value" ) },
74*b1cdbd2cSJim Jagielski 			  { new StringPair( "Id", "Num5" ), new StringPair( "TargetMode", "" ), new StringPair( "Type", "unknown" ), new StringPair( "Target", "URL value" ) }
75*b1cdbd2cSJim Jagielski 			};
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski 		try
78*b1cdbd2cSJim Jagielski 		{
79*b1cdbd2cSJim Jagielski 			String sTempFileURL = m_aTestHelper.CreateTempFile( m_xMSF );
80*b1cdbd2cSJim Jagielski 			if ( sTempFileURL == null || sTempFileURL == "" )
81*b1cdbd2cSJim Jagielski 			{
82*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "No valid temporary file was created!" );
83*b1cdbd2cSJim Jagielski 				return false;
84*b1cdbd2cSJim Jagielski 			}
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski 			// create temporary storage based on arbitrary medium
87*b1cdbd2cSJim Jagielski 			// after such a storage is closed it is lost
88*b1cdbd2cSJim Jagielski 			XStorage xTempStorage = m_aTestHelper.createTempStorage( m_xMSF, m_xStorageFactory );
89*b1cdbd2cSJim Jagielski 			if ( xTempStorage == null )
90*b1cdbd2cSJim Jagielski 			{
91*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create temporary storage representation!" );
92*b1cdbd2cSJim Jagielski 				return false;
93*b1cdbd2cSJim Jagielski 			}
94*b1cdbd2cSJim Jagielski 
95*b1cdbd2cSJim Jagielski 			// open substorages and create streams there
96*b1cdbd2cSJim Jagielski 
97*b1cdbd2cSJim Jagielski 			// first substorage of the root storage
98*b1cdbd2cSJim Jagielski 			XStorage xTempSubStorage1 = m_aTestHelper.openSubStorage( xTempStorage,
99*b1cdbd2cSJim Jagielski 																		"SubStorage1",
100*b1cdbd2cSJim Jagielski 																		ElementModes.WRITE );
101*b1cdbd2cSJim Jagielski 			if ( xTempSubStorage1 == null )
102*b1cdbd2cSJim Jagielski 			{
103*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create substorage!" );
104*b1cdbd2cSJim Jagielski 				return false;
105*b1cdbd2cSJim Jagielski 			}
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski 			byte pBytes1[] = { 1, 1, 1, 1, 1 };
108*b1cdbd2cSJim Jagielski 
109*b1cdbd2cSJim Jagielski 			// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
110*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage1,
111*b1cdbd2cSJim Jagielski 														"SubStream1",
112*b1cdbd2cSJim Jagielski 														"MediaType1",
113*b1cdbd2cSJim Jagielski 														true,
114*b1cdbd2cSJim Jagielski 														pBytes1,
115*b1cdbd2cSJim Jagielski 														aRelations1 ) )
116*b1cdbd2cSJim Jagielski 				return false;
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski 			// second substorage of the root storage
119*b1cdbd2cSJim Jagielski 			XStorage xTempSubStorage2 = m_aTestHelper.openSubStorage( xTempStorage,
120*b1cdbd2cSJim Jagielski 																		"SubStorage2",
121*b1cdbd2cSJim Jagielski 																		ElementModes.WRITE );
122*b1cdbd2cSJim Jagielski 			if ( xTempSubStorage2 == null )
123*b1cdbd2cSJim Jagielski 			{
124*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create substorage!" );
125*b1cdbd2cSJim Jagielski 				return false;
126*b1cdbd2cSJim Jagielski 			}
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski 			byte pBytes2[] = { 2, 2, 2, 2, 2 };
129*b1cdbd2cSJim Jagielski 
130*b1cdbd2cSJim Jagielski 			// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
131*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage2,
132*b1cdbd2cSJim Jagielski 														"SubStream2",
133*b1cdbd2cSJim Jagielski 														"MediaType2",
134*b1cdbd2cSJim Jagielski 														false,
135*b1cdbd2cSJim Jagielski 														pBytes2,
136*b1cdbd2cSJim Jagielski 														aRelations2 ) )
137*b1cdbd2cSJim Jagielski 				return false;
138*b1cdbd2cSJim Jagielski 
139*b1cdbd2cSJim Jagielski 			// set Relations for storages and check that "IsRoot" and "OpenMode" properties are set correctly
140*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempStorage,
141*b1cdbd2cSJim Jagielski 															true,
142*b1cdbd2cSJim Jagielski 															ElementModes.WRITE,
143*b1cdbd2cSJim Jagielski 															aRelations2 ) )
144*b1cdbd2cSJim Jagielski 				return false;
145*b1cdbd2cSJim Jagielski 
146*b1cdbd2cSJim Jagielski 			// set Relations for storages and check that "IsRoot" and "OpenMode" properties are set correctly
147*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage1,
148*b1cdbd2cSJim Jagielski 															false,
149*b1cdbd2cSJim Jagielski 															ElementModes.WRITE,
150*b1cdbd2cSJim Jagielski 															aRelations2 ) )
151*b1cdbd2cSJim Jagielski 				return false;
152*b1cdbd2cSJim Jagielski 
153*b1cdbd2cSJim Jagielski 			// set Relations for storages and check that "IsRoot" and "OpenMode" properties are set correctly
154*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage2,
155*b1cdbd2cSJim Jagielski 															false,
156*b1cdbd2cSJim Jagielski 															ElementModes.WRITE,
157*b1cdbd2cSJim Jagielski 															aRelations2 ) )
158*b1cdbd2cSJim Jagielski 				return false;
159*b1cdbd2cSJim Jagielski 
160*b1cdbd2cSJim Jagielski 			// create temporary storage based on a previously created temporary file
161*b1cdbd2cSJim Jagielski 			XStorage xTempFileStorage = m_aTestHelper.createStorageFromURL( m_xStorageFactory,
162*b1cdbd2cSJim Jagielski 																			sTempFileURL,
163*b1cdbd2cSJim Jagielski 																			ElementModes.WRITE );
164*b1cdbd2cSJim Jagielski 			if ( xTempFileStorage == null )
165*b1cdbd2cSJim Jagielski 			{
166*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create storage based on temporary file!" );
167*b1cdbd2cSJim Jagielski 				return false;
168*b1cdbd2cSJim Jagielski 			}
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.copyElementTo( xTempStorage, "SubStorage1", xTempFileStorage ) )
171*b1cdbd2cSJim Jagielski 				return false;
172*b1cdbd2cSJim Jagielski 
173*b1cdbd2cSJim Jagielski 			// if storage is not commited before disposing all the changes will be lost
174*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.commitStorage( xTempSubStorage2 ) )
175*b1cdbd2cSJim Jagielski 				return false;
176*b1cdbd2cSJim Jagielski 
177*b1cdbd2cSJim Jagielski 			// a storage must be disposed before moving/removing otherwise the access will be denied
178*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xTempSubStorage2 ) )
179*b1cdbd2cSJim Jagielski 				return false;
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.moveElementTo( xTempStorage, "SubStorage2", xTempFileStorage ) )
182*b1cdbd2cSJim Jagielski 				return false;
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski 			// SubStorage2 must be removed and disposed now
185*b1cdbd2cSJim Jagielski 			try
186*b1cdbd2cSJim Jagielski 			{
187*b1cdbd2cSJim Jagielski 				xTempSubStorage2.isStreamElement( "SubStream2" );
188*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "SubStorage2 must be disposed already!" );
189*b1cdbd2cSJim Jagielski 				return false;
190*b1cdbd2cSJim Jagielski 			}
191*b1cdbd2cSJim Jagielski 			catch( com.sun.star.lang.DisposedException de )
192*b1cdbd2cSJim Jagielski 			{
193*b1cdbd2cSJim Jagielski 			}
194*b1cdbd2cSJim Jagielski 			catch( Exception e )
195*b1cdbd2cSJim Jagielski 			{
196*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Wrong exception in case of disposed storage, exception: " + e );
197*b1cdbd2cSJim Jagielski 				return false;
198*b1cdbd2cSJim Jagielski 			}
199*b1cdbd2cSJim Jagielski 
200*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.copyElementTo( xTempSubStorage1, "SubStream1", xTempFileStorage ) )
201*b1cdbd2cSJim Jagielski 				return false;
202*b1cdbd2cSJim Jagielski 
203*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.renameElement( xTempFileStorage, "SubStream1", "SubStream1_copy" ) )
204*b1cdbd2cSJim Jagielski 				return false;
205*b1cdbd2cSJim Jagielski 
206*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.moveElementTo( xTempSubStorage1, "SubStream1", xTempFileStorage ) )
207*b1cdbd2cSJim Jagielski 				return false;
208*b1cdbd2cSJim Jagielski 
209*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.commitStorage( xTempFileStorage ) )
210*b1cdbd2cSJim Jagielski 				return false;
211*b1cdbd2cSJim Jagielski 
212*b1cdbd2cSJim Jagielski 			// dispose used storages to free resources
213*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xTempStorage ) || !m_aTestHelper.disposeStorage( xTempFileStorage ) )
214*b1cdbd2cSJim Jagielski 				return false;
215*b1cdbd2cSJim Jagielski 
216*b1cdbd2cSJim Jagielski 			// ================================================
217*b1cdbd2cSJim Jagielski 			// now check all the written and copied information
218*b1cdbd2cSJim Jagielski 			// ================================================
219*b1cdbd2cSJim Jagielski 
220*b1cdbd2cSJim Jagielski 			// the temporary file must not be locked any more after storage disposing
221*b1cdbd2cSJim Jagielski 			XStorage xResStorage = m_aTestHelper.createStorageFromURL( m_xStorageFactory,
222*b1cdbd2cSJim Jagielski 																		sTempFileURL,
223*b1cdbd2cSJim Jagielski 																		ElementModes.WRITE );
224*b1cdbd2cSJim Jagielski 
225*b1cdbd2cSJim Jagielski 			if ( xResStorage == null )
226*b1cdbd2cSJim Jagielski 			{
227*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't reopen storage based on temporary file!" );
228*b1cdbd2cSJim Jagielski 				return false;
229*b1cdbd2cSJim Jagielski 			}
230*b1cdbd2cSJim Jagielski 
231*b1cdbd2cSJim Jagielski 			// open and check SubStorage1
232*b1cdbd2cSJim Jagielski 			XStorage xResSubStorage1 = m_aTestHelper.openSubStorage( xResStorage,
233*b1cdbd2cSJim Jagielski 																		"SubStorage1",
234*b1cdbd2cSJim Jagielski 																		ElementModes.READ );
235*b1cdbd2cSJim Jagielski 			if ( xResSubStorage1 == null )
236*b1cdbd2cSJim Jagielski 			{
237*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't open existing substorage!" );
238*b1cdbd2cSJim Jagielski 				return false;
239*b1cdbd2cSJim Jagielski 			}
240*b1cdbd2cSJim Jagielski 
241*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStorageProperties( xResSubStorage1,
242*b1cdbd2cSJim Jagielski 														false,
243*b1cdbd2cSJim Jagielski 														ElementModes.READ,
244*b1cdbd2cSJim Jagielski 														aRelations2 ) )
245*b1cdbd2cSJim Jagielski 				return false;
246*b1cdbd2cSJim Jagielski 
247*b1cdbd2cSJim Jagielski 
248*b1cdbd2cSJim Jagielski 			// open and check SubStorage2
249*b1cdbd2cSJim Jagielski 			XStorage xResSubStorage2 = m_aTestHelper.openSubStorage( xResStorage,
250*b1cdbd2cSJim Jagielski 																		"SubStorage2",
251*b1cdbd2cSJim Jagielski 																		ElementModes.READ );
252*b1cdbd2cSJim Jagielski 			if ( xResSubStorage2 == null )
253*b1cdbd2cSJim Jagielski 			{
254*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't open existing substorage!" );
255*b1cdbd2cSJim Jagielski 				return false;
256*b1cdbd2cSJim Jagielski 			}
257*b1cdbd2cSJim Jagielski 
258*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStorageProperties( xResSubStorage2,
259*b1cdbd2cSJim Jagielski 														false,
260*b1cdbd2cSJim Jagielski 														ElementModes.READ,
261*b1cdbd2cSJim Jagielski 														aRelations2 ) )
262*b1cdbd2cSJim Jagielski 				return false;
263*b1cdbd2cSJim Jagielski 
264*b1cdbd2cSJim Jagielski 
265*b1cdbd2cSJim Jagielski 			// check all the result streams
266*b1cdbd2cSJim Jagielski 
267*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResStorage, "SubStream1", "MediaType1", pBytes1, aRelations1 ) )
268*b1cdbd2cSJim Jagielski 				return false;
269*b1cdbd2cSJim Jagielski 
270*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResStorage, "SubStream1_copy", "MediaType1", pBytes1, aRelations1 ) )
271*b1cdbd2cSJim Jagielski 				return false;
272*b1cdbd2cSJim Jagielski 
273*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResSubStorage1, "SubStream1", "MediaType1", pBytes1, aRelations1 ) )
274*b1cdbd2cSJim Jagielski 				return false;
275*b1cdbd2cSJim Jagielski 
276*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResSubStorage2, "SubStream2", "MediaType2", pBytes2, aRelations2 ) )
277*b1cdbd2cSJim Jagielski 				return false;
278*b1cdbd2cSJim Jagielski 
279*b1cdbd2cSJim Jagielski 			// the storage must be disposed before removing
280*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xResSubStorage2 ) )
281*b1cdbd2cSJim Jagielski 				return false;
282*b1cdbd2cSJim Jagielski 
283*b1cdbd2cSJim Jagielski 			// remove element and check that it was removed completelly
284*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.removeElement( xResStorage, "SubStorage2" ) )
285*b1cdbd2cSJim Jagielski 				return false;
286*b1cdbd2cSJim Jagielski 
287*b1cdbd2cSJim Jagielski 			try
288*b1cdbd2cSJim Jagielski 			{
289*b1cdbd2cSJim Jagielski 				XNameAccess xResAccess = (XNameAccess) UnoRuntime.queryInterface( XNameAccess.class, xResStorage );
290*b1cdbd2cSJim Jagielski 				if ( xResAccess.hasByName( "SubStorage2" ) )
291*b1cdbd2cSJim Jagielski 					m_aTestHelper.Error( "SubStorage2 must be removed already!" );
292*b1cdbd2cSJim Jagielski 			}
293*b1cdbd2cSJim Jagielski 			catch( Exception e )
294*b1cdbd2cSJim Jagielski 			{
295*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't get access to root storage, exception: " + e );
296*b1cdbd2cSJim Jagielski 				return false;
297*b1cdbd2cSJim Jagielski 			}
298*b1cdbd2cSJim Jagielski 
299*b1cdbd2cSJim Jagielski 			try
300*b1cdbd2cSJim Jagielski 			{
301*b1cdbd2cSJim Jagielski 				xResSubStorage2.isStreamElement( "SubStream2" );
302*b1cdbd2cSJim Jagielski 
303*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "SubStorage2 must be disposed already!" );
304*b1cdbd2cSJim Jagielski 				return false;
305*b1cdbd2cSJim Jagielski 			}
306*b1cdbd2cSJim Jagielski 			catch( com.sun.star.lang.DisposedException de )
307*b1cdbd2cSJim Jagielski 			{
308*b1cdbd2cSJim Jagielski 			}
309*b1cdbd2cSJim Jagielski 			catch( Exception e )
310*b1cdbd2cSJim Jagielski 			{
311*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Wrong exception in case of disposed storage, exception: " + e );
312*b1cdbd2cSJim Jagielski 				return false;
313*b1cdbd2cSJim Jagielski 			}
314*b1cdbd2cSJim Jagielski 
315*b1cdbd2cSJim Jagielski 			// dispose used storages to free resources
316*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xResStorage ) )
317*b1cdbd2cSJim Jagielski 				return false;
318*b1cdbd2cSJim Jagielski 
319*b1cdbd2cSJim Jagielski 			return true;
320*b1cdbd2cSJim Jagielski 		}
321*b1cdbd2cSJim Jagielski 		catch( Exception e )
322*b1cdbd2cSJim Jagielski 		{
323*b1cdbd2cSJim Jagielski 			m_aTestHelper.Error( "Exception: " + e );
324*b1cdbd2cSJim Jagielski 			return false;
325*b1cdbd2cSJim Jagielski 		}
326*b1cdbd2cSJim Jagielski     }
327*b1cdbd2cSJim Jagielski 
328*b1cdbd2cSJim Jagielski }
329*b1cdbd2cSJim Jagielski 
330