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.storages; 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 28*b1cdbd2cSJim Jagielski import com.sun.star.bridge.XUnoUrlResolver; 29*b1cdbd2cSJim Jagielski import com.sun.star.uno.UnoRuntime; 30*b1cdbd2cSJim Jagielski import com.sun.star.uno.XInterface; 31*b1cdbd2cSJim Jagielski import com.sun.star.io.XStream; 32*b1cdbd2cSJim Jagielski import com.sun.star.io.XInputStream; 33*b1cdbd2cSJim Jagielski 34*b1cdbd2cSJim Jagielski import com.sun.star.embed.*; 35*b1cdbd2cSJim Jagielski 36*b1cdbd2cSJim Jagielski import share.LogWriter; 37*b1cdbd2cSJim Jagielski import complex.storages.TestHelper; 38*b1cdbd2cSJim Jagielski import complex.storages.StorageTest; 39*b1cdbd2cSJim Jagielski 40*b1cdbd2cSJim Jagielski public class RegressionTest_i29321 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 RegressionTest_i29321( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter )46*b1cdbd2cSJim Jagielski public RegressionTest_i29321( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter ) 47*b1cdbd2cSJim Jagielski { 48*b1cdbd2cSJim Jagielski m_xMSF = xMSF; 49*b1cdbd2cSJim Jagielski m_xStorageFactory = xStorageFactory; 50*b1cdbd2cSJim Jagielski m_aTestHelper = new TestHelper( aLogWriter, "RegressionTest_i29321: " ); 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 XStream xTempFileStream = m_aTestHelper.CreateTempFileStream( m_xMSF ); 58*b1cdbd2cSJim Jagielski if ( xTempFileStream == null ) 59*b1cdbd2cSJim Jagielski return false; 60*b1cdbd2cSJim Jagielski 61*b1cdbd2cSJim Jagielski // create storage based on the temporary stream 62*b1cdbd2cSJim Jagielski Object pArgs[] = new Object[2]; 63*b1cdbd2cSJim Jagielski pArgs[0] = (Object) xTempFileStream; 64*b1cdbd2cSJim Jagielski pArgs[1] = new Integer( ElementModes.WRITE ); 65*b1cdbd2cSJim Jagielski 66*b1cdbd2cSJim Jagielski Object oTempStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 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 a new substorage 75*b1cdbd2cSJim Jagielski XStorage xTempSubStorage = m_aTestHelper.openSubStorage( xTempStorage, 76*b1cdbd2cSJim Jagielski "SubStorage1", 77*b1cdbd2cSJim Jagielski ElementModes.WRITE ); 78*b1cdbd2cSJim Jagielski if ( xTempSubStorage == null ) 79*b1cdbd2cSJim Jagielski { 80*b1cdbd2cSJim Jagielski m_aTestHelper.Error( "Can't create substorage!" ); 81*b1cdbd2cSJim Jagielski return false; 82*b1cdbd2cSJim Jagielski } 83*b1cdbd2cSJim Jagielski 84*b1cdbd2cSJim Jagielski // open a new substorage 85*b1cdbd2cSJim Jagielski XStorage xTempSubSubStorage = m_aTestHelper.openSubStorage( xTempSubStorage, 86*b1cdbd2cSJim Jagielski "SubSubStorage1", 87*b1cdbd2cSJim Jagielski ElementModes.WRITE ); 88*b1cdbd2cSJim Jagielski if ( xTempSubSubStorage == null ) 89*b1cdbd2cSJim Jagielski { 90*b1cdbd2cSJim Jagielski m_aTestHelper.Error( "Can't create substorage!" ); 91*b1cdbd2cSJim Jagielski return false; 92*b1cdbd2cSJim Jagielski } 93*b1cdbd2cSJim Jagielski 94*b1cdbd2cSJim Jagielski byte pBytes1[] = { 1, 1, 1, 1, 1 }; 95*b1cdbd2cSJim Jagielski 96*b1cdbd2cSJim Jagielski // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 97*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.WriteBytesToSubstream( xTempStorage, "Stream1", "MediaType1", true, pBytes1 ) ) 98*b1cdbd2cSJim Jagielski return false; 99*b1cdbd2cSJim Jagielski 100*b1cdbd2cSJim Jagielski // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 101*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage, "SubStream1", "MediaType2", true, pBytes1 ) ) 102*b1cdbd2cSJim Jagielski return false; 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( xTempSubSubStorage, "SubSubStream1", "MediaType3", true, pBytes1 ) ) 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 "MediaType4", 111*b1cdbd2cSJim Jagielski true, 112*b1cdbd2cSJim Jagielski ElementModes.WRITE ) ) 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( xTempSubStorage, 117*b1cdbd2cSJim Jagielski "MediaType5", 118*b1cdbd2cSJim Jagielski false, 119*b1cdbd2cSJim Jagielski ElementModes.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( xTempSubSubStorage, 124*b1cdbd2cSJim Jagielski "MediaType6", 125*b1cdbd2cSJim Jagielski false, 126*b1cdbd2cSJim Jagielski ElementModes.WRITE ) ) 127*b1cdbd2cSJim Jagielski return false; 128*b1cdbd2cSJim Jagielski 129*b1cdbd2cSJim Jagielski // ================================================ 130*b1cdbd2cSJim Jagielski // commit the storages twice to test the bug scenario 131*b1cdbd2cSJim Jagielski // ================================================ 132*b1cdbd2cSJim Jagielski 133*b1cdbd2cSJim Jagielski // commit lowlevel substorage first 134*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.commitStorage( xTempSubSubStorage ) ) 135*b1cdbd2cSJim Jagielski return false; 136*b1cdbd2cSJim Jagielski 137*b1cdbd2cSJim Jagielski // commit substorage 138*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 139*b1cdbd2cSJim Jagielski return false; 140*b1cdbd2cSJim Jagielski 141*b1cdbd2cSJim Jagielski // commit substorage to let the renaming take place 142*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 143*b1cdbd2cSJim Jagielski return false; 144*b1cdbd2cSJim Jagielski 145*b1cdbd2cSJim Jagielski // commit lowlevel substorage first 146*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.commitStorage( xTempSubSubStorage ) ) 147*b1cdbd2cSJim Jagielski return false; 148*b1cdbd2cSJim Jagielski 149*b1cdbd2cSJim Jagielski // commit substorage 150*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 151*b1cdbd2cSJim Jagielski return false; 152*b1cdbd2cSJim Jagielski 153*b1cdbd2cSJim Jagielski // commit substorage to let the renaming take place 154*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 155*b1cdbd2cSJim Jagielski return false; 156*b1cdbd2cSJim Jagielski 157*b1cdbd2cSJim Jagielski // ================================================ 158*b1cdbd2cSJim Jagielski // check the storages and streams without closing 159*b1cdbd2cSJim Jagielski // ================================================ 160*b1cdbd2cSJim Jagielski 161*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.checkStorageProperties( xTempSubSubStorage, "MediaType6", false, ElementModes.WRITE ) ) 162*b1cdbd2cSJim Jagielski return false; 163*b1cdbd2cSJim Jagielski 164*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.checkStorageProperties( xTempSubStorage, "MediaType5", false, ElementModes.WRITE ) ) 165*b1cdbd2cSJim Jagielski return false; 166*b1cdbd2cSJim Jagielski 167*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.checkStorageProperties( xTempStorage, "MediaType4", true, ElementModes.WRITE ) ) 168*b1cdbd2cSJim Jagielski return false; 169*b1cdbd2cSJim Jagielski 170*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.checkStream( xTempSubSubStorage, "SubSubStream1", "MediaType3", true, pBytes1 ) ) 171*b1cdbd2cSJim Jagielski return false; 172*b1cdbd2cSJim Jagielski 173*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.checkStream( xTempSubStorage, "SubStream1", "MediaType2", true, pBytes1 ) ) 174*b1cdbd2cSJim Jagielski return false; 175*b1cdbd2cSJim Jagielski 176*b1cdbd2cSJim Jagielski if ( !m_aTestHelper.checkStream( xTempStorage, "Stream1", "MediaType1", true, pBytes1 ) ) 177*b1cdbd2cSJim Jagielski return false; 178*b1cdbd2cSJim Jagielski 179*b1cdbd2cSJim Jagielski // the root storage is based on the temporary stream so it can be left undisposed, since it does not lock 180*b1cdbd2cSJim Jagielski // any resource, later the garbage collector will release the object and it must die by refcount 181*b1cdbd2cSJim Jagielski 182*b1cdbd2cSJim Jagielski return true; 183*b1cdbd2cSJim Jagielski } 184*b1cdbd2cSJim Jagielski catch( Exception e ) 185*b1cdbd2cSJim Jagielski { 186*b1cdbd2cSJim Jagielski m_aTestHelper.Error( "Exception: " + e ); 187*b1cdbd2cSJim Jagielski return false; 188*b1cdbd2cSJim Jagielski } 189*b1cdbd2cSJim Jagielski } 190*b1cdbd2cSJim Jagielski } 191*b1cdbd2cSJim Jagielski 192