From a750e6f4f5b45cb63d0ddf04477b53ab6035d878 Mon Sep 17 00:00:00 2001 From: Max Horn Date: Mon, 13 Nov 2006 22:06:27 +0000 Subject: Patch #1583931: (Seekable)SubReadStream (the unit tests were missing, as I accidentally commited from the wrong directory) svn-id: r24715 --- test/common/seekablesubreadstream.h | 72 +++++++++++++++++++++++++++++++++++++ test/common/subreadstream.h | 30 ++++++++++++++++ 2 files changed, 102 insertions(+) create mode 100644 test/common/seekablesubreadstream.h create mode 100644 test/common/subreadstream.h (limited to 'test/common') diff --git a/test/common/seekablesubreadstream.h b/test/common/seekablesubreadstream.h new file mode 100644 index 0000000000..96de086949 --- /dev/null +++ b/test/common/seekablesubreadstream.h @@ -0,0 +1,72 @@ +#include + +#include "common/stdafx.h" +#include "common/stream.h" + +class SeekableSubReadStreamTestSuite : public CxxTest::TestSuite +{ + public: + void test_traverse( void ) + { + byte contents[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; + Common::MemoryReadStream ms = Common::MemoryReadStream(contents, 10); + + int start = 2, end = 8; + + Common::SeekableSubReadStream ssrs = Common::SeekableSubReadStream(&ms, start, end); + + int i; + byte b; + for (i = start; i < end; ++i) + { + TS_ASSERT( !ssrs.eos() ); + + TS_ASSERT_EQUALS( i - start, ssrs.pos() ); + + ssrs.read(&b, 1); + TS_ASSERT_EQUALS( i, b ); + } + + TS_ASSERT( ssrs.eos() ); + } + + void test_seek( void ) + { + byte contents[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; + Common::MemoryReadStream ms = Common::MemoryReadStream(contents, 10); + + Common::SeekableSubReadStream ssrs = Common::SeekableSubReadStream(&ms, 1, 9); + byte b; + + TS_ASSERT_EQUALS( ssrs.pos(), 0 ); + + ssrs.seek(1, SEEK_SET); + TS_ASSERT_EQUALS( ssrs.pos(), 1 ); + b = ssrs.readByte(); + TS_ASSERT_EQUALS( b, 2 ); + + ssrs.seek(5, SEEK_CUR); + TS_ASSERT_EQUALS( ssrs.pos(), 7 ); + b = ssrs.readByte(); + TS_ASSERT_EQUALS( b, 8 ); + + ssrs.seek(-3, SEEK_CUR); + TS_ASSERT_EQUALS( ssrs.pos(), 5 ); + b = ssrs.readByte(); + TS_ASSERT_EQUALS( b, 6 ); + + ssrs.seek(0, SEEK_END); + TS_ASSERT_EQUALS( ssrs.pos(), 8 ); + TS_ASSERT( ssrs.eos() ); + + ssrs.seek(3, SEEK_END); + TS_ASSERT_EQUALS( ssrs.pos(), 5 ); + b = ssrs.readByte(); + TS_ASSERT_EQUALS( b, 6 ); + + ssrs.seek(8, SEEK_END); + TS_ASSERT_EQUALS( ssrs.pos(), 0 ); + b = ssrs.readByte(); + TS_ASSERT_EQUALS( b, 1 ); + } +}; diff --git a/test/common/subreadstream.h b/test/common/subreadstream.h new file mode 100644 index 0000000000..eb50436665 --- /dev/null +++ b/test/common/subreadstream.h @@ -0,0 +1,30 @@ +#include + +#include "common/stdafx.h" +#include "common/stream.h" + +class SubReadStreamTestSuite : public CxxTest::TestSuite +{ + public: + void test_traverse( void ) + { + byte contents[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; + Common::MemoryReadStream ms = Common::MemoryReadStream(contents, 10); + + int end = 5; + + Common::SubReadStream srs = Common::SubReadStream(&ms, end); + + int i; + byte b; + for (i = 0; i < end; ++i) + { + TS_ASSERT( !srs.eos() ); + + srs.read(&b, 1); + TS_ASSERT_EQUALS( i, b ); + } + + TS_ASSERT( srs.eos() ); + } +}; -- cgit v1.2.3