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