forked from amazingfate/loongoffice
2009-04-22 12:58:26 +0200 b_michaelsen r271093 : #i101084# using the frames enumeration for other SwXFrames-queries; also added a complex test to ensure the behavior to be the same 2009-04-20 14:53:03 +0200 mav r270987 : #i101219# adjust the testcases to test memory cache and temporary file cache 2009-04-20 14:52:09 +0200 mav r270986 : #i101219#,#i99077# use memory to cache data; no precopying on commit 2009-04-20 14:39:21 +0200 mav r270984 : #i101219# use memory to cache data 2009-04-20 14:39:08 +0200 mav r270983 : #i101219# use memory to cache data 2009-04-20 14:38:45 +0200 mav r270982 : #i101219# use memory to cache data 2009-04-17 07:37:52 +0200 os r270912 : CWS-TOOLING: rebase CWS os128 to trunk@270723 (milestone: DEV300:m46) 2009-04-15 14:54:18 +0200 b_michaelsen r270845 : #i101084# using frame enumerations for paragraph export for better performance 2009-04-15 14:52:54 +0200 b_michaelsen r270843 : #i101084# implemented XEnumerationAccess interface on framesets 2009-04-03 17:08:10 +0200 mav r270504 : #i100722# do not compress streams of known compressed types per default 2009-04-03 13:49:50 +0200 os r270484 : resync error fixed 2009-04-03 12:55:32 +0200 mav r270470 : #i100722# do not compress streams of known compressed types per default 2009-04-03 10:00:58 +0200 os r270463 : resync error fixed 2009-04-03 09:52:53 +0200 os r270462 : resync error fixed 2009-04-03 09:10:14 +0200 os r270449 : #i99568# string compare operator of hash_map changed 2009-04-03 09:03:49 +0200 os r270446 : #i100683# normalize file URLs 2009-04-02 11:09:27 +0200 os r270381 : #i100683# making URLs relative without file access 2009-04-02 09:04:42 +0200 os r270366 : CWS-TOOLING: rebase CWS os128 to trunk@270033 (milestone: DEV300:m45) 2009-03-31 08:08:37 +0200 os r270258 : #i100683# reducing calls to URIHelper::simpleNormalizeMakeRelative() 2009-03-19 17:06:22 +0100 os r269756 : #i99568# XTolerantMultiPropertySet activated 2009-03-16 11:46:14 +0100 os r269517 : wrong commit to #i97471# removed 2009-03-16 11:36:50 +0100 os r269514 : #i97471# SwDrawTextShell::Init(): mouse double click and key input in group objects at the same time: prevent crash 2009-03-13 11:08:54 +0100 os r269464 : #i99568# static SfxItemPropertySet 2009-03-13 11:03:22 +0100 os r269463 : #i99568# static SfxItemPropertySet 2009-03-11 12:59:27 +0100 os r269320 : #i99568# WhichId of properties handled from ScDocOptionsObj added 2009-03-06 09:09:58 +0100 os r268972 : #i99568# SfxItemPropertySet improvements 2009-03-05 20:54:43 +0100 os r268942 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 20:19:52 +0100 os r268941 : #i99568# SfxItemPropertySet improvements 2009-03-05 20:05:03 +0100 os r268940 : #i99568# SfxItemPropertySet improvements 2009-03-05 18:54:47 +0100 os r268936 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 17:51:38 +0100 os r268931 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 17:33:03 +0100 os r268930 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 15:53:00 +0100 os r268920 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 15:52:50 +0100 os r268919 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 15:50:41 +0100 os r268918 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 15:41:04 +0100 os r268916 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 15:40:40 +0100 os r268915 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 10:16:20 +0100 os r268881 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-05 10:15:55 +0100 os r268880 : #i99568# Sfx/SvxItemPropertySet improvements 2009-03-03 08:40:09 +0100 os r268704 : ScTableSheetObj::GetItemPropertyMap fixed 2009-03-03 07:50:00 +0100 os r268703 : SfxItemProperty set as pointer 2009-03-03 07:49:46 +0100 os r268702 : SfxItemProperty set as pointer 2009-03-02 08:15:37 +0100 os r268631 : minor fix 2009-03-02 07:58:38 +0100 os r268630 : minor fix 2009-02-27 13:03:25 +0100 os r268584 : exports 2009-02-27 11:17:04 +0100 os r268567 : debug code removed 2009-02-27 11:04:07 +0100 os r268565 : duplicate return removed 2009-02-27 10:17:37 +0100 os r268558 : syntax fixed 2009-02-27 09:56:14 +0100 os r268554 : #i99568# type mix fixed 2009-02-27 09:40:56 +0100 os r268553 : #i99568# exports changes reverted 2009-02-25 12:50:54 +0100 os r268433 : #i99568# SfxItemPropertySet rework 2009-02-25 12:13:39 +0100 os r268432 : #i99568# SfxItemPropertySet rework 2009-02-25 12:12:47 +0100 os r268431 : #i99568# SfxItemPropertySet rework 2009-02-25 12:10:27 +0100 os r268430 : #i99568# SfxItemPropertySet rework 2009-02-25 12:09:36 +0100 os r268429 : #i99568# SfxItemPropertySet rework 2009-02-25 12:07:39 +0100 os r268428 : #i99568# SfxItemPropertySet rework 2009-02-25 11:59:35 +0100 os r268427 : #i99568# SfxItemPropertySet rework 2009-02-25 11:52:52 +0100 os r268425 : #i99568# SfxItemPropertySet rework 2009-02-25 11:49:17 +0100 os r268424 : #i99568# SfxItemPropertySet rework 2009-02-25 11:45:17 +0100 os r268423 : #i99568# SfxItemPropertySet rework 2009-02-11 11:39:04 +0100 os r267587 : #i57008# use registration of index marks at SwUnoCallback
300 lines
13 KiB
Java
300 lines
13 KiB
Java
package complex.storages;
|
|
|
|
import com.sun.star.uno.XInterface;
|
|
import com.sun.star.lang.XMultiServiceFactory;
|
|
import com.sun.star.lang.XSingleServiceFactory;
|
|
|
|
import com.sun.star.bridge.XUnoUrlResolver;
|
|
import com.sun.star.uno.UnoRuntime;
|
|
import com.sun.star.uno.XInterface;
|
|
import com.sun.star.io.XStream;
|
|
|
|
import com.sun.star.embed.*;
|
|
|
|
import share.LogWriter;
|
|
import complex.storages.TestHelper;
|
|
import complex.storages.StorageTest;
|
|
|
|
public class Test05 implements StorageTest {
|
|
|
|
XMultiServiceFactory m_xMSF;
|
|
XSingleServiceFactory m_xStorageFactory;
|
|
TestHelper m_aTestHelper;
|
|
|
|
public Test05( XMultiServiceFactory xMSF, XSingleServiceFactory xStorageFactory, LogWriter aLogWriter )
|
|
{
|
|
m_xMSF = xMSF;
|
|
m_xStorageFactory = xStorageFactory;
|
|
m_aTestHelper = new TestHelper( aLogWriter, "Test05: " );
|
|
}
|
|
|
|
public boolean test()
|
|
{
|
|
try
|
|
{
|
|
String sTempFileURL = m_aTestHelper.CreateTempFile( m_xMSF );
|
|
if ( sTempFileURL == null || sTempFileURL == "" )
|
|
{
|
|
m_aTestHelper.Error( "No valid temporary file was created!" );
|
|
return false;
|
|
}
|
|
|
|
// create temporary storage based on a previously created temporary file
|
|
Object pArgs[] = new Object[2];
|
|
pArgs[0] = (Object) sTempFileURL;
|
|
pArgs[1] = new Integer( ElementModes.WRITE );
|
|
|
|
Object oTempFileStorage = m_xStorageFactory.createInstanceWithArguments( pArgs );
|
|
XStorage xTempFileStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oTempFileStorage );
|
|
if ( xTempFileStorage == null )
|
|
{
|
|
m_aTestHelper.Error( "Can't create storage based on temporary file!" );
|
|
return false;
|
|
}
|
|
|
|
// open a new substorage
|
|
XStorage xTempSubStorage = m_aTestHelper.openSubStorage( xTempFileStorage,
|
|
"SubStorage1",
|
|
ElementModes.WRITE );
|
|
if ( xTempSubStorage == null )
|
|
{
|
|
m_aTestHelper.Error( "Can't create substorage!" );
|
|
return false;
|
|
}
|
|
|
|
// open a new substorage
|
|
XStorage xSubSubStorage = m_aTestHelper.openSubStorage( xTempSubStorage,
|
|
"SubSubStorage1",
|
|
ElementModes.WRITE );
|
|
if ( xSubSubStorage == null )
|
|
{
|
|
m_aTestHelper.Error( "Can't create substorage!" );
|
|
return false;
|
|
}
|
|
|
|
byte pBigBytes[] = new byte[33000];
|
|
for ( int nInd = 0; nInd < 33000; nInd++ )
|
|
pBigBytes[nInd] = (byte)( nInd % 128 );
|
|
|
|
// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
|
|
if ( !m_aTestHelper.WriteBytesToSubstream( xSubSubStorage, "BigSubStream1", "MediaType1", true, pBigBytes ) )
|
|
return false;
|
|
|
|
// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
|
|
if ( !m_aTestHelper.WriteBytesToSubstream( xSubSubStorage, "BigSubStream2", "MediaType2", false, pBigBytes ) )
|
|
return false;
|
|
|
|
byte pBytes1[] = { 1, 1, 1, 1, 1 };
|
|
|
|
// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
|
|
if ( !m_aTestHelper.WriteBytesToSubstream( xSubSubStorage, "SubStream1", "MediaType1", true, pBytes1 ) )
|
|
return false;
|
|
|
|
byte pBytes2[] = { 2, 2, 2, 2, 2 };
|
|
|
|
// open a new substream, set "MediaType" and "Compressed" properties to it and write some bytes
|
|
if ( !m_aTestHelper.WriteBytesToSubstream( xSubSubStorage, "SubStream2", "MediaType2", false, pBytes2 ) )
|
|
return false;
|
|
|
|
// set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly
|
|
if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempFileStorage,
|
|
"MediaType3",
|
|
true,
|
|
ElementModes.WRITE ) )
|
|
return false;
|
|
|
|
// set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly
|
|
if ( !m_aTestHelper.setStorageTypeAndCheckProps( xTempSubStorage,
|
|
"MediaType4",
|
|
false,
|
|
ElementModes.WRITE ) )
|
|
return false;
|
|
|
|
// set "MediaType" property for storages and check that "IsRoot" and "OpenMode" properties are set correctly
|
|
if ( !m_aTestHelper.setStorageTypeAndCheckProps( xSubSubStorage,
|
|
"MediaType5",
|
|
false,
|
|
ElementModes.WRITE ) )
|
|
return false;
|
|
|
|
|
|
// commit all the storages
|
|
if ( !m_aTestHelper.commitStorage( xSubSubStorage ) )
|
|
return false;
|
|
|
|
if ( !m_aTestHelper.commitStorage( xTempSubStorage ) )
|
|
return false;
|
|
|
|
if ( !m_aTestHelper.commitStorage( xTempFileStorage ) )
|
|
return false;
|
|
|
|
// try to open an opened substorage, open call must fail
|
|
if ( !m_aTestHelper.cantOpenStorage( xTempFileStorage, "SubStorage1" ) )
|
|
return false;
|
|
|
|
|
|
// reopen created streams
|
|
XStream xSubStream1 = m_aTestHelper.OpenStream( xSubSubStorage,
|
|
"SubStream1",
|
|
ElementModes.WRITE | ElementModes.NOCREATE );
|
|
XStream xBigSubStream1 = m_aTestHelper.OpenStream( xSubSubStorage,
|
|
"BigSubStream1",
|
|
ElementModes.WRITE | ElementModes.NOCREATE );
|
|
XStream xSubStream2 = m_aTestHelper.OpenStream( xSubSubStorage,
|
|
"SubStream2",
|
|
ElementModes.READ | ElementModes.NOCREATE );
|
|
XStream xBigSubStream2 = m_aTestHelper.OpenStream( xSubSubStorage,
|
|
"BigSubStream2",
|
|
ElementModes.READ | ElementModes.NOCREATE );
|
|
|
|
if ( xSubStream1 == null || xBigSubStream1 == null || xSubStream2 == null || xBigSubStream2 == null )
|
|
return false;
|
|
|
|
// it should be possible to have more then one copy of stream for reading
|
|
XStream xSubStream2clone = m_aTestHelper.OpenStream( xSubSubStorage,
|
|
"SubStream2",
|
|
ElementModes.READ | ElementModes.NOCREATE );
|
|
XStream xBigSubStream2clone = m_aTestHelper.OpenStream( xSubSubStorage,
|
|
"BigSubStream2",
|
|
ElementModes.READ | ElementModes.NOCREATE );
|
|
if ( xSubStream2clone == null || xBigSubStream2clone == null )
|
|
return false;
|
|
|
|
|
|
// so now the first streams can not be open neither for reading nor for writing
|
|
if ( !m_aTestHelper.cantOpenStream( xSubSubStorage, "SubStream1", ElementModes.WRITE )
|
|
|| !m_aTestHelper.cantOpenStream( xSubSubStorage, "SubStream1", ElementModes.READ )
|
|
|| !m_aTestHelper.cantOpenStream( xSubSubStorage, "BigSubStream1", ElementModes.WRITE )
|
|
|| !m_aTestHelper.cantOpenStream( xSubSubStorage, "BigSubStream1", ElementModes.READ ) )
|
|
return false;
|
|
|
|
// the second streams can not be open for writing
|
|
if ( !m_aTestHelper.cantOpenStream( xSubSubStorage, "SubStream2", ElementModes.WRITE )
|
|
|| !m_aTestHelper.cantOpenStream( xSubSubStorage, "BigSubStream2", ElementModes.WRITE ) )
|
|
return false;
|
|
|
|
|
|
// dispose xTestSubStorage, all the subtree must be disposed
|
|
if ( !m_aTestHelper.disposeStorage( xTempSubStorage ) )
|
|
return false;
|
|
|
|
// check that subtree was disposed correctly
|
|
try
|
|
{
|
|
xSubSubStorage.isStreamElement( "SubStream1" );
|
|
m_aTestHelper.Error( "Substorage was not disposed!" );
|
|
return false;
|
|
}
|
|
catch ( com.sun.star.lang.DisposedException de )
|
|
{}
|
|
catch ( Exception e )
|
|
{
|
|
m_aTestHelper.Error( "Wrong exception is thrown by disposed storage: " + e );
|
|
return false;
|
|
}
|
|
|
|
try
|
|
{
|
|
xSubStream1.getInputStream();
|
|
m_aTestHelper.Error( "Writeable substream was not disposed!" );
|
|
return false;
|
|
}
|
|
catch ( com.sun.star.lang.DisposedException de )
|
|
{}
|
|
catch ( Exception e )
|
|
{
|
|
m_aTestHelper.Error( "Wrong exception is thrown by disposed stream: " + e );
|
|
return false;
|
|
}
|
|
|
|
try
|
|
{
|
|
xSubStream2.getInputStream();
|
|
m_aTestHelper.Error( "Readonly substream was not disposed!" );
|
|
return false;
|
|
}
|
|
catch ( com.sun.star.lang.DisposedException de )
|
|
{}
|
|
catch ( Exception e )
|
|
{
|
|
m_aTestHelper.Error( "Wrong exception is thrown by disposed stream: " + e );
|
|
return false;
|
|
}
|
|
|
|
|
|
// dispose root storage
|
|
if ( !m_aTestHelper.disposeStorage( xTempFileStorage ) )
|
|
return false;
|
|
|
|
|
|
// ================================================
|
|
// now check all the written and copied information
|
|
// ================================================
|
|
|
|
pArgs[1] = new Integer( ElementModes.READ );
|
|
Object oResultStorage = m_xStorageFactory.createInstanceWithArguments( pArgs );
|
|
XStorage xResultStorage = (XStorage) UnoRuntime.queryInterface( XStorage.class, oResultStorage );
|
|
if ( xResultStorage == null )
|
|
{
|
|
m_aTestHelper.Error( "Can't reopen storage based on temporary file!" );
|
|
return false;
|
|
}
|
|
|
|
if ( !m_aTestHelper.checkStorageProperties( xResultStorage, "MediaType3", true, ElementModes.READ ) )
|
|
return false;
|
|
|
|
// open existing substorage
|
|
XStorage xResSubStorage = m_aTestHelper.openSubStorage( xResultStorage,
|
|
"SubStorage1",
|
|
ElementModes.READ );
|
|
if ( xResSubStorage == null )
|
|
{
|
|
m_aTestHelper.Error( "Can't open existing substorage 'SubSubStorage'!" );
|
|
return false;
|
|
}
|
|
|
|
if ( !m_aTestHelper.checkStorageProperties( xResSubStorage, "MediaType4", false, ElementModes.READ ) )
|
|
return false;
|
|
|
|
// open existing substorage
|
|
XStorage xResSubSubStorage = m_aTestHelper.openSubStorage( xResSubStorage,
|
|
"SubSubStorage1",
|
|
ElementModes.READ );
|
|
if ( xResSubSubStorage == null )
|
|
{
|
|
m_aTestHelper.Error( "Can't open existing substorage 'SubSubStorage'!" );
|
|
return false;
|
|
}
|
|
|
|
if ( !m_aTestHelper.checkStorageProperties( xResSubSubStorage, "MediaType5", false, ElementModes.READ ) )
|
|
return false;
|
|
|
|
// check substreams
|
|
if ( !m_aTestHelper.checkStream( xResSubSubStorage, "SubStream1", "MediaType1", true, pBytes1 ) )
|
|
return false;
|
|
|
|
if ( !m_aTestHelper.checkStream( xResSubSubStorage, "BigSubStream1", "MediaType1", true, pBigBytes ) )
|
|
return false;
|
|
|
|
if ( !m_aTestHelper.checkStream( xResSubSubStorage, "SubStream2", "MediaType2", false, pBytes2 ) )
|
|
return false;
|
|
|
|
if ( !m_aTestHelper.checkStream( xResSubSubStorage, "BigSubStream2", "MediaType2", false, pBigBytes ) )
|
|
return false;
|
|
|
|
// dispose used storages to free resources
|
|
if ( !m_aTestHelper.disposeStorage( xResultStorage ) )
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
catch( Exception e )
|
|
{
|
|
m_aTestHelper.Error( "Exception: " + e );
|
|
return false;
|
|
}
|
|
}
|
|
|
|
}
|
|
|