1 package complex.storages; 2 3 import com.sun.star.uno.XInterface; 4 import com.sun.star.lang.XMultiServiceFactory; 5 import com.sun.star.lang.XSingleServiceFactory; 6 7 import com.sun.star.bridge.XUnoUrlResolver; 8 import com.sun.star.uno.UnoRuntime; 9 import com.sun.star.uno.XInterface; 10 import com.sun.star.io.XStream; 11 import com.sun.star.io.XInputStream; 12 13 import com.sun.star.embed.*; 14 15 import share.LogWriter; 16 import complex.storages.TestHelper; 17 import complex.storages.StorageTest; 18 19 public class RegressionTest_i29321 implements StorageTest { 20 21 XMultiServiceFactory m_xMSF; 22 XSingleServiceFactory m_xStorageFactory; 23 TestHelper m_aTestHelper; 24 25 public RegressionTest_i29321( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter ) 26 { 27 m_xMSF = xMSF; 28 m_xStorageFactory = xStorageFactory; 29 m_aTestHelper = new TestHelper( aLogWriter, "RegressionTest_i29321: " ); 30 } 31 32 public boolean test() 33 { 34 try 35 { 36 XStream xTempFileStream = m_aTestHelper.CreateTempFileStream( m_xMSF ); 37 if ( xTempFileStream == null ) 38 return false; 39 40 // create storage based on the temporary stream 41 Object pArgs[] = new Object[2]; 42 pArgs[0] = (Object) xTempFileStream; 43 pArgs[1] = new Integer( ElementModes.WRITE ); 44 45 Object oTempStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 46 XStorage xTempStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oTempStorage ); 47 if ( xTempStorage == null ) 48 { 49 m_aTestHelper.Error( "Can't create temporary storage representation!" ); 50 return false; 51 } 52 53 // open a new substorage 54 XStorage xTempSubStorage = m_aTestHelper.openSubStorage( xTempStorage, 55 "SubStorage1", 56 ElementModes.WRITE ); 57 if ( xTempSubStorage == null ) 58 { 59 m_aTestHelper.Error( "Can't create substorage!" ); 60 return false; 61 } 62 63 // open a new substorage 64 XStorage xTempSubSubStorage = m_aTestHelper.openSubStorage( xTempSubStorage, 65 "SubSubStorage1", 66 ElementModes.WRITE ); 67 if ( xTempSubSubStorage == null ) 68 { 69 m_aTestHelper.Error( "Can't create substorage!" ); 70 return false; 71 } 72 73 byte pBytes1[] = { 1, 1, 1, 1, 1 }; 74 75 // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 76 if ( !m_aTestHelper.WriteBytesToSubstream( xTempStorage, "Stream1", "MediaType1", true, pBytes1 ) ) 77 return false; 78 79 // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 80 if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubStorage, "SubStream1", "MediaType2", true, pBytes1 ) ) 81 return false; 82 83 // open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes 84 if ( !m_aTestHelper.WriteBytesToSubstream( xTempSubSubStorage, "SubSubStream1", "MediaType3", true, pBytes1 ) ) 85 return false; 86 87 // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 88 if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempStorage, 89 "MediaType4", 90 true, 91 ElementModes.WRITE ) ) 92 return false; 93 94 // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 95 if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage, 96 "MediaType5", 97 false, 98 ElementModes.WRITE ) ) 99 return false; 100 101 // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 102 if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubSubStorage, 103 "MediaType6", 104 false, 105 ElementModes.WRITE ) ) 106 return false; 107 108 // ================================================ 109 // commit the storages twice to test the bug scenario 110 // ================================================ 111 112 // commit lowlevel substorage first 113 if ( !m_aTestHelper.commitStorage( xTempSubSubStorage ) ) 114 return false; 115 116 // commit substorage 117 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 118 return false; 119 120 // commit substorage to let the renaming take place 121 if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 122 return false; 123 124 // commit lowlevel substorage first 125 if ( !m_aTestHelper.commitStorage( xTempSubSubStorage ) ) 126 return false; 127 128 // commit substorage 129 if ( !m_aTestHelper.commitStorage( xTempSubStorage ) ) 130 return false; 131 132 // commit substorage to let the renaming take place 133 if ( !m_aTestHelper.commitStorage( xTempStorage ) ) 134 return false; 135 136 // ================================================ 137 // check the storages and streams without closing 138 // ================================================ 139 140 if ( !m_aTestHelper.checkStorageProperties( xTempSubSubStorage, "MediaType6", false, ElementModes.WRITE ) ) 141 return false; 142 143 if ( !m_aTestHelper.checkStorageProperties( xTempSubStorage, "MediaType5", false, ElementModes.WRITE ) ) 144 return false; 145 146 if ( !m_aTestHelper.checkStorageProperties( xTempStorage, "MediaType4", true, ElementModes.WRITE ) ) 147 return false; 148 149 if ( !m_aTestHelper.checkStream( xTempSubSubStorage, "SubSubStream1", "MediaType3", true, pBytes1 ) ) 150 return false; 151 152 if ( !m_aTestHelper.checkStream( xTempSubStorage, "SubStream1", "MediaType2", true, pBytes1 ) ) 153 return false; 154 155 if ( !m_aTestHelper.checkStream( xTempStorage, "Stream1", "MediaType1", true, pBytes1 ) ) 156 return false; 157 158 // the root storage is based on the temporary stream so it can be left undisposed, since it does not lock 159 // any resource, later the garbage collector will release the object and it must die by refcount 160 161 return true; 162 } 163 catch( Exception e ) 164 { 165 m_aTestHelper.Error( "Exception: " + e ); 166 return false; 167 } 168 } 169 } 170 171