2016-08-02 05:14:09 +08:00
|
|
|
#include <cassert>
|
2016-08-15 07:09:58 +08:00
|
|
|
#include <deque>
|
|
|
|
#include <iostream>
|
2016-08-02 05:14:09 +08:00
|
|
|
#include <vector>
|
|
|
|
|
2016-08-11 11:47:30 +08:00
|
|
|
#include "communication/bolt/v1/transport/chunked_encoder.hpp"
|
2016-08-15 07:09:58 +08:00
|
|
|
#include "logging/default.hpp"
|
|
|
|
#include "logging/streams/stdout.hpp"
|
2016-08-02 05:14:09 +08:00
|
|
|
|
|
|
|
using byte = unsigned char;
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
void print_hex(byte x) { printf("%02X ", static_cast<byte>(x)); }
|
2016-08-02 05:14:09 +08:00
|
|
|
|
|
|
|
class DummyStream
|
|
|
|
{
|
|
|
|
public:
|
2016-08-15 07:09:58 +08:00
|
|
|
void write(const byte *values, size_t n)
|
2016-08-02 05:14:09 +08:00
|
|
|
{
|
|
|
|
num_calls++;
|
|
|
|
data.insert(data.end(), values, values + n);
|
|
|
|
}
|
|
|
|
|
|
|
|
byte pop()
|
|
|
|
{
|
|
|
|
auto c = data.front();
|
|
|
|
data.pop_front();
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
size_t pop_size() { return ((size_t)pop() << 8) | pop(); }
|
2016-08-02 05:14:09 +08:00
|
|
|
|
|
|
|
void print()
|
|
|
|
{
|
2016-08-15 07:09:58 +08:00
|
|
|
for (size_t i = 0; i < data.size(); ++i)
|
2016-08-02 05:14:09 +08:00
|
|
|
print_hex(data[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
std::deque<byte> data;
|
2016-08-15 07:09:58 +08:00
|
|
|
size_t num_calls{0};
|
2016-08-02 05:14:09 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
using Encoder = bolt::ChunkedEncoder<DummyStream>;
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
void write_ff(Encoder &encoder, size_t n)
|
2016-08-02 05:14:09 +08:00
|
|
|
{
|
|
|
|
std::vector<byte> v;
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
for (size_t i = 0; i < n; ++i)
|
2016-08-02 05:14:09 +08:00
|
|
|
v.push_back('\xFF');
|
|
|
|
|
|
|
|
encoder.write(v.data(), v.size());
|
|
|
|
}
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
void check_ff(DummyStream &stream, size_t n)
|
2016-08-02 05:14:09 +08:00
|
|
|
{
|
2016-08-15 07:09:58 +08:00
|
|
|
for (size_t i = 0; i < n; ++i)
|
2016-08-02 05:14:09 +08:00
|
|
|
assert(stream.pop() == byte('\xFF'));
|
|
|
|
|
|
|
|
(void)stream;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2016-08-29 01:50:54 +08:00
|
|
|
// TODO: write new test
|
|
|
|
|
|
|
|
// logging::init_async();
|
|
|
|
// logging::log->pipe(std::make_unique<Stdout>());
|
|
|
|
// DummyStream stream;
|
|
|
|
// bolt::ChunkedEncoder<DummyStream> encoder(stream);
|
|
|
|
|
|
|
|
// write_ff(encoder, 10);
|
|
|
|
// write_ff(encoder, 10);
|
|
|
|
// encoder.flush();
|
|
|
|
|
|
|
|
// write_ff(encoder, 10);
|
|
|
|
// write_ff(encoder, 10);
|
|
|
|
// encoder.flush();
|
|
|
|
|
|
|
|
// // this should be two chunks, one of size 65533 and the other of size 1467
|
|
|
|
// write_ff(encoder, 67000);
|
|
|
|
// encoder.flush();
|
|
|
|
|
|
|
|
// for (int i = 0; i < 10000; ++i)
|
|
|
|
// write_ff(encoder, 1500);
|
|
|
|
// encoder.flush();
|
|
|
|
|
|
|
|
// assert(stream.pop_size() == 20);
|
|
|
|
// check_ff(stream, 20);
|
|
|
|
// assert(stream.pop_size() == 0);
|
|
|
|
|
|
|
|
// assert(stream.pop_size() == 20);
|
|
|
|
// check_ff(stream, 20);
|
|
|
|
// assert(stream.pop_size() == 0);
|
|
|
|
|
|
|
|
// assert(stream.pop_size() == encoder.chunk_size);
|
|
|
|
// check_ff(stream, encoder.chunk_size);
|
|
|
|
// assert(stream.pop_size() == 1467);
|
|
|
|
// check_ff(stream, 1467);
|
|
|
|
// assert(stream.pop_size() == 0);
|
|
|
|
|
|
|
|
// size_t k = 10000 * 1500;
|
|
|
|
|
|
|
|
// while (k > 0) {
|
|
|
|
// auto size = k > encoder.chunk_size ? encoder.chunk_size : k;
|
|
|
|
// assert(stream.pop_size() == size);
|
|
|
|
// check_ff(stream, size);
|
|
|
|
|
|
|
|
// k -= size;
|
|
|
|
// }
|
|
|
|
|
|
|
|
// assert(stream.pop_size() == 0);
|
2016-08-02 05:14:09 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|