danicoin/tests/System/ContextGroupTimeoutTests.cpp
2015-07-30 16:22:07 +01:00

60 lines
2.3 KiB
C++

// Copyright (c) 2012-2015, The CryptoNote developers, The Bytecoin developers
//
// This file is part of Bytecoin.
//
// Bytecoin is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Bytecoin is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with Bytecoin. If not, see <http://www.gnu.org/licenses/>.
#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));
}