summaryrefslogtreecommitdiff
path: root/unotools/qa
diff options
context:
space:
mode:
authorOliver Bolte <obo@openoffice.org>2008-01-04 15:26:35 +0000
committerOliver Bolte <obo@openoffice.org>2008-01-04 15:26:35 +0000
commit33676699257805aeb381dace9fb4fdd107125fcb (patch)
tree3b27f685181ff88ba361a0ba396e912cbfe0c8a8 /unotools/qa
parent5ac0c87a529fcfd3217dbff398e74e38a3be8275 (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.java94
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;
+ }
+}