:m_pCleanup(value)
{}
~CleanupHelper()
- {
+ {
m_pCleanup->DeleteInStream();
m_pCleanup->DeleteOutStream();
}
// Prevent mem leaks!
delete m_pCurrentIn;
delete m_pCurrentOut;
- }
+ }
protected:
/*
// Note: the input stream should at least be of min size +10!
- char buf[10];
+ char buf[10];
(void)stream_in.Read(buf, 10);
CPPUNIT_ASSERT(!stream_in.Eof());
CPPUNIT_ASSERT(stream_in.Eof());
}
- // Test and see what happens to the EOF when we
+ // Test and see what happens to the EOF when we
// read after EOF was encountered.
void Input_Eof()
{
}
// Check EOF stream state.
- CPPUNIT_ASSERT_MESSAGE("EOF is not EOF?", stream_in.Eof());
+ CPPUNIT_ASSERT_MESSAGE("EOF is not EOF?", stream_in.Eof());
// Ok we found the end, lets see if we can go past it.
for (size_t i = 0; i < 100; i++)
CPPUNIT_ASSERT(stream_in.LastRead() == 1);
}
+ void Input_CanRead()
+ {
+ CleanupHelper cleanup(this);
+ TStreamIn &stream_in = CreateInStream();
+
+ CPPUNIT_ASSERT( stream_in.CanRead() );
+
+ // read the entire contents
+ (void)stream_in.Read(CreateOutStream());
+
+ CPPUNIT_ASSERT( !stream_in.CanRead() );
+ }
+
// Just try to perform a SeekI() on the input stream.
void Input_SeekI()
{
CPPUNIT_ASSERT(stream_in.TellI() == pos);
}
}
-
+
// Just try to perform a Peek() on the input stream.
void Input_Peek()
{
CleanupHelper cleanup(this);
TStreamIn &stream_in = CreateInStream();
CPPUNIT_ASSERT(!stream_in.Eof());
-
+
const char *ungetstr = "test";
size_t ungetsize = stream_in.Ungetch(ungetstr, strlen(ungetstr) + 1);
if (ungetsize != 0)
{
CleanupHelper cleanup(this);
TStreamOut &stream_out = CreateOutStream();
-
+
// First put some data in the stream, so it is not empty.
char *buf = "1234567890";
(void)stream_out.Write(buf, 10);
// First put some extra data in the stream, so it's not empty.
char *buf = "1234567890";
(void)stream_out.Write(buf, 10);
-
+
off_t pos = stream_out.SeekO(5, wxFromStart);
CPPUNIT_ASSERT(stream_out.TellO() == pos);
(void)stream_out.PutC('1');
protected:
// Some tests can be configured... here you can find the config settings
- bool m_bSimpleTellITest; // if true, no SeekI will be used by the TellI test.
+ bool m_bSimpleTellITest; // if true, no SeekI will be used by the TellI test.
// Default false.
- bool m_bSimpleTellOTest; // if true, no SeekO will be used by the TellI test.
+ bool m_bSimpleTellOTest; // if true, no SeekO will be used by the TellI test.
// Default false.
bool m_bSeekInvalidBeyondEnd; // if true a SeekI|O beyond the end of the stream should return wxInvalidOffset
// Default true.
// Default true.
protected:
TStreamIn &CreateInStream()
- {
+ {
if (m_pCurrentIn)
{
wxFAIL_MSG(_T("Error in test case, the previouse input stream needs to be delete first!"));
return *m_pCurrentIn;
}
TStreamOut &CreateOutStream()
- {
+ {
if (m_pCurrentOut)
{
wxFAIL_MSG(_T("Error in test case, the previouse output stream needs to be delete first!"));
wxASSERT(m_pCurrentOut != NULL);
return *m_pCurrentOut;
}
-
+
void DeleteInStream()
{
if (m_pCurrentIn == NULL)
{
if (m_pCurrentOut == NULL)
return;
+
+ CPPUNIT_ASSERT(m_pCurrentOut->Close());
+
delete m_pCurrentOut;
m_pCurrentOut = NULL;
// Incase something extra needs to be done.