39 lines
997 B
C++
39 lines
997 B
C++
|
#include <glog/logging.h>
|
||
|
#include "communication/result_stream_faker.hpp"
|
||
|
#include "database/dbms.hpp"
|
||
|
#include "query/engine.hpp"
|
||
|
#include "query/exceptions.hpp"
|
||
|
|
||
|
#include <gtest/gtest.h>
|
||
|
|
||
|
DECLARE_int32(query_execution_time_sec);
|
||
|
|
||
|
TEST(TransactionTimeout, TransactionTimeout) {
|
||
|
FLAGS_query_execution_time_sec = 3;
|
||
|
Dbms dbms;
|
||
|
QueryEngine<ResultStreamFaker> engine;
|
||
|
{
|
||
|
ResultStreamFaker stream;
|
||
|
auto dba1 = dbms.active();
|
||
|
engine.Run("MATCH (n) RETURN n", *dba1, stream);
|
||
|
}
|
||
|
{
|
||
|
ResultStreamFaker stream;
|
||
|
auto dba2 = dbms.active();
|
||
|
std::this_thread::sleep_for(std::chrono::seconds(5));
|
||
|
ASSERT_THROW(engine.Run("MATCH (n) RETURN n", *dba2, stream),
|
||
|
query::HintedAbortError);
|
||
|
}
|
||
|
{
|
||
|
ResultStreamFaker stream;
|
||
|
auto dba3 = dbms.active();
|
||
|
engine.Run("MATCH (n) RETURN n", *dba3, stream);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
int main(int argc, char **argv) {
|
||
|
google::InitGoogleLogging(argv[0]);
|
||
|
::testing::InitGoogleTest(&argc, argv);
|
||
|
return RUN_ALL_TESTS();
|
||
|
}
|