danicoin/tests/System/ContextGroupTimeoutTests.cpp
2016-01-18 15:33:29 +00:00

48 lines
1.8 KiB
C++

// Copyright (c) 2011-2016 The Cryptonote developers
// Distributed under the MIT/X11 software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
#include <gtest/gtest.h>
#include <System/ContextGroupTimeout.h>
#include <System/InterruptedException.h>
using namespace System;
class ContextGroupTimeoutTest : public testing::Test {
public:
ContextGroupTimeoutTest() : contextGroup(dispatcher), timer(dispatcher) {
}
Dispatcher dispatcher;
ContextGroup contextGroup;
Timer timer;
};
TEST_F(ContextGroupTimeoutTest, timeoutHappens) {
auto begin = std::chrono::high_resolution_clock::now();
ContextGroupTimeout groupTimeout(dispatcher, contextGroup, std::chrono::milliseconds(100));
contextGroup.spawn([&] {
EXPECT_THROW(Timer(dispatcher).sleep(std::chrono::milliseconds(200)), InterruptedException);
});
contextGroup.wait();
ASSERT_GE(std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::high_resolution_clock::now() - begin).count(), 50);
ASSERT_TRUE((std::chrono::high_resolution_clock::now() - begin) < std::chrono::milliseconds(150));
}
TEST_F(ContextGroupTimeoutTest, timeoutSkipped) {
auto begin = std::chrono::high_resolution_clock::now();
{
ContextGroupTimeout op(dispatcher, contextGroup, std::chrono::milliseconds(200));
contextGroup.spawn([&] {
EXPECT_NO_THROW(Timer(dispatcher).sleep(std::chrono::milliseconds(100)));
});
contextGroup.wait();
}
ASSERT_TRUE((std::chrono::high_resolution_clock::now() - begin) > std::chrono::milliseconds(50));
ASSERT_TRUE((std::chrono::high_resolution_clock::now() - begin) < std::chrono::milliseconds(150));
}
TEST_F(ContextGroupTimeoutTest, noOperation) {
ContextGroupTimeout op(dispatcher, contextGroup, std::chrono::milliseconds(100));
}