2023-11-22 21:05:02 +08:00
|
|
|
// Copyright 2023 Memgraph Ltd.
|
2021-10-26 14:53:56 +08:00
|
|
|
//
|
|
|
|
// Use of this software is governed by the Business Source License
|
|
|
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
// License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
//
|
|
|
|
// As of the Change Date specified in that file, in accordance with
|
|
|
|
// the Business Source License, use of this software will be governed
|
|
|
|
// by the Apache License, Version 2.0, included in the file
|
|
|
|
// licenses/APL.txt.
|
|
|
|
|
2017-03-22 22:53:30 +08:00
|
|
|
#include "bolt_common.hpp"
|
2017-04-06 20:30:04 +08:00
|
|
|
#include "communication/bolt/v1/encoder/chunked_encoder_buffer.hpp"
|
2017-03-22 22:53:30 +08:00
|
|
|
|
2017-03-28 18:42:04 +08:00
|
|
|
// aliases
|
2022-02-22 20:33:45 +08:00
|
|
|
using BufferT = memgraph::communication::bolt::ChunkedEncoderBuffer<TestOutputStream>;
|
2017-03-22 22:53:30 +08:00
|
|
|
|
2017-09-06 20:57:20 +08:00
|
|
|
// constants
|
2022-02-22 20:33:45 +08:00
|
|
|
using memgraph::communication::bolt::kChunkHeaderSize;
|
|
|
|
using memgraph::communication::bolt::kChunkMaxDataSize;
|
|
|
|
using memgraph::communication::bolt::kChunkWholeSize;
|
2017-09-06 20:57:20 +08:00
|
|
|
|
|
|
|
// test data
|
2022-03-31 19:52:43 +08:00
|
|
|
inline constexpr const int kTestDataSize = 100000;
|
2018-07-18 16:40:06 +08:00
|
|
|
uint8_t test_data[kTestDataSize];
|
2017-03-22 22:53:30 +08:00
|
|
|
|
2021-01-21 22:47:56 +08:00
|
|
|
struct BoltChunkedEncoderBuffer : ::testing::Test {
|
|
|
|
// In newer gtest library (1.8.1+) this is changed to SetUpTestSuite
|
|
|
|
static void SetUpTestCase() { InitializeData(test_data, kTestDataSize); }
|
|
|
|
};
|
|
|
|
|
2017-03-28 18:42:04 +08:00
|
|
|
/**
|
2018-07-18 16:40:06 +08:00
|
|
|
* Verifies a single chunk. The chunk should be constructed from a header
|
|
|
|
* (chunk size) and data. The header is a two byte long number written in big
|
|
|
|
* endian format. Data is an array of elements from test_data whose max size is
|
|
|
|
* 0xFFFF.
|
2017-03-28 18:42:04 +08:00
|
|
|
*
|
|
|
|
* @param data pointer on data array (array of bytes)
|
|
|
|
* @param size of data array
|
2017-09-06 20:57:20 +08:00
|
|
|
* @param offset offset from the begining of the test data
|
2017-03-28 18:42:04 +08:00
|
|
|
*/
|
2018-07-18 16:40:06 +08:00
|
|
|
void VerifyChunkOfTestData(uint8_t *data, int size, uint64_t offset = 0) {
|
2017-03-28 18:42:04 +08:00
|
|
|
// first two bytes are size (big endian)
|
|
|
|
uint8_t lower_byte = size & 0xFF;
|
|
|
|
uint8_t higher_byte = (size & 0xFF00) >> 8;
|
|
|
|
ASSERT_EQ(*data, higher_byte);
|
|
|
|
ASSERT_EQ(*(data + 1), lower_byte);
|
2017-03-22 22:53:30 +08:00
|
|
|
|
2017-03-28 18:42:04 +08:00
|
|
|
// in the data array should be size number of ones
|
|
|
|
// the header is skipped
|
2017-09-06 20:57:20 +08:00
|
|
|
for (auto i = 0; i < size; ++i) {
|
2018-07-18 16:40:06 +08:00
|
|
|
ASSERT_EQ(data[i + kChunkHeaderSize], test_data[i + offset]);
|
2017-09-06 18:51:56 +08:00
|
|
|
}
|
2017-03-22 22:53:30 +08:00
|
|
|
}
|
|
|
|
|
2021-01-21 22:47:56 +08:00
|
|
|
TEST_F(BoltChunkedEncoderBuffer, OneSmallChunk) {
|
2017-03-28 18:42:04 +08:00
|
|
|
int size = 100;
|
2017-03-22 22:53:30 +08:00
|
|
|
|
2017-03-28 18:42:04 +08:00
|
|
|
// initialize tested buffer
|
2018-03-23 23:32:17 +08:00
|
|
|
TestOutputStream output_stream;
|
|
|
|
BufferT buffer(output_stream);
|
2017-03-28 18:42:04 +08:00
|
|
|
|
|
|
|
// write into buffer
|
2017-09-06 20:57:20 +08:00
|
|
|
buffer.Write(test_data, size);
|
2017-03-28 18:42:04 +08:00
|
|
|
buffer.Flush();
|
|
|
|
|
|
|
|
// check the output array
|
2018-07-18 16:40:06 +08:00
|
|
|
// the array should look like: [0, 100, first 100 bytes of test data]
|
2018-03-23 23:32:17 +08:00
|
|
|
VerifyChunkOfTestData(output_stream.output.data(), size);
|
2017-03-28 18:42:04 +08:00
|
|
|
}
|
|
|
|
|
2021-01-21 22:47:56 +08:00
|
|
|
TEST_F(BoltChunkedEncoderBuffer, TwoSmallChunks) {
|
2017-03-28 18:42:04 +08:00
|
|
|
int size1 = 100;
|
|
|
|
int size2 = 200;
|
|
|
|
|
|
|
|
// initialize tested buffer
|
2018-03-23 23:32:17 +08:00
|
|
|
TestOutputStream output_stream;
|
|
|
|
BufferT buffer(output_stream);
|
2017-03-28 18:42:04 +08:00
|
|
|
|
|
|
|
// write into buffer
|
2017-09-06 20:57:20 +08:00
|
|
|
buffer.Write(test_data, size1);
|
2018-07-18 16:40:06 +08:00
|
|
|
buffer.Flush();
|
2017-09-06 20:57:20 +08:00
|
|
|
buffer.Write(test_data + size1, size2);
|
2017-03-28 18:42:04 +08:00
|
|
|
buffer.Flush();
|
|
|
|
|
|
|
|
// check the output array
|
2017-09-06 20:57:20 +08:00
|
|
|
// the output array should look like this:
|
2018-07-18 16:40:06 +08:00
|
|
|
// [0, 100, first 100 bytes of test data] +
|
|
|
|
// [0, 100, second 100 bytes of test data]
|
2023-11-22 21:05:02 +08:00
|
|
|
auto *data = output_stream.output.data();
|
2017-09-06 20:57:20 +08:00
|
|
|
VerifyChunkOfTestData(data, size1);
|
2018-07-18 16:40:06 +08:00
|
|
|
VerifyChunkOfTestData(data + kChunkHeaderSize + size1, size2, size1);
|
2017-03-22 22:53:30 +08:00
|
|
|
}
|
|
|
|
|
2021-01-21 22:47:56 +08:00
|
|
|
TEST_F(BoltChunkedEncoderBuffer, OneAndAHalfOfMaxChunk) {
|
2017-03-28 18:42:04 +08:00
|
|
|
// initialize tested buffer
|
2018-03-23 23:32:17 +08:00
|
|
|
TestOutputStream output_stream;
|
|
|
|
BufferT buffer(output_stream);
|
2017-03-28 18:42:04 +08:00
|
|
|
|
|
|
|
// write into buffer
|
2018-07-18 16:40:06 +08:00
|
|
|
buffer.Write(test_data, kTestDataSize);
|
2017-03-28 18:42:04 +08:00
|
|
|
buffer.Flush();
|
|
|
|
|
|
|
|
// check the output array
|
|
|
|
// the output array should look like this:
|
2017-09-06 20:57:20 +08:00
|
|
|
// [0xFF, 0xFF, first 65535 bytes of test data,
|
2018-07-18 16:40:06 +08:00
|
|
|
// 0x86, 0xA1, 34465 bytes of test data after the first 65535 bytes]
|
2023-11-22 21:05:02 +08:00
|
|
|
auto *output = output_stream.output.data();
|
2018-07-18 16:40:06 +08:00
|
|
|
VerifyChunkOfTestData(output, kChunkMaxDataSize);
|
2021-02-18 22:32:43 +08:00
|
|
|
VerifyChunkOfTestData(output + kChunkWholeSize, kTestDataSize - kChunkMaxDataSize, kChunkMaxDataSize);
|
2017-03-28 18:42:04 +08:00
|
|
|
}
|