diff options
author | Oliver Bolte <obo@openoffice.org> | 2008-01-04 15:26:35 +0000 |
---|---|---|
committer | Oliver Bolte <obo@openoffice.org> | 2008-01-04 15:26:35 +0000 |
commit | 33676699257805aeb381dace9fb4fdd107125fcb (patch) | |
tree | 3b27f685181ff88ba361a0ba396e912cbfe0c8a8 /unotools/qa | |
parent | 5ac0c87a529fcfd3217dbff398e74e38a3be8275 (diff) |
INTEGRATION: CWS fwk77 (1.1.2); FILE ADDED
2007/10/18 11:40:35 mav 1.1.2.1: #i47532# TempFile service
Diffstat (limited to 'unotools/qa')
-rw-r--r-- | unotools/qa/complex/tempfile/Test01.java | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/unotools/qa/complex/tempfile/Test01.java b/unotools/qa/complex/tempfile/Test01.java new file mode 100644 index 000000000000..146d99043a25 --- /dev/null +++ b/unotools/qa/complex/tempfile/Test01.java @@ -0,0 +1,94 @@ +package complex.tempfile; + +import complexlib.ComplexTestCase; + +import com.sun.star.lang.XMultiServiceFactory; +import com.sun.star.ucb.XSimpleFileAccess; +import com.sun.star.io.*; +import com.sun.star.uno.UnoRuntime; +import java.util.Random; + +import share.LogWriter; + +public class Test01 implements TempFileTest { + LogWriter m_aLogWriter; + XMultiServiceFactory m_xMSF = null; + XSimpleFileAccess m_xSFA = null; + TestHelper m_aTestHelper = null; + + public Test01(XMultiServiceFactory xMSF, XSimpleFileAccess xSFA, LogWriter aLogWriter) { + m_xMSF = xMSF; + m_xSFA = xSFA; + m_aTestHelper = new TestHelper(aLogWriter, "Test01: "); + } + + public boolean test() { + XTempFile xTempFile = null; + XTruncate xTruncate = null; + String sFileURL = null; + String sFileName = null; + //create a temporary file. + try { + Object oTempFile = m_xMSF.createInstance( "com.sun.star.io.TempFile" ); + xTempFile = (XTempFile) UnoRuntime.queryInterface( XTempFile.class, + oTempFile ); + m_aTestHelper.Message( "Tempfile created." ); + xTruncate = (XTruncate)UnoRuntime.queryInterface( XTruncate.class, + oTempFile ); + } catch( Exception e ) { + m_aTestHelper.Error( "Cannot create TempFile. exception: " + e ); + return false; + } + + //retrieve the tempfile URL + if ( xTempFile == null ) { + m_aTestHelper.Error( "Cannot get XTempFile interface." ); + return false; + } + + try { + //compare the file name with the name in the URL. + sFileURL = m_aTestHelper.GetTempFileURL( xTempFile ); + sFileName = m_aTestHelper.GetTempFileName( xTempFile ); + m_aTestHelper.CompareFileNameAndURL( sFileName, sFileURL ); + + //write to the stream using the service. + byte pBytesIn[] = new byte[9]; + byte pBytesOut1[][] = new byte [1][9]; + byte pBytesOut2[][] = new byte [1][9]; + Random oRandom = new Random(); + oRandom.nextBytes( pBytesIn ); + m_aTestHelper.WriteBytesWithStream( pBytesIn, xTempFile ); + + //check the result by reading from the service. + xTempFile.seek(0); + m_aTestHelper.ReadBytesWithStream( pBytesOut1, pBytesIn.length + 1, xTempFile ); + for ( int i = 0; i < pBytesIn.length ; i++ ) { + if ( pBytesOut1[0][i] != pBytesIn[i] ) { + m_aTestHelper.Error( "Tempfile outputs false data!" ); + } + } + + //check the result by reading from the file directly. + m_aTestHelper.ReadDirectlyFromTempFile( pBytesOut2, pBytesIn.length + 1, m_xSFA, sFileURL ); + for ( int i = 0; i < pBytesIn.length; i++ ) { + if ( pBytesOut2[0][i] != pBytesIn[i] ) { + m_aTestHelper.Error( "Tempfile contains false data!" ); + } + } + + //close the object(by closing input and output), check that the file was removed. + xTempFile.setRemoveFile( false ); + m_aTestHelper.CloseTempFile( xTempFile ); + if( !m_aTestHelper.IfTempFileExists( m_xSFA, sFileURL ) ) { + m_aTestHelper.Error( "TempFile mistakenly removed. " ); + } else { + m_aTestHelper.KillTempFile( sFileURL, m_xSFA ); + } + } catch ( Exception e ) { + m_aTestHelper.Error( "Exception: " + e ); + return false; + } + return true; + } +} |