aboutsummaryrefslogtreecommitdiff
path: root/test/common/bufferedreadstream.h
diff options
context:
space:
mode:
authorMax Horn2008-07-29 17:42:19 +0000
committerMax Horn2008-07-29 17:42:19 +0000
commitaaa4d104f7eb4094ec6bd69ef2d44f80edd61aa4 (patch)
treef515c39e140b5ddd37f46060578d3b41759a15e3 /test/common/bufferedreadstream.h
parent0a95a4814cbc9453f3af7abb46d6998409d96f53 (diff)
downloadscummvm-rg350-aaa4d104f7eb4094ec6bd69ef2d44f80edd61aa4.tar.gz
scummvm-rg350-aaa4d104f7eb4094ec6bd69ef2d44f80edd61aa4.tar.bz2
scummvm-rg350-aaa4d104f7eb4094ec6bd69ef2d44f80edd61aa4.zip
Added two new classes, BufferedReadStream & BufferedSeekableReadStream, as proposed on scummvm-devel
svn-id: r33419
Diffstat (limited to 'test/common/bufferedreadstream.h')
-rw-r--r--test/common/bufferedreadstream.h27
1 files changed, 27 insertions, 0 deletions
diff --git a/test/common/bufferedreadstream.h b/test/common/bufferedreadstream.h
new file mode 100644
index 0000000000..7733949d9a
--- /dev/null
+++ b/test/common/bufferedreadstream.h
@@ -0,0 +1,27 @@
+#include <cxxtest/TestSuite.h>
+
+#include "common/stream.h"
+
+class BufferedReadStreamTestSuite : public CxxTest::TestSuite {
+ public:
+ void test_traverse(void) {
+ byte contents[10] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
+ Common::MemoryReadStream ms(contents, 10);
+
+ // Use a buffer size of 4 -- note that 10 % 4 != 0,
+ // so we test what happens if the cache can't be completly
+ // refilled.
+ Common::BufferedReadStream srs(&ms, 4);
+
+ int i;
+ byte b;
+ for (i = 0; i < 10; ++i) {
+ TS_ASSERT( !srs.eos() );
+
+ b = srs.readByte();
+ TS_ASSERT_EQUALS( i, b );
+ }
+
+ TS_ASSERT( srs.eos() );
+ }
+};