1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 package complex.storages; 23 24 import com.sun.star.uno.XInterface; 25 import com.sun.star.lang.XMultiServiceFactory; 26 import com.sun.star.lang.XSingleServiceFactory; 27 28 import com.sun.star.bridge.XUnoUrlResolver; 29 import com.sun.star.uno.UnoRuntime; 30 import com.sun.star.uno.XInterface; 31 import com.sun.star.io.XStream; 32 import com.sun.star.io.XInputStream; 33 34 import com.sun.star.embed.*; 35 36 import share.LogWriter; 37 import complex.storages.TestHelper; 38 import complex.storages.StorageTest; 39 40 public class RegressionTest_i29169 implements StorageTest { 41 42 XMultiServiceFactory m_xMSF; 43 XSingleServiceFactory m_xStorageFactory; 44 TestHelper m_aTestHelper; 45 RegressionTest_i29169( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter )46 public RegressionTest_i29169( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter ) 47 { 48 m_xMSF = xMSF; 49 m_xStorageFactory = xStorageFactory; 50 m_aTestHelper = new TestHelper( aLogWriter, "RegressionTest_i29169: " ); 51 } 52 test()53 public boolean test() 54 { 55 try 56 { 57 XStream xTempFileStream = m_aTestHelper.CreateTempFileStream( m_xMSF ); 58 if ( xTempFileStream == null ) 59 return false; 60 61 // create storage based on the temporary stream 62 Object pArgs[] = new Object[2]; 63 pArgs[0] = (Object) xTempFileStream; 64 pArgs[1] = new Integer( ElementModes.WRITE ); 65 66 Object oTempStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 67 XStorage xTempStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oTempStorage ); 68 if ( xTempStorage == null ) 69 { 70 m_aTestHelper.Error( "Can't create temporary storage representation!" ); 71 return false; 72 } 73 74 // open a new substorage 75 XStorage xTempSubStorage = m_aTestHelper.openSubStorage( xTempStorage, 76 "SubStorage1", 77 ElementModes.WRITE ); 78 if ( xTempSubStorage == null ) 79 { 80 m_aTestHelper.Error( "Can't create substorage!" ); 81 return false; 82 } 83 84 byte pBytes1[] = { 1, 1, 1, 1, 1 }; 85 86 // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 87 if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage, "SubStream1", "MediaType1", true, pBytes1 ) ) 88 return false; 89 90 // open a new substorage in the existing substorage 91 XStorage xTempSubSubStorage = m_aTestHelper.openSubStorage( xTempSubStorage, 92 "SubSubStorage1", 93 ElementModes.WRITE ); 94 if ( xTempSubStorage == null ) 95 { 96 m_aTestHelper.Error( "Can't create substorage!" ); 97 return false; 98 } 99 100 // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 101 if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubSubStorage, "SubSubStream1", "MediaType2", true, pBytes1 ) ) 102 return false; 103 104 // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 105 if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubSubStorage, 106 "MediaType3", 107 false, 108 ElementModes.WRITE ) ) 109 return false; 110 111 112 // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 113 if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage, 114 "MediaType4", 115 false, 116 ElementModes.WRITE ) ) 117 return false; 118 119 // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 120 if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempStorage, 121 "MediaType5", 122 true, 123 ElementModes.WRITE ) ) 124 return false; 125 126 // ================================================ 127 // commit the storages, and check the renaming in all stages 128 // ================================================ 129 130 // rename the storage before it is commited 131 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage1", "SubSubStorage2" ) ) 132 return false; 133 134 // rename the stream 135 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream1", "SubStream2" ) ) 136 return false; 137 138 // commit lowlevel substorage first 139 if ( !m_aTestHelper.commitStorage( xTempSubSubStorage ) ) 140 return false; 141 142 // rename the storage after it is commited 143 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage2", "SubSubStorage3" ) ) 144 return false; 145 146 // rename the stream one more time 147 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream2", "SubStream3" ) ) 148 return false; 149 150 // commit substorage 151 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 152 return false; 153 154 // rename the storage after it`s parent is commited 155 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage3", "SubSubStorage4" ) ) 156 return false; 157 158 // rename the stream after it`s parent is commited 159 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream3", "SubStream4" ) ) 160 return false; 161 162 // commit substorage to let the renaming take place 163 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 164 return false; 165 166 // commit the root storage so the contents must be stored now 167 if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 168 return false; 169 170 // rename the storage after the package is commited 171 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage4", "SubSubStorage5" ) ) 172 return false; 173 174 // rename the stream after it`s parent is commited 175 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream4", "SubStream5" ) ) 176 return false; 177 178 // commit substorage to let the renaming take place 179 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 180 return false; 181 182 // commit the root storage so the contents must be stored now 183 if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 184 return false; 185 186 // ================================================ 187 // dispose the storages 188 // ================================================ 189 190 // dispose lowerest substorage 191 if ( !m_aTestHelper.disposeStorage( xTempSubSubStorage ) ) 192 return false; 193 194 // dispose substorage 195 if ( !m_aTestHelper.disposeStorage( xTempSubStorage ) ) 196 return false; 197 198 // dispose the temporary storage 199 if ( !m_aTestHelper.disposeStorage( xTempStorage ) ) 200 return false; 201 202 // ================================================ 203 // create a new storage based on the stream and check the substreams and substorages 204 // ================================================ 205 206 oTempStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 207 xTempStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oTempStorage ); 208 if ( xTempStorage == null ) 209 { 210 m_aTestHelper.Error( "Can't create temporary storage representation!" ); 211 return false; 212 } 213 214 // open the substorage 215 xTempSubStorage = m_aTestHelper.openSubStorage( xTempStorage, 216 "SubStorage1", 217 ElementModes.WRITE ); 218 if ( xTempSubStorage == null ) 219 { 220 m_aTestHelper.Error( "Can't create substorage!" ); 221 return false; 222 } 223 224 // open the lowlevel substorage 225 xTempSubSubStorage = m_aTestHelper.openSubStorage( xTempSubStorage, 226 "SubSubStorage5", 227 ElementModes.WRITE ); 228 if ( xTempSubStorage == null ) 229 { 230 m_aTestHelper.Error( "Can't create substorage!" ); 231 return false; 232 } 233 234 // check the storages and streams 235 236 if ( !m_aTestHelper.checkStorageProperties( xTempSubSubStorage, "MediaType3", false, ElementModes.WRITE ) ) 237 return false; 238 239 if ( !m_aTestHelper.checkStorageProperties( xTempSubStorage, "MediaType4", false, ElementModes.WRITE ) ) 240 return false; 241 242 if ( !m_aTestHelper.checkStorageProperties( xTempStorage, "MediaType5", true, ElementModes.WRITE ) ) 243 return false; 244 245 if ( !m_aTestHelper.checkStream( xTempSubStorage, "SubStream5", "MediaType1", true, pBytes1 ) ) 246 return false; 247 248 if ( !m_aTestHelper.checkStream( xTempSubSubStorage, "SubSubStream1", "MediaType2", true, pBytes1 ) ) 249 return false; 250 251 // ================================================ 252 // rename the reopened storages and streams 253 // ================================================ 254 255 // rename the storage before it is commited 256 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage5", "SubSubStorage6" ) ) 257 return false; 258 259 // rename the stream 260 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream5", "SubStream6" ) ) 261 return false; 262 263 // commit lowlevel substorage first 264 if ( !m_aTestHelper.commitStorage( xTempSubSubStorage ) ) 265 return false; 266 267 // rename the storage after it is commited 268 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage6", "SubSubStorage7" ) ) 269 return false; 270 271 // rename the stream one more time 272 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream6", "SubStream7" ) ) 273 return false; 274 275 // commit substorage 276 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 277 return false; 278 279 // rename the storage after it`s parent is commited 280 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage7", "SubSubStorage8" ) ) 281 return false; 282 283 // rename the stream after it`s parent is commited 284 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream7", "SubStream8" ) ) 285 return false; 286 287 // commit substorage to let the renaming take place 288 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 289 return false; 290 291 // commit the root storage so the contents must be stored now 292 if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 293 return false; 294 295 // rename the storage after the package is commited 296 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubSubStorage8", "SubSubStorage9" ) ) 297 return false; 298 299 // rename the stream after it`s parent is commited 300 if ( !m_aTestHelper.renameElement( xTempSubStorage, "SubStream8", "SubStream9" ) ) 301 return false; 302 303 // commit substorage to let the renaming take place 304 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 305 return false; 306 307 // commit the root storage so the contents must be stored now 308 if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 309 return false; 310 311 // ================================================ 312 // dispose the storages 313 // ================================================ 314 315 // dispose lowerest substorage 316 if ( !m_aTestHelper.disposeStorage( xTempSubSubStorage ) ) 317 return false; 318 319 // dispose substorage 320 if ( !m_aTestHelper.disposeStorage( xTempSubStorage ) ) 321 return false; 322 323 // dispose the temporary storage 324 if ( !m_aTestHelper.disposeStorage( xTempStorage ) ) 325 return false; 326 327 328 // ================================================ 329 // create a new readonly storage based on the stream and check the contents 330 // ================================================ 331 332 pArgs[1] = new Integer( ElementModes.READ ); 333 oTempStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 334 xTempStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oTempStorage ); 335 if ( xTempStorage == null ) 336 { 337 m_aTestHelper.Error( "Can't create temporary storage representation!" ); 338 return false; 339 } 340 341 // open the substorage 342 xTempSubStorage = m_aTestHelper.openSubStorage( xTempStorage, 343 "SubStorage1", 344 ElementModes.READ ); 345 if ( xTempSubStorage == null ) 346 { 347 m_aTestHelper.Error( "Can't create substorage!" ); 348 return false; 349 } 350 351 // open the lowlevel substorage 352 xTempSubSubStorage = m_aTestHelper.openSubStorage( xTempSubStorage, 353 "SubSubStorage9", 354 ElementModes.READ ); 355 if ( xTempSubStorage == null ) 356 { 357 m_aTestHelper.Error( "Can't create substorage!" ); 358 return false; 359 } 360 361 // check the storages and streams 362 363 if ( !m_aTestHelper.checkStorageProperties( xTempSubSubStorage, "MediaType3", false, ElementModes.READ ) ) 364 return false; 365 366 if ( !m_aTestHelper.checkStorageProperties( xTempSubStorage, "MediaType4", false, ElementModes.READ ) ) 367 return false; 368 369 if ( !m_aTestHelper.checkStorageProperties( xTempStorage, "MediaType5", true, ElementModes.READ ) ) 370 return false; 371 372 if ( !m_aTestHelper.checkStream( xTempSubStorage, "SubStream9", "MediaType1", true, pBytes1 ) ) 373 return false; 374 375 if ( !m_aTestHelper.checkStream( xTempSubSubStorage, "SubSubStream1", "MediaType2", true, pBytes1 ) ) 376 return false; 377 378 // the storage is based on the temporary stream so it can be left undisposed, since it does not lock 379 // any resource, later the garbage collector will release the object and it must die by refcount 380 381 return true; 382 } 383 catch( Exception e ) 384 { 385 m_aTestHelper.Error( "Exception: " + e ); 386 return false; 387 } 388 } 389 } 390 391