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 storagetesting;
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 
37*b1cdbd2cSJim Jagielski import storagetesting.TestHelper;
38*b1cdbd2cSJim Jagielski import storagetesting.StorageTest;
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski public class Test04 implements StorageTest {
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski 	XMultiServiceFactory m_xMSF;
43*b1cdbd2cSJim Jagielski 	XSingleServiceFactory m_xStorageFactory;
44*b1cdbd2cSJim Jagielski 	TestHelper m_aTestHelper;
45*b1cdbd2cSJim Jagielski 
Test04( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory )46*b1cdbd2cSJim Jagielski 	public Test04( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory )
47*b1cdbd2cSJim Jagielski 	{
48*b1cdbd2cSJim Jagielski 		m_xMSF = xMSF;
49*b1cdbd2cSJim Jagielski 		m_xStorageFactory = xStorageFactory;
50*b1cdbd2cSJim Jagielski 		m_aTestHelper = new TestHelper( "Test04: " );
51*b1cdbd2cSJim Jagielski 	}
52*b1cdbd2cSJim Jagielski 
test()53*b1cdbd2cSJim Jagielski     public boolean test()
54*b1cdbd2cSJim Jagielski 	{
55*b1cdbd2cSJim Jagielski 		try
56*b1cdbd2cSJim Jagielski 		{
57*b1cdbd2cSJim Jagielski 			String sTempFileURL = m_aTestHelper.CreateTempFile( m_xMSF );
58*b1cdbd2cSJim Jagielski 			if ( sTempFileURL == null || sTempFileURL == "" )
59*b1cdbd2cSJim Jagielski 			{
60*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "No valid temporary file was created!" );
61*b1cdbd2cSJim Jagielski 				return false;
62*b1cdbd2cSJim Jagielski 			}
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski 			// create temporary storage based on arbitrary medium
65*b1cdbd2cSJim Jagielski 			// after such a storage is closed it is lost
66*b1cdbd2cSJim Jagielski 			Object oTempStorage = m_xStorageFactory.createInstance();
67*b1cdbd2cSJim Jagielski 			XStorage xTempStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oTempStorage );
68*b1cdbd2cSJim Jagielski 			if ( xTempStorage == null )
69*b1cdbd2cSJim Jagielski 			{
70*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create temporary storage representation!" );
71*b1cdbd2cSJim Jagielski 				return false;
72*b1cdbd2cSJim Jagielski 			}
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski 			// open substorages and create streams there
75*b1cdbd2cSJim Jagielski 
76*b1cdbd2cSJim Jagielski 			// first substorage of the root storage
77*b1cdbd2cSJim Jagielski 			XStorage xTempSubStorage1 = m_aTestHelper.openSubStorage( xTempStorage,
78*b1cdbd2cSJim Jagielski 																		"SubStorage1",
79*b1cdbd2cSJim Jagielski 																		ElementModes.ELEMENT_WRITE );
80*b1cdbd2cSJim Jagielski 			if ( xTempSubStorage1 == null )
81*b1cdbd2cSJim Jagielski 			{
82*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create substorage!" );
83*b1cdbd2cSJim Jagielski 				return false;
84*b1cdbd2cSJim Jagielski 			}
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski 			byte pBytes1[] = { 1, 1, 1, 1, 1 };
87*b1cdbd2cSJim Jagielski 
88*b1cdbd2cSJim Jagielski 			// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
89*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage1, "SubStream1", "MediaType1", true, pBytes1 ) )
90*b1cdbd2cSJim Jagielski 				return false;
91*b1cdbd2cSJim Jagielski 
92*b1cdbd2cSJim Jagielski 			// second substorage of the root storage
93*b1cdbd2cSJim Jagielski 			XStorage xTempSubStorage2 = m_aTestHelper.openSubStorage( xTempStorage,
94*b1cdbd2cSJim Jagielski 																		"SubStorage2",
95*b1cdbd2cSJim Jagielski 																		ElementModes.ELEMENT_WRITE );
96*b1cdbd2cSJim Jagielski 			if ( xTempSubStorage2 == null )
97*b1cdbd2cSJim Jagielski 			{
98*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create substorage!" );
99*b1cdbd2cSJim Jagielski 				return false;
100*b1cdbd2cSJim Jagielski 			}
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski 			byte pBytes2[] = { 2, 2, 2, 2, 2 };
103*b1cdbd2cSJim Jagielski 
104*b1cdbd2cSJim Jagielski 			// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
105*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage2, "SubStream2", "MediaType2", false, pBytes2 ) )
106*b1cdbd2cSJim Jagielski 				return false;
107*b1cdbd2cSJim Jagielski 
108*b1cdbd2cSJim Jagielski 			// set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly
109*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempStorage,
110*b1cdbd2cSJim Jagielski 															"MediaType3",
111*b1cdbd2cSJim Jagielski 															true,
112*b1cdbd2cSJim Jagielski 															ElementModes.ELEMENT_READWRITE ) )
113*b1cdbd2cSJim Jagielski 				return false;
114*b1cdbd2cSJim Jagielski 
115*b1cdbd2cSJim Jagielski 			// set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly
116*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage1,
117*b1cdbd2cSJim Jagielski 															"MediaType4",
118*b1cdbd2cSJim Jagielski 															false,
119*b1cdbd2cSJim Jagielski 															ElementModes.ELEMENT_WRITE ) )
120*b1cdbd2cSJim Jagielski 				return false;
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski 			// set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly
123*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage2,
124*b1cdbd2cSJim Jagielski 															"MediaType5",
125*b1cdbd2cSJim Jagielski 															false,
126*b1cdbd2cSJim Jagielski 															ElementModes.ELEMENT_WRITE ) )
127*b1cdbd2cSJim Jagielski 				return false;
128*b1cdbd2cSJim Jagielski 
129*b1cdbd2cSJim Jagielski 			// create temporary storage based on a previously created temporary file
130*b1cdbd2cSJim Jagielski 			Object pArgs[] = new Object[2];
131*b1cdbd2cSJim Jagielski 			pArgs[0] = (Object) sTempFileURL;
132*b1cdbd2cSJim Jagielski 			pArgs[1] = new Integer( ElementModes.ELEMENT_WRITE );
133*b1cdbd2cSJim Jagielski 
134*b1cdbd2cSJim Jagielski 			Object oTempFileStorage = m_xStorageFactory.createInstanceWithArguments( pArgs );
135*b1cdbd2cSJim Jagielski 			XStorage xTempFileStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oTempFileStorage );
136*b1cdbd2cSJim Jagielski 			if ( xTempFileStorage == null )
137*b1cdbd2cSJim Jagielski 			{
138*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't create storage based on temporary file!" );
139*b1cdbd2cSJim Jagielski 				return false;
140*b1cdbd2cSJim Jagielski 			}
141*b1cdbd2cSJim Jagielski 
142*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.copyElementTo( xTempStorage, "SubStorage1", xTempFileStorage ) )
143*b1cdbd2cSJim Jagielski 				return false;
144*b1cdbd2cSJim Jagielski 
145*b1cdbd2cSJim Jagielski 			// if storage is not commited before disposing all the changes will be lost
146*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.commitStorage( xTempSubStorage2 ) )
147*b1cdbd2cSJim Jagielski 				return false;
148*b1cdbd2cSJim Jagielski 
149*b1cdbd2cSJim Jagielski 			// a storage must be disposed before moving/removing otherwise the access will be denied
150*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xTempSubStorage2 ) )
151*b1cdbd2cSJim Jagielski 				return false;
152*b1cdbd2cSJim Jagielski 
153*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.moveElementTo( xTempStorage, "SubStorage2", xTempFileStorage ) )
154*b1cdbd2cSJim Jagielski 				return false;
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski 			// SubStorage2 must be removed and disposed now
157*b1cdbd2cSJim Jagielski 			try
158*b1cdbd2cSJim Jagielski 			{
159*b1cdbd2cSJim Jagielski 				xTempSubStorage2.isStreamElement( "SubStream2" );
160*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "SubStorage2 must be disposed already!" );
161*b1cdbd2cSJim Jagielski 				return false;
162*b1cdbd2cSJim Jagielski 			}
163*b1cdbd2cSJim Jagielski 			catch( com.sun.star.lang.DisposedException de )
164*b1cdbd2cSJim Jagielski 			{
165*b1cdbd2cSJim Jagielski 			}
166*b1cdbd2cSJim Jagielski 			catch( Exception e )
167*b1cdbd2cSJim Jagielski 			{
168*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Wrong exception in case of disposed storage, exception: " + e );
169*b1cdbd2cSJim Jagielski 				return false;
170*b1cdbd2cSJim Jagielski 			}
171*b1cdbd2cSJim Jagielski 
172*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.copyElementTo( xTempSubStorage1, "SubStream1", xTempFileStorage ) )
173*b1cdbd2cSJim Jagielski 				return false;
174*b1cdbd2cSJim Jagielski 
175*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.renameElement( xTempFileStorage, "SubStream1", "SubStream1_copy" ) )
176*b1cdbd2cSJim Jagielski 				return false;
177*b1cdbd2cSJim Jagielski 
178*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.moveElementTo( xTempSubStorage1, "SubStream1", xTempFileStorage ) )
179*b1cdbd2cSJim Jagielski 				return false;
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.commitStorage( xTempFileStorage ) )
182*b1cdbd2cSJim Jagielski 				return false;
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski 			// dispose used storages to free resources
185*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xTempStorage ) || !m_aTestHelper.disposeStorage( xTempFileStorage ) )
186*b1cdbd2cSJim Jagielski 				return false;
187*b1cdbd2cSJim Jagielski 
188*b1cdbd2cSJim Jagielski 			// ================================================
189*b1cdbd2cSJim Jagielski 			// now check all the written and copied information
190*b1cdbd2cSJim Jagielski 			// ================================================
191*b1cdbd2cSJim Jagielski 
192*b1cdbd2cSJim Jagielski 			// the temporary file must not be locked any more after storage disposing
193*b1cdbd2cSJim Jagielski 			pArgs[1] = new Integer( ElementModes.ELEMENT_READWRITE );
194*b1cdbd2cSJim Jagielski 			Object oResStorage = m_xStorageFactory.createInstanceWithArguments( pArgs );
195*b1cdbd2cSJim Jagielski 			XStorage xResStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oResStorage );
196*b1cdbd2cSJim Jagielski 			if ( xResStorage == null )
197*b1cdbd2cSJim Jagielski 			{
198*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't reopen storage based on temporary file!" );
199*b1cdbd2cSJim Jagielski 				return false;
200*b1cdbd2cSJim Jagielski 			}
201*b1cdbd2cSJim Jagielski 
202*b1cdbd2cSJim Jagielski 			// open and check SubStorage1
203*b1cdbd2cSJim Jagielski 			XStorage xResSubStorage1 = m_aTestHelper.openSubStorage( xResStorage,
204*b1cdbd2cSJim Jagielski 																		"SubStorage1",
205*b1cdbd2cSJim Jagielski 																		ElementModes.ELEMENT_READ );
206*b1cdbd2cSJim Jagielski 			if ( xResSubStorage1 == null )
207*b1cdbd2cSJim Jagielski 			{
208*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't open existing substorage!" );
209*b1cdbd2cSJim Jagielski 				return false;
210*b1cdbd2cSJim Jagielski 			}
211*b1cdbd2cSJim Jagielski 
212*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStorageProperties( xResSubStorage1, "MediaType4", false, ElementModes.ELEMENT_READ ) )
213*b1cdbd2cSJim Jagielski 				return false;
214*b1cdbd2cSJim Jagielski 
215*b1cdbd2cSJim Jagielski 
216*b1cdbd2cSJim Jagielski 			// open and check SubStorage2
217*b1cdbd2cSJim Jagielski 			XStorage xResSubStorage2 = m_aTestHelper.openSubStorage( xResStorage,
218*b1cdbd2cSJim Jagielski 																		"SubStorage2",
219*b1cdbd2cSJim Jagielski 																		ElementModes.ELEMENT_READ );
220*b1cdbd2cSJim Jagielski 			if ( xResSubStorage2 == null )
221*b1cdbd2cSJim Jagielski 			{
222*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't open existing substorage!" );
223*b1cdbd2cSJim Jagielski 				return false;
224*b1cdbd2cSJim Jagielski 			}
225*b1cdbd2cSJim Jagielski 
226*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStorageProperties( xResSubStorage2, "MediaType5", false, ElementModes.ELEMENT_READ ) )
227*b1cdbd2cSJim Jagielski 				return false;
228*b1cdbd2cSJim Jagielski 
229*b1cdbd2cSJim Jagielski 
230*b1cdbd2cSJim Jagielski 			// check all the result streams
231*b1cdbd2cSJim Jagielski 
232*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResStorage, "SubStream1", "MediaType1", pBytes1 ) )
233*b1cdbd2cSJim Jagielski 				return false;
234*b1cdbd2cSJim Jagielski 
235*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResStorage, "SubStream1_copy", "MediaType1", pBytes1 ) )
236*b1cdbd2cSJim Jagielski 				return false;
237*b1cdbd2cSJim Jagielski 
238*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResSubStorage1, "SubStream1", "MediaType1", pBytes1 ) )
239*b1cdbd2cSJim Jagielski 				return false;
240*b1cdbd2cSJim Jagielski 
241*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.checkStream( xResSubStorage2, "SubStream2", "MediaType2", pBytes2 ) )
242*b1cdbd2cSJim Jagielski 				return false;
243*b1cdbd2cSJim Jagielski 
244*b1cdbd2cSJim Jagielski 			// the storage must be disposed before removing
245*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xResSubStorage2 ) )
246*b1cdbd2cSJim Jagielski 				return false;
247*b1cdbd2cSJim Jagielski 
248*b1cdbd2cSJim Jagielski 			// remove element and check that it was removed completelly
249*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.removeElement( xResStorage, "SubStorage2" ) )
250*b1cdbd2cSJim Jagielski 				return false;
251*b1cdbd2cSJim Jagielski 
252*b1cdbd2cSJim Jagielski 			try
253*b1cdbd2cSJim Jagielski 			{
254*b1cdbd2cSJim Jagielski 				XNameAccess xResAccess = (XNameAccess) UnoRuntime.queryInterface( XNameAccess.class, xResStorage );
255*b1cdbd2cSJim Jagielski 				if ( xResAccess.hasByName( "SubStorage2" ) )
256*b1cdbd2cSJim Jagielski 					m_aTestHelper.Error( "SubStorage2 must be removed already!" );
257*b1cdbd2cSJim Jagielski 			}
258*b1cdbd2cSJim Jagielski 			catch( Exception e )
259*b1cdbd2cSJim Jagielski 			{
260*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Can't get access to root storage, exception: " + e );
261*b1cdbd2cSJim Jagielski 				return false;
262*b1cdbd2cSJim Jagielski 			}
263*b1cdbd2cSJim Jagielski 
264*b1cdbd2cSJim Jagielski 			try
265*b1cdbd2cSJim Jagielski 			{
266*b1cdbd2cSJim Jagielski 				xResSubStorage2.isStreamElement( "SubStream2" );
267*b1cdbd2cSJim Jagielski 
268*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "SubStorage2 must be disposed already!" );
269*b1cdbd2cSJim Jagielski 				return false;
270*b1cdbd2cSJim Jagielski 			}
271*b1cdbd2cSJim Jagielski 			catch( com.sun.star.lang.DisposedException de )
272*b1cdbd2cSJim Jagielski 			{
273*b1cdbd2cSJim Jagielski 			}
274*b1cdbd2cSJim Jagielski 			catch( Exception e )
275*b1cdbd2cSJim Jagielski 			{
276*b1cdbd2cSJim Jagielski 				m_aTestHelper.Error( "Wrong exception in case of disposed storage, exception: " + e );
277*b1cdbd2cSJim Jagielski 				return false;
278*b1cdbd2cSJim Jagielski 			}
279*b1cdbd2cSJim Jagielski 
280*b1cdbd2cSJim Jagielski 			// dispose used storages to free resources
281*b1cdbd2cSJim Jagielski 			if ( !m_aTestHelper.disposeStorage( xResStorage ) )
282*b1cdbd2cSJim Jagielski 				return false;
283*b1cdbd2cSJim Jagielski 
284*b1cdbd2cSJim Jagielski 			return true;
285*b1cdbd2cSJim Jagielski 		}
286*b1cdbd2cSJim Jagielski 		catch( Exception e )
287*b1cdbd2cSJim Jagielski 		{
288*b1cdbd2cSJim Jagielski 			m_aTestHelper.Error( "Exception: " + e );
289*b1cdbd2cSJim Jagielski 			return false;
290*b1cdbd2cSJim Jagielski 		}
291*b1cdbd2cSJim Jagielski     }
292*b1cdbd2cSJim Jagielski 
293*b1cdbd2cSJim Jagielski }
294*b1cdbd2cSJim Jagielski 
295