d7a9c5bab8
Summary: This is the first step in cutting the crazy dependencies of communication module to the whole database. Includes have been reorganized and conversion between DecodedValue and other Memgraph types (TypedValue and PropertyValue) has been extracted to a higher level component called `communication/conversion`. Encoder, like Decoder, now relies only on DecodedValue. Hopefully the conversion operations will not significantly slow down streaming Bolt data. Additionally, Bolt ID is now wrapped in a class. Our storage model uses *unsigned* int64, while Bolt expects *signed* int64. The implicit conversions may lead to encode/decode errors, so the wrapper should enforce some type safety to prevent such errors. Reviewers: mferencevic, buda, msantl, mtomic Reviewed By: mferencevic, mtomic Subscribers: pullbot Differential Revision: https://phabricator.memgraph.io/D1453
33 lines
898 B
C++
33 lines
898 B
C++
#include <glog/logging.h>
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "communication/result_stream_faker.hpp"
|
|
#include "query/exceptions.hpp"
|
|
#include "query/interpreter.hpp"
|
|
|
|
DECLARE_int32(query_execution_time_sec);
|
|
|
|
TEST(TransactionTimeout, TransactionTimeout) {
|
|
FLAGS_query_execution_time_sec = 3;
|
|
database::SingleNode db;
|
|
query::Interpreter interpreter{db};
|
|
auto interpret = [&](auto &dba, const std::string &query) {
|
|
ResultStreamFaker<query::TypedValue> stream;
|
|
interpreter(query, dba, {}, false).PullAll(stream);
|
|
|
|
};
|
|
{
|
|
database::GraphDbAccessor dba(db);
|
|
interpret(dba, "MATCH (n) RETURN n");
|
|
}
|
|
{
|
|
database::GraphDbAccessor dba(db);
|
|
std::this_thread::sleep_for(std::chrono::seconds(5));
|
|
ASSERT_THROW(interpret(dba, "MATCH (n) RETURN n"), query::HintedAbortError);
|
|
}
|
|
{
|
|
database::GraphDbAccessor dba(db);
|
|
interpret(dba, "MATCH (n) RETURN n");
|
|
}
|
|
}
|