# HG changeset patch # User Mike Becker # Date 1652721919 -7200 # Node ID 459bca1cdf8df4f049a22f552153f3779576dac9 # Parent 9e933920dcf98ec6f473703c72dcdc1e27507382 #170 test buffer eof diff -r 9e933920dcf9 -r 459bca1cdf8d test/test_buffer.cpp --- a/test/test_buffer.cpp Mon May 16 19:15:44 2022 +0200 +++ b/test/test_buffer.cpp Mon May 16 19:25:19 2022 +0200 @@ -31,6 +31,21 @@ #include #include "util_allocator.h" +class BufferFixture : public ::testing::Test { +protected: + void SetUp() override { + cxBufferInit(&buf, nullptr, 16, cxDefaultAllocator, CX_BUFFER_DEFAULT); + buf.size = 6; + buf.pos = 3; + } + + void TearDown() override { + cxBufferDestroy(&buf); + } + + CxBuffer buf{}; +}; + static void expect_default_flush_config(CxBuffer *buf) { EXPECT_EQ(buf->flush_blkmax, 0); EXPECT_EQ(buf->flush_blksize, 4096); @@ -580,19 +595,7 @@ EXPECT_EQ(memcmp(target.space, "prepfoobarhello", 15), 0); } -class BufferSeek : public ::testing::Test { -protected: - void SetUp() override { - cxBufferInit(&buf, nullptr, 16, cxDefaultAllocator, CX_BUFFER_DEFAULT); - buf.size = 6; - buf.pos = 3; - } - - void TearDown() override { - cxBufferDestroy(&buf); - } - - CxBuffer buf{}; +class BufferSeek : public BufferFixture { }; TEST_F(BufferSeek, SetZero) { @@ -678,4 +681,24 @@ EXPECT_NE(result, 0); EXPECT_EQ(buf.size, 6); EXPECT_EQ(buf.pos, 3); -} \ No newline at end of file +} + +class BufferEof : public BufferFixture { +}; + +TEST_F(BufferEof, Reached) { + buf.pos = buf.size; + EXPECT_TRUE(cxBufferEof(&buf)); + buf.pos = buf.size - 1; + ASSERT_FALSE(cxBufferEof(&buf)); + cxBufferPut(&buf, 'a'); + EXPECT_TRUE(cxBufferEof(&buf)); +} + +TEST_F(BufferEof, NotReached) { + buf.pos = buf.size - 1; + EXPECT_FALSE(cxBufferEof(&buf)); + buf.pos = 0; + cxBufferWrite("test", 1, 5, &buf); + EXPECT_FALSE(cxBufferEof(&buf)); +}