1*a740f2aaSAndrew Rist /************************************************************** 2*a740f2aaSAndrew Rist * 3*a740f2aaSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*a740f2aaSAndrew Rist * or more contributor license agreements. See the NOTICE file 5*a740f2aaSAndrew Rist * distributed with this work for additional information 6*a740f2aaSAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*a740f2aaSAndrew Rist * to you under the Apache License, Version 2.0 (the 8*a740f2aaSAndrew Rist * "License"); you may not use this file except in compliance 9*a740f2aaSAndrew Rist * with the License. You may obtain a copy of the License at 10*a740f2aaSAndrew Rist * 11*a740f2aaSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*a740f2aaSAndrew Rist * 13*a740f2aaSAndrew Rist * Unless required by applicable law or agreed to in writing, 14*a740f2aaSAndrew Rist * software distributed under the License is distributed on an 15*a740f2aaSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*a740f2aaSAndrew Rist * KIND, either express or implied. See the License for the 17*a740f2aaSAndrew Rist * specific language governing permissions and limitations 18*a740f2aaSAndrew Rist * under the License. 19*a740f2aaSAndrew Rist * 20*a740f2aaSAndrew Rist *************************************************************/ 21*a740f2aaSAndrew Rist 22cdf0e10cSrcweir package complex.storages; 23cdf0e10cSrcweir 24cdf0e10cSrcweir import com.sun.star.uno.XInterface; 25cdf0e10cSrcweir import com.sun.star.lang.XMultiServiceFactory; 26cdf0e10cSrcweir import com.sun.star.lang.XSingleServiceFactory; 27cdf0e10cSrcweir 28cdf0e10cSrcweir import com.sun.star.bridge.XUnoUrlResolver; 29cdf0e10cSrcweir import com.sun.star.uno.UnoRuntime; 30cdf0e10cSrcweir import com.sun.star.uno.XInterface; 31cdf0e10cSrcweir 32cdf0e10cSrcweir import com.sun.star.embed.*; 33cdf0e10cSrcweir 34cdf0e10cSrcweir import share.LogWriter; 35cdf0e10cSrcweir import complex.storages.TestHelper; 36cdf0e10cSrcweir import complex.storages.StorageTest; 37cdf0e10cSrcweir 38cdf0e10cSrcweir public class Test14 implements StorageTest { 39cdf0e10cSrcweir 40cdf0e10cSrcweir XMultiServiceFactory m_xMSF; 41cdf0e10cSrcweir XSingleServiceFactory m_xStorageFactory; 42cdf0e10cSrcweir TestHelper m_aTestHelper; 43cdf0e10cSrcweir Test14( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter )44cdf0e10cSrcweir public Test14( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter ) 45cdf0e10cSrcweir { 46cdf0e10cSrcweir m_xMSF = xMSF; 47cdf0e10cSrcweir m_xStorageFactory = xStorageFactory; 48cdf0e10cSrcweir m_aTestHelper = new TestHelper( aLogWriter, "Test14: " ); 49cdf0e10cSrcweir } 50cdf0e10cSrcweir test()51cdf0e10cSrcweir public boolean test() 52cdf0e10cSrcweir { 53cdf0e10cSrcweir String aStreamPrefix = ""; 54cdf0e10cSrcweir for ( int nInd = 0; nInd < 4; ++nInd, aStreamPrefix += "SubStorage" + nInd ) 55cdf0e10cSrcweir if ( !testForPath( aStreamPrefix ) ) 56cdf0e10cSrcweir return false; 57cdf0e10cSrcweir 58cdf0e10cSrcweir return true; 59cdf0e10cSrcweir } 60cdf0e10cSrcweir testForPath( String aStreamPrefix )61cdf0e10cSrcweir public boolean testForPath( String aStreamPrefix ) 62cdf0e10cSrcweir { 63cdf0e10cSrcweir try 64cdf0e10cSrcweir { 65cdf0e10cSrcweir String aSubStream1Path = aStreamPrefix + "SubStream1"; 66cdf0e10cSrcweir String aSubStream2Path = aStreamPrefix + "SubStream2"; 67cdf0e10cSrcweir String aSubStream3Path = aStreamPrefix + "SubStream3"; 68cdf0e10cSrcweir 69cdf0e10cSrcweir String sTempFileURL = m_aTestHelper.CreateTempFile( m_xMSF ); 70cdf0e10cSrcweir if ( sTempFileURL == null || sTempFileURL == "" ) 71cdf0e10cSrcweir { 72cdf0e10cSrcweir m_aTestHelper.Error( "No valid temporary file was created!" ); 73cdf0e10cSrcweir return false; 74cdf0e10cSrcweir } 75cdf0e10cSrcweir 76cdf0e10cSrcweir // create temporary storage based on a previously created temporary file 77cdf0e10cSrcweir Object pArgs[] = new Object[2]; 78cdf0e10cSrcweir pArgs[0] = (Object) sTempFileURL; 79cdf0e10cSrcweir pArgs[1] = new Integer( ElementModes.WRITE ); 80cdf0e10cSrcweir 81cdf0e10cSrcweir Object oTempFileStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 82cdf0e10cSrcweir XStorage xTempFileStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oTempFileStorage ); 83cdf0e10cSrcweir if ( xTempFileStorage == null ) 84cdf0e10cSrcweir { 85cdf0e10cSrcweir m_aTestHelper.Error( "Can't create storage based on temporary file!" ); 86cdf0e10cSrcweir return false; 87cdf0e10cSrcweir } 88cdf0e10cSrcweir 89cdf0e10cSrcweir byte pBytes1[] = { 1, 1, 1, 1, 1 }; 90cdf0e10cSrcweir String sPass1 = "12345"; 91cdf0e10cSrcweir 92cdf0e10cSrcweir // open a new substream hierarchically, set "MediaType" and "Compressed" properties to it, write some bytes 93cdf0e10cSrcweir // and commit 94cdf0e10cSrcweir if ( !m_aTestHelper.WriteBytesToEncrStreamH( xTempFileStorage, aSubStream1Path, "MediaType1", true, pBytes1, sPass1, true ) ) 95cdf0e10cSrcweir return false; 96cdf0e10cSrcweir 97cdf0e10cSrcweir byte pBytes2[] = { 2, 2, 2, 2, 2 }; 98cdf0e10cSrcweir String sPass2 = "54321"; 99cdf0e10cSrcweir 100cdf0e10cSrcweir // open a new substream hierarchically, set "MediaType" and "Compressed" properties to it, write some bytes 101cdf0e10cSrcweir // and commit 102cdf0e10cSrcweir if ( !m_aTestHelper.WriteBytesToEncrStreamH( xTempFileStorage, aSubStream2Path, "MediaType2", false, pBytes2, sPass2, true ) ) 103cdf0e10cSrcweir return false; 104cdf0e10cSrcweir 105cdf0e10cSrcweir // open a new substream hierarchically, set "MediaType" and "Compressed" properties to it, write some bytes 106cdf0e10cSrcweir // and don't commit 107cdf0e10cSrcweir if ( !m_aTestHelper.WriteBytesToEncrStreamH( xTempFileStorage, aSubStream3Path, "MediaType2", false, pBytes2, sPass2, false ) ) 108cdf0e10cSrcweir return false; 109cdf0e10cSrcweir 110cdf0e10cSrcweir // set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly 111cdf0e10cSrcweir if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempFileStorage, 112cdf0e10cSrcweir "MediaType3", 113cdf0e10cSrcweir true, 114cdf0e10cSrcweir ElementModes.WRITE ) ) 115cdf0e10cSrcweir return false; 116cdf0e10cSrcweir 117cdf0e10cSrcweir // commit the root storage so the contents must be stored now 118cdf0e10cSrcweir if ( !m_aTestHelper.commitStorage( xTempFileStorage ) ) 119cdf0e10cSrcweir return false; 120cdf0e10cSrcweir 121cdf0e10cSrcweir // dispose used storages to free resources 122cdf0e10cSrcweir if ( !m_aTestHelper.disposeStorage( xTempFileStorage ) ) 123cdf0e10cSrcweir return false; 124cdf0e10cSrcweir 125cdf0e10cSrcweir // ================================================ 126cdf0e10cSrcweir // now reopen the storage, 127cdf0e10cSrcweir // check all the written and copied information 128cdf0e10cSrcweir // and change it 129cdf0e10cSrcweir // ================================================ 130cdf0e10cSrcweir 131cdf0e10cSrcweir // the temporary file must not be locked any more after storage disposing 132cdf0e10cSrcweir oTempFileStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 133cdf0e10cSrcweir xTempFileStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oTempFileStorage ); 134cdf0e10cSrcweir if ( xTempFileStorage == null ) 135cdf0e10cSrcweir { 136cdf0e10cSrcweir m_aTestHelper.Error( "Can't create storage based on temporary file!" ); 137cdf0e10cSrcweir return false; 138cdf0e10cSrcweir } 139cdf0e10cSrcweir 140cdf0e10cSrcweir if ( !m_aTestHelper.checkStorageProperties( xTempFileStorage, "MediaType3", true, ElementModes.WRITE ) ) 141cdf0e10cSrcweir return false; 142cdf0e10cSrcweir 143cdf0e10cSrcweir if ( !m_aTestHelper.checkEncrStreamH( xTempFileStorage, aSubStream1Path, "MediaType1", pBytes1, sPass1 ) ) 144cdf0e10cSrcweir return false; 145cdf0e10cSrcweir 146cdf0e10cSrcweir if ( !m_aTestHelper.checkEncrStreamH( xTempFileStorage, aSubStream2Path, "MediaType2", pBytes2, sPass2 ) ) 147cdf0e10cSrcweir return false; 148cdf0e10cSrcweir 149cdf0e10cSrcweir if ( !m_aTestHelper.cantOpenEncrStreamH( xTempFileStorage, aSubStream3Path, ElementModes.READ, sPass2 ) ) 150cdf0e10cSrcweir return false; 151cdf0e10cSrcweir 152cdf0e10cSrcweir // open existing substream hierarchically, set "MediaType" and "Compressed" properties to it, write some bytes 153cdf0e10cSrcweir // and commit 154cdf0e10cSrcweir if ( !m_aTestHelper.WriteBytesToEncrStreamH( xTempFileStorage, aSubStream1Path, "MediaType3", true, pBytes2, sPass1, true ) ) 155cdf0e10cSrcweir return false; 156cdf0e10cSrcweir 157cdf0e10cSrcweir // open existing substream hierarchically, set "MediaType" and "Compressed" properties to it, write some bytes 158cdf0e10cSrcweir // and don't commit 159cdf0e10cSrcweir if ( !m_aTestHelper.WriteBytesToEncrStreamH( xTempFileStorage, aSubStream2Path, "MediaType3", true, pBytes1, sPass2, false ) ) 160cdf0e10cSrcweir return false; 161cdf0e10cSrcweir 162cdf0e10cSrcweir // commit the root storage so the contents must be stored now 163cdf0e10cSrcweir if ( !m_aTestHelper.commitStorage( xTempFileStorage ) ) 164cdf0e10cSrcweir return false; 165cdf0e10cSrcweir 166cdf0e10cSrcweir // dispose used storages to free resources 167cdf0e10cSrcweir if ( !m_aTestHelper.disposeStorage( xTempFileStorage ) ) 168cdf0e10cSrcweir return false; 169cdf0e10cSrcweir 170cdf0e10cSrcweir // ================================================ 171cdf0e10cSrcweir // now reopen the storage, 172cdf0e10cSrcweir // check all the written information 173cdf0e10cSrcweir // ================================================ 174cdf0e10cSrcweir 175cdf0e10cSrcweir // the temporary file must not be locked any more after storage disposing 176cdf0e10cSrcweir pArgs[1] = new Integer( ElementModes.READ ); 177cdf0e10cSrcweir Object oResultStorage = m_xStorageFactory.createInstanceWithArguments( pArgs ); 178cdf0e10cSrcweir XStorage xResultStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oResultStorage ); 179cdf0e10cSrcweir if ( xResultStorage == null ) 180cdf0e10cSrcweir { 181cdf0e10cSrcweir m_aTestHelper.Error( "Can't reopen storage based on temporary file!" ); 182cdf0e10cSrcweir return false; 183cdf0e10cSrcweir } 184cdf0e10cSrcweir 185cdf0e10cSrcweir if ( !m_aTestHelper.checkStorageProperties( xResultStorage, "MediaType3", true, ElementModes.READ ) ) 186cdf0e10cSrcweir return false; 187cdf0e10cSrcweir 188cdf0e10cSrcweir if ( !m_aTestHelper.checkEncrStreamH( xResultStorage, aSubStream1Path, "MediaType3", pBytes2, sPass1 ) ) 189cdf0e10cSrcweir return false; 190cdf0e10cSrcweir 191cdf0e10cSrcweir // the following stream was not commited last time, so the last change must be lost 192cdf0e10cSrcweir if ( !m_aTestHelper.checkEncrStreamH( xResultStorage, aSubStream2Path, "MediaType2", pBytes2, sPass2 ) ) 193cdf0e10cSrcweir return false; 194cdf0e10cSrcweir 195cdf0e10cSrcweir // dispose used storages to free resources 196cdf0e10cSrcweir if ( !m_aTestHelper.disposeStorage( xResultStorage ) ) 197cdf0e10cSrcweir return false; 198cdf0e10cSrcweir 199cdf0e10cSrcweir return true; 200cdf0e10cSrcweir } 201cdf0e10cSrcweir catch( Exception e ) 202cdf0e10cSrcweir { 203cdf0e10cSrcweir m_aTestHelper.Error( "Exception: " + e ); 204cdf0e10cSrcweir return false; 205cdf0e10cSrcweir } 206cdf0e10cSrcweir } 207cdf0e10cSrcweir 208cdf0e10cSrcweir } 209cdf0e10cSrcweir 210