#include "stdafx.h" #include "gtest/gtest.h" #include "gmock/gmock.h" #include "../TOverlappedReaderWriter.h" #include "../TOverlappedDataBuffer.h" #include "../TCoreException.h" #include "../../liblogger/TLogFileData.h" using namespace chcore; #define EXPECT_TIMEOUT(handle)\ {\ DWORD dwResult = WaitForSingleObject(handle, 0); \ EXPECT_EQ(WAIT_TIMEOUT, dwResult); \ } #define EXPECT_SIGNALED(handle)\ {\ DWORD dwResult = WaitForSingleObject(handle, 0); \ EXPECT_EQ(WAIT_OBJECT_0 + 0, dwResult); \ } TEST(TOverlappedReaderWriterTests, DefaultConstructor_SanityTest) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared()); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_EQ(nullptr, tReaderWriter.GetEmptyBuffer()); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedReadBuffer()); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedWriteBuffer()); EXPECT_NE(nullptr, tReaderWriter.GetEventReadPossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEventWritePossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEventWriteFinishedHandle()); EXPECT_TIMEOUT(tReaderWriter.GetEventReadPossibleHandle()); EXPECT_TIMEOUT(tReaderWriter.GetEventWritePossibleHandle()); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); EXPECT_FALSE(tReaderWriter.IsDataSourceFinished()); // EXPECT_FALSE(tReaderWriter.IsDataWritingFinished()); EXPECT_EQ(0, spBuffers->GetTotalBufferCount()); EXPECT_EQ(0, spBuffers->GetSingleBufferSize()); } TEST(TOverlappedReaderWriterTests, AllocatingConstructor_SanityTest) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_NE(nullptr, tReaderWriter.GetEmptyBuffer()); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedReadBuffer()); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedWriteBuffer()); EXPECT_NE(nullptr, tReaderWriter.GetEventReadPossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEventWritePossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEventWriteFinishedHandle()); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); EXPECT_TIMEOUT(tReaderWriter.GetEventWritePossibleHandle()); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); EXPECT_FALSE(tReaderWriter.IsDataSourceFinished()); // EXPECT_FALSE(tReaderWriter.IsDataWritingFinished()); } TEST(TOverlappedReaderWriterTests, AllocatingConstructor_CheckBufferSizes) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_EQ(3, spBuffers->GetTotalBufferCount()); EXPECT_EQ(32768, spBuffers->GetSingleBufferSize()); EXPECT_EQ(32768, pBuffers[0]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[1]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[2]->GetBufferSize()); } /////////////////////////////////////////////////////////////////////////////////////////////////// TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_FailsWithBuffersInUse) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); tReaderWriter.GetEmptyBuffer(); EXPECT_THROW(spBuffers->ReinitializeBuffers(3, 65536), TCoreException); } TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_ZeroLengthBuffers) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_THROW(spBuffers->ReinitializeBuffers(3, 0), TCoreException); } TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_SameSizeSameCount) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); spBuffers->ReinitializeBuffers(3, 32768); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_EQ(3, spBuffers->GetTotalBufferCount()); EXPECT_EQ(32768, spBuffers->GetSingleBufferSize()); EXPECT_EQ(32768, pBuffers[0]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[1]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[2]->GetBufferSize()); } TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_IncreaseSize) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); spBuffers->ReinitializeBuffers(3, 65536); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_EQ(3, spBuffers->GetTotalBufferCount()); EXPECT_EQ(65536, spBuffers->GetSingleBufferSize()); EXPECT_EQ(65536, pBuffers[0]->GetBufferSize()); EXPECT_EQ(65536, pBuffers[1]->GetBufferSize()); EXPECT_EQ(65536, pBuffers[2]->GetBufferSize()); } TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_DecreaseSize) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 65536)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); spBuffers->ReinitializeBuffers(3, 32768); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_EQ(3, spBuffers->GetTotalBufferCount()); EXPECT_EQ(32768, spBuffers->GetSingleBufferSize()); EXPECT_EQ(32768, pBuffers[0]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[1]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[2]->GetBufferSize()); } TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_IncreaseCount) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); spBuffers->ReinitializeBuffers(5, 32768); EXPECT_EQ(5, spBuffers->GetTotalBufferCount()); EXPECT_EQ(32768, spBuffers->GetSingleBufferSize()); TOverlappedDataBuffer* pBuffers[5] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_EQ(32768, pBuffers[0]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[1]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[2]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[3]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[4]->GetBufferSize()); } TEST(TOverlappedReaderWriterTests, ReinitializeBuffer_DecreaseCount) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(5, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); spBuffers->ReinitializeBuffers(3, 32768); EXPECT_EQ(3, spBuffers->GetTotalBufferCount()); EXPECT_EQ(32768, spBuffers->GetSingleBufferSize()); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_EQ(32768, pBuffers[0]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[1]->GetBufferSize()); EXPECT_EQ(32768, pBuffers[2]->GetBufferSize()); } /////////////////////////////////////////////////////////////////////////////////////////////////// TEST(TOverlappedReaderWriterTests, GetEmptyBuffer) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEmptyBuffer()); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEmptyBuffer()); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); EXPECT_NE(nullptr, tReaderWriter.GetEmptyBuffer()); EXPECT_TIMEOUT(tReaderWriter.GetEventReadPossibleHandle()); EXPECT_EQ(nullptr, tReaderWriter.GetEmptyBuffer()); } TEST(TOverlappedReaderWriterTests, AddEmptyBuffer) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; EXPECT_TIMEOUT(tReaderWriter.GetEventReadPossibleHandle()); tReaderWriter.AddEmptyBuffer(pBuffers[0], false); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); tReaderWriter.AddEmptyBuffer(pBuffers[1], false); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); tReaderWriter.AddEmptyBuffer(pBuffers[2], false); EXPECT_SIGNALED(tReaderWriter.GetEventReadPossibleHandle()); } TEST(TOverlappedReaderWriterTests, AddEmptyBuffer_Null) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_THROW(tReaderWriter.AddEmptyBuffer(nullptr, false), TCoreException); } /////////////////////////////////////////////////////////////////////////////////////////////////// TEST(TOverlappedReaderWriterTests, AddFullBuffer_GetFullBuffer) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffer = tReaderWriter.GetEmptyBuffer(); tReaderWriter.AddFinishedReadBuffer(pBuffer); EXPECT_SIGNALED(tReaderWriter.GetEventWritePossibleHandle()); tReaderWriter.GetFinishedReadBuffer(); EXPECT_TIMEOUT(tReaderWriter.GetEventWritePossibleHandle()); } TEST(TOverlappedReaderWriterTests, GetFullBuffer_WrongOrder) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; tReaderWriter.AddFinishedReadBuffer(pBuffers[1]); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedReadBuffer()); tReaderWriter.AddFinishedReadBuffer(pBuffers[2]); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedReadBuffer()); tReaderWriter.AddFinishedReadBuffer(pBuffers[0]); EXPECT_NE(nullptr, tReaderWriter.GetFinishedReadBuffer()); } TEST(TOverlappedReaderWriterTests, AddFullBuffer_HandlingSrcEof) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; pBuffers[1]->SetLastPart(true); tReaderWriter.AddFinishedReadBuffer(pBuffers[0]); EXPECT_FALSE(tReaderWriter.IsDataSourceFinished()); tReaderWriter.AddFinishedReadBuffer(pBuffers[1]); EXPECT_TRUE(tReaderWriter.IsDataSourceFinished()); } TEST(TOverlappedReaderWriterTests, AddFullBuffer_HandlingDstEof) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; pBuffers[2]->SetLastPart(true); tReaderWriter.AddFinishedReadBuffer(pBuffers[0]); tReaderWriter.AddFinishedReadBuffer(pBuffers[1]); tReaderWriter.AddFinishedReadBuffer(pBuffers[2]); tReaderWriter.GetFinishedReadBuffer(); // EXPECT_FALSE(tReaderWriter.IsDataWritingFinished()); tReaderWriter.GetFinishedReadBuffer(); // EXPECT_FALSE(tReaderWriter.IsDataWritingFinished()); // getting the last buffer (marked as eof) causes setting the data-writing-finished flag tReaderWriter.GetFinishedReadBuffer(); // EXPECT_TRUE(tReaderWriter.IsDataWritingFinished()); } TEST(TOverlappedReaderWriterTests, AddFullBuffer_Null) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_THROW(tReaderWriter.AddFinishedReadBuffer(nullptr), TCoreException); } TEST(TOverlappedReaderWriterTests, AddFullBuffer_SameBufferTwice) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffer = tReaderWriter.GetEmptyBuffer(); pBuffer->InitForRead(0, 1280); pBuffer->SetBytesTransferred(1230); pBuffer->SetStatusCode(0); tReaderWriter.AddFinishedReadBuffer(pBuffer); EXPECT_THROW(tReaderWriter.AddFinishedReadBuffer(pBuffer), TCoreException); } TEST(TOverlappedReaderWriterTests, GetFullBuffer_AddFullBuffer_OutOfOrder) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; pBuffers[0]->InitForRead(0, 1000); pBuffers[0]->SetBytesTransferred(1000); pBuffers[0]->SetStatusCode(0); pBuffers[1]->InitForRead(1000, 1200); pBuffers[1]->SetBytesTransferred(1200); pBuffers[1]->SetStatusCode(0); pBuffers[2]->InitForRead(2200, 1400); pBuffers[2]->SetBytesTransferred(800); pBuffers[2]->SetStatusCode(0); pBuffers[2]->SetLastPart(true); EXPECT_TIMEOUT(tReaderWriter.GetEventWritePossibleHandle()); tReaderWriter.AddFinishedReadBuffer(pBuffers[1]); EXPECT_TIMEOUT(tReaderWriter.GetEventWritePossibleHandle()); tReaderWriter.AddFinishedReadBuffer(pBuffers[2]); EXPECT_TIMEOUT(tReaderWriter.GetEventWritePossibleHandle()); tReaderWriter.AddFinishedReadBuffer(pBuffers[0]); EXPECT_SIGNALED(tReaderWriter.GetEventWritePossibleHandle()); } /////////////////////////////////////////////////////////////////////////////////////////////////// TEST(TOverlappedReaderWriterTests, AddFinishedBuffer_OutOfOrder_Signals) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; pBuffers[0]->InitForRead(0, 1000); pBuffers[0]->SetBytesTransferred(1000); pBuffers[0]->SetStatusCode(0); pBuffers[1]->InitForRead(1000, 1200); pBuffers[1]->SetBytesTransferred(1200); pBuffers[1]->SetStatusCode(0); pBuffers[2]->InitForRead(2200, 1400); pBuffers[2]->SetBytesTransferred(800); pBuffers[2]->SetStatusCode(0); pBuffers[2]->SetLastPart(true); tReaderWriter.AddFinishedWriteBuffer(pBuffers[1]); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); tReaderWriter.AddFinishedWriteBuffer(pBuffers[2]); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); tReaderWriter.AddFinishedWriteBuffer(pBuffers[0]); EXPECT_SIGNALED(tReaderWriter.GetEventWriteFinishedHandle()); } TEST(TOverlappedReaderWriterTests, GetFinishedBuffer_Signals) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; pBuffers[0]->InitForRead(0, 4096); pBuffers[0]->SetBytesTransferred(4096); pBuffers[0]->SetStatusCode(0); pBuffers[1]->InitForRead(4096, 4096); pBuffers[1]->SetBytesTransferred(4096); pBuffers[1]->SetStatusCode(0); pBuffers[2]->InitForRead(8192, 4096); pBuffers[2]->SetBytesTransferred(800); pBuffers[2]->SetStatusCode(0); pBuffers[2]->SetLastPart(true); tReaderWriter.AddFinishedWriteBuffer(pBuffers[1]); tReaderWriter.AddFinishedWriteBuffer(pBuffers[2]); tReaderWriter.AddFinishedWriteBuffer(pBuffers[0]); TOverlappedDataBuffer* pBuffer = tReaderWriter.GetFinishedWriteBuffer(); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); tReaderWriter.MarkFinishedBufferAsComplete(pBuffer); EXPECT_SIGNALED(tReaderWriter.GetEventWriteFinishedHandle()); pBuffer = tReaderWriter.GetFinishedWriteBuffer(); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); tReaderWriter.MarkFinishedBufferAsComplete(pBuffer); EXPECT_SIGNALED(tReaderWriter.GetEventWriteFinishedHandle()); pBuffer = tReaderWriter.GetFinishedWriteBuffer(); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); tReaderWriter.MarkFinishedBufferAsComplete(pBuffer); EXPECT_TIMEOUT(tReaderWriter.GetEventWriteFinishedHandle()); } TEST(TOverlappedReaderWriterTests, GetFinishedBuffer_WrongOrder) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffers[3] = { tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer(), tReaderWriter.GetEmptyBuffer() }; pBuffers[0]->InitForRead(0, 1000); pBuffers[0]->SetBytesTransferred(1000); pBuffers[0]->SetStatusCode(0); pBuffers[1]->InitForRead(1000, 1200); pBuffers[1]->SetBytesTransferred(1200); pBuffers[1]->SetStatusCode(0); pBuffers[2]->InitForRead(2200, 1400); pBuffers[2]->SetBytesTransferred(800); pBuffers[2]->SetStatusCode(0); pBuffers[2]->SetLastPart(true); tReaderWriter.AddFinishedWriteBuffer(pBuffers[1]); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedWriteBuffer()); tReaderWriter.AddFinishedWriteBuffer(pBuffers[2]); EXPECT_EQ(nullptr, tReaderWriter.GetFinishedWriteBuffer()); tReaderWriter.AddFinishedWriteBuffer(pBuffers[0]); EXPECT_NE(nullptr, tReaderWriter.GetFinishedWriteBuffer()); } TEST(TOverlappedReaderWriterTests, AddFinishedBuffer_Null) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); EXPECT_THROW(tReaderWriter.AddFinishedWriteBuffer(nullptr), TCoreException); } TEST(TOverlappedReaderWriterTests, AddFinishedBuffer_SameBufferTwice) { logger::TLogFileDataPtr spLogData(std::make_shared()); TOverlappedMemoryPoolPtr spBuffers(std::make_shared(3, 32768)); TOverlappedReaderWriter tReaderWriter(spLogData, spBuffers, 0, 4096); TOverlappedDataBuffer* pBuffer = tReaderWriter.GetEmptyBuffer(); tReaderWriter.AddFinishedWriteBuffer(pBuffer); EXPECT_THROW(tReaderWriter.AddFinishedWriteBuffer(pBuffer), TCoreException); }