2017-04-06 20:30:04 +08:00
|
|
|
#include "bolt_common.hpp"
|
2018-04-04 21:56:36 +08:00
|
|
|
#include "communication/buffer.hpp"
|
2017-04-06 20:30:04 +08:00
|
|
|
#include "communication/bolt/v1/decoder/chunked_decoder_buffer.hpp"
|
|
|
|
|
|
|
|
constexpr const int SIZE = 131072;
|
|
|
|
uint8_t data[SIZE];
|
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
using BufferT = communication::Buffer;
|
2017-04-06 20:30:04 +08:00
|
|
|
using StreamBufferT = io::network::StreamBuffer;
|
2018-04-04 21:56:36 +08:00
|
|
|
using DecoderBufferT = communication::bolt::ChunkedDecoderBuffer<BufferT::ReadEnd>;
|
2017-04-15 21:14:12 +08:00
|
|
|
using ChunkStateT = communication::bolt::ChunkState;
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
TEST(BoltBuffer, CorrectChunk) {
|
|
|
|
uint8_t tmp[2000];
|
|
|
|
BufferT buffer;
|
2018-04-04 21:56:36 +08:00
|
|
|
DecoderBufferT decoder_buffer(buffer.read_end());
|
|
|
|
StreamBufferT sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[0] = 0x03;
|
|
|
|
sb.data[1] = 0xe8;
|
2017-04-06 20:30:04 +08:00
|
|
|
memcpy(sb.data + 2, data, 1000);
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[1002] = 0;
|
|
|
|
sb.data[1003] = 0;
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(1004);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-04-15 21:14:12 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Whole);
|
2017-09-06 18:51:56 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Done);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
ASSERT_EQ(decoder_buffer.Read(tmp, 1000), true);
|
2017-06-21 17:29:13 +08:00
|
|
|
for (int i = 0; i < 1000; ++i) EXPECT_EQ(data[i], tmp[i]);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
ASSERT_EQ(buffer.read_end().size(), 0);
|
2017-04-06 20:30:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BoltBuffer, CorrectChunkTrailingData) {
|
|
|
|
uint8_t tmp[2000];
|
|
|
|
BufferT buffer;
|
2018-04-04 21:56:36 +08:00
|
|
|
DecoderBufferT decoder_buffer(buffer.read_end());
|
|
|
|
StreamBufferT sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[0] = 0x03;
|
|
|
|
sb.data[1] = 0xe8;
|
2017-04-06 20:30:04 +08:00
|
|
|
memcpy(sb.data + 2, data, 2002);
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[1002] = 0;
|
|
|
|
sb.data[1003] = 0;
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(2004);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-04-15 21:14:12 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Whole);
|
2017-09-06 18:51:56 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Done);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
ASSERT_EQ(decoder_buffer.Read(tmp, 1000), true);
|
2017-06-21 17:29:13 +08:00
|
|
|
for (int i = 0; i < 1000; ++i) EXPECT_EQ(data[i], tmp[i]);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
uint8_t *leftover = buffer.read_end().data();
|
|
|
|
ASSERT_EQ(buffer.read_end().size(), 1000);
|
2017-06-21 17:29:13 +08:00
|
|
|
for (int i = 0; i < 1000; ++i) EXPECT_EQ(data[i + 1002], leftover[i]);
|
2017-04-06 20:30:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BoltBuffer, GraduallyPopulatedChunk) {
|
|
|
|
uint8_t tmp[2000];
|
|
|
|
BufferT buffer;
|
2018-04-04 21:56:36 +08:00
|
|
|
DecoderBufferT decoder_buffer(buffer.read_end());
|
|
|
|
StreamBufferT sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[0] = 0x03;
|
|
|
|
sb.data[1] = 0xe8;
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(2);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
for (int i = 0; i < 5; ++i) {
|
2017-09-06 18:51:56 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Partial);
|
2018-04-04 21:56:36 +08:00
|
|
|
sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
memcpy(sb.data, data + 200 * i, 200);
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(200);
|
2017-04-06 20:30:04 +08:00
|
|
|
}
|
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
sb = buffer.write_end().Allocate();
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[0] = 0;
|
|
|
|
sb.data[1] = 0;
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(2);
|
2017-04-15 21:14:12 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Whole);
|
2017-09-06 18:51:56 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Done);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
ASSERT_EQ(decoder_buffer.Read(tmp, 1000), true);
|
2017-06-21 17:29:13 +08:00
|
|
|
for (int i = 0; i < 1000; ++i) EXPECT_EQ(data[i], tmp[i]);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
ASSERT_EQ(buffer.read_end().size(), 0);
|
2017-04-06 20:30:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BoltBuffer, GraduallyPopulatedChunkTrailingData) {
|
|
|
|
uint8_t tmp[2000];
|
|
|
|
BufferT buffer;
|
2018-04-04 21:56:36 +08:00
|
|
|
DecoderBufferT decoder_buffer(buffer.read_end());
|
|
|
|
StreamBufferT sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[0] = 0x03;
|
|
|
|
sb.data[1] = 0xe8;
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(2);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
for (int i = 0; i < 5; ++i) {
|
2017-09-06 18:51:56 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Partial);
|
2018-04-04 21:56:36 +08:00
|
|
|
sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
memcpy(sb.data, data + 200 * i, 200);
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(200);
|
2017-04-06 20:30:04 +08:00
|
|
|
}
|
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
sb = buffer.write_end().Allocate();
|
2017-06-21 17:29:13 +08:00
|
|
|
sb.data[0] = 0;
|
|
|
|
sb.data[1] = 0;
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(2);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
sb = buffer.write_end().Allocate();
|
2017-04-06 20:30:04 +08:00
|
|
|
memcpy(sb.data, data, 1000);
|
2018-04-04 21:56:36 +08:00
|
|
|
buffer.write_end().Written(1000);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2017-04-15 21:14:12 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Whole);
|
2017-09-06 18:51:56 +08:00
|
|
|
ASSERT_EQ(decoder_buffer.GetChunk(), ChunkStateT::Done);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
|
|
|
ASSERT_EQ(decoder_buffer.Read(tmp, 1000), true);
|
2017-06-21 17:29:13 +08:00
|
|
|
for (int i = 0; i < 1000; ++i) EXPECT_EQ(data[i], tmp[i]);
|
2017-04-06 20:30:04 +08:00
|
|
|
|
2018-04-04 21:56:36 +08:00
|
|
|
uint8_t *leftover = buffer.read_end().data();
|
|
|
|
ASSERT_EQ(buffer.read_end().size(), 1000);
|
2017-06-21 17:29:13 +08:00
|
|
|
for (int i = 0; i < 1000; ++i) EXPECT_EQ(data[i], leftover[i]);
|
2017-04-06 20:30:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
InitializeData(data, SIZE);
|
2017-06-21 17:29:13 +08:00
|
|
|
google::InitGoogleLogging(argv[0]);
|
2017-04-06 20:30:04 +08:00
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
return RUN_ALL_TESTS();
|
|
|
|
}
|