1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/apps/openmw_test_suite/misc/progressreporter.cpp
elsid bb26ba30b6
Add progress reporter type
To log/report progress of long duration operations using given time period.
2021-10-18 01:26:10 +02:00

44 lines
1.1 KiB
C++

#include <components/misc/progressreporter.hpp>
#include <gtest/gtest.h>
#include <gmock/gmock.h>
#include <chrono>
namespace
{
using namespace testing;
using namespace Misc;
struct ReportMock
{
MOCK_METHOD(void, call, (std::size_t, std::size_t), ());
};
struct Report
{
StrictMock<ReportMock>* mImpl;
void operator()(std::size_t provided, std::size_t expected)
{
mImpl->call(provided, expected);
}
};
TEST(MiscProgressReporterTest, shouldCallReportWhenPassedInterval)
{
StrictMock<ReportMock> report;
EXPECT_CALL(report, call(13, 42)).WillOnce(Return());
ProgressReporter reporter(std::chrono::steady_clock::duration(0), Report {&report});
reporter(13, 42);
}
TEST(MiscProgressReporterTest, shouldNotCallReportWhenIntervalIsNotPassed)
{
StrictMock<ReportMock> report;
EXPECT_CALL(report, call(13, 42)).Times(0);
ProgressReporter reporter(std::chrono::seconds(1000), Report {&report});
reporter(13, 42);
}
}