diff options
author | Oliver Bolte <obo@openoffice.org> | 2008-01-04 15:27:11 +0000 |
---|---|---|
committer | Oliver Bolte <obo@openoffice.org> | 2008-01-04 15:27:11 +0000 |
commit | 882a0258be933f8db8d04409590af206fe921264 (patch) | |
tree | 508b81b87a3c0754f2e8fa5204624e1a45a224f5 /unotools/qa | |
parent | 25d5773f8ca0e9f62268f0970e62e0cd08631ac2 (diff) |
INTEGRATION: CWS fwk77 (1.1.2); FILE ADDED
2007/10/18 11:40:54 mav 1.1.2.1: #i47532# TempFile service
Diffstat (limited to 'unotools/qa')
-rw-r--r-- | unotools/qa/complex/tempfile/TestHelper.java | 199 |
1 files changed, 199 insertions, 0 deletions
diff --git a/unotools/qa/complex/tempfile/TestHelper.java b/unotools/qa/complex/tempfile/TestHelper.java new file mode 100644 index 000000000000..ae3ce81134dd --- /dev/null +++ b/unotools/qa/complex/tempfile/TestHelper.java @@ -0,0 +1,199 @@ +package complex.tempfile; + +import complexlib.ComplexTestCase; +import com.sun.star.lang.XMultiServiceFactory; + +import com.sun.star.io.*; + +import com.sun.star.uno.AnyConverter; +import com.sun.star.ucb.XSimpleFileAccess; +import com.sun.star.uno.UnoRuntime; +import share.LogWriter; + +public class TestHelper { + LogWriter m_aLogWriter; + String m_sTestPrefix; + + public TestHelper( LogWriter aLogWriter, String sTestPrefix ) { + m_aLogWriter = aLogWriter; + m_sTestPrefix = sTestPrefix; + } + public void SetTempFileRemove( XTempFile xTempFile, boolean b ) { + try { + xTempFile.setRemoveFile( b ); + } catch( Exception e ) { + Error( "Cannot set TempFileRemove. exception: " + e ); + } + } + + public boolean GetTempFileRemove ( XTempFile xTempFile ) { + boolean b = false; + try { + b = xTempFile.getRemoveFile(); + } catch( Exception e) { + Error( "Cannot get TempFileRemove. exception: " + e ); + } + return b; + } + + public String GetTempFileURL ( XTempFile xTempFile ) { + String sTempFileURL = null; + try { + sTempFileURL = AnyConverter.toString( xTempFile.getUri() ); + } catch (Exception e) { + Error ( "Cannot get TempFileURL. exception: " + e ); + } + if ( sTempFileURL == null || sTempFileURL == "" ) { + Error ( "Temporary file not valid." ); + } + return sTempFileURL; + } + + public String GetTempFileName( XTempFile xTempFile ) { + String sTempFileName = null; + try { + sTempFileName = AnyConverter.toString( xTempFile.getResourceName() ); + } catch ( Exception e ) { + Error( "Cannot get TempFileName. exception: " + e ); + } + if ( sTempFileName == null || sTempFileName == "") { + Error( "Temporary file not valid." ); + } + return sTempFileName; + } + + public boolean CompareFileNameAndURL ( String sTempFileName, String sTempFileURL ) { + boolean bRet = false; + try { + bRet = sTempFileURL.endsWith( sTempFileName.replaceAll( "\\\\" , "/" ) ); + Message ( "Compare file name and URL: " + + ( bRet ? "OK." : "ERROR: FILE NAME AND URL DO NOT MATCH." ) ); + } + catch ( Exception e ) { + Error ( "exception: " + e); + } + return bRet; + } + + public void WriteBytesWithStream( byte [] pBytes, XTempFile xTempFile ) { + try { + XOutputStream xOutTemp = xTempFile.getOutputStream(); + if ( xOutTemp == null ) { + Error( "Cannot get output stream." ); + } else { + xOutTemp.writeBytes( pBytes ); + Message ( "Write to tempfile successfully." ); + } + } catch ( Exception e ) { + Error( "Cannot write to stream. exception: " + e ); + } + } + + public void ReadBytesWithStream( byte [][] pBytes, int nBytes, XTempFile xTempFile ) { + try { + XInputStream xInTemp = xTempFile.getInputStream(); + if ( xInTemp == null ) { + Error( "Cannot get input stream from tempfile." ); + } else { + xInTemp.readBytes( pBytes, nBytes ); + Message ( "Read from tempfile successfully." ); + } + } catch ( Exception e ) { + Error( "Cannot read from stream. exception: " + e ); + } + } + public void ReadDirectlyFromTempFile( byte [][] pBytes, int nBytes, XSimpleFileAccess xSFA, String sTempFileURL ) + { + try + { + if ( xSFA != null ) { + XInputStream xInTemp = xSFA.openFileRead( sTempFileURL ); + if ( xInTemp != null ) + { + xInTemp.readBytes( pBytes, nBytes ); + xInTemp.closeInput(); + Message ( "Read directly from tempfile successfully." ); + } else { + Error ( "Cannot creat input stream from URL." ); + } + } + } + catch ( Exception e) + { + Error( "Exception caught in TestHelper." + + "ReadDirectlyFromTempFile(). exception: " + e ); + } + } + + public void CloseTempFile( XTempFile xTempFile ) { + XOutputStream xOutTemp = null; + XInputStream xInTemp = null; + try { + xOutTemp = xTempFile.getOutputStream(); + if ( xOutTemp == null ) { + Error( "Cannot get output stream." ); + } + } catch ( Exception e ) { + Error( "Cannot get output stream. exception:" + e ); + } + try { + xOutTemp.closeOutput(); + } catch( Exception e ) { + Error( "Cannot close output stream. exception:" + e ); + } + try { + xInTemp = xTempFile.getInputStream(); + if ( xInTemp == null ) { + Error( "Cannot get input stream." ); + } + } catch ( Exception e ) { + Error( "Cannot get input stream. exception:" + e ); + } + try { + xInTemp.closeInput(); + Message ( "Tempfile closed successfully." ); + } catch( Exception e ) { + Error( "Cannot close input stream. exception:" + e ); + } + } + + public void KillTempFile ( String sTempFileURL, XSimpleFileAccess xSFA ) { + try { + if ( sTempFileURL != null ) { + if ( xSFA != null ) { + xSFA.kill( sTempFileURL ); + Message ( "Tempfile killed successfully." ); + } + } + } + catch ( Exception e ) { + Error ( "Exception caught in TestHelper." + + "KillTempFile(): " + e); + } + } + + public boolean IfTempFileExists( XSimpleFileAccess xSFA, String sTempFileURL ) { + boolean bRet = false; + try { + if ( sTempFileURL != null ) { + if ( xSFA != null ) { + bRet = xSFA.exists( sTempFileURL ); + Message ( "Tempfile " + ( bRet ? "still " : "no longer " ) + "exists." ); + } + } + } + catch( Exception e ) { + Error( "Exception caught in TestHelper." + + "IfTempFileExists(): " + e ); + } + return bRet; + } + + public void Error( String sError ) { + m_aLogWriter.println( m_sTestPrefix + "Error: " + sError ); + } + + public void Message( String sMessage ) { + m_aLogWriter.println( m_sTestPrefix + sMessage ); + } +} |