// Copyright 2015 The Chromium OS Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef LIBBRILLO_BRILLO_MESSAGE_LOOPS_MOCK_MESSAGE_LOOP_H_ #define LIBBRILLO_BRILLO_MESSAGE_LOOPS_MOCK_MESSAGE_LOOP_H_ #include <gmock/gmock.h> #include <base/location.h> #include <base/test/simple_test_clock.h> #include <base/time/time.h> #include <brillo/brillo_export.h> #include <brillo/message_loops/fake_message_loop.h> #include <brillo/message_loops/message_loop.h> namespace brillo { // The MockMessageLoop is a mockable MessageLoop that will by default act as a // FakeMessageLoop. It is possible to set expectations with EXPECT_CALL without // any action associated and they will call the same methods in the underlying // FakeMessageLoop implementation. // This message loop implementation is useful to check interaction with the // message loop when running unittests. class BRILLO_EXPORT MockMessageLoop : public MessageLoop { public: // Create a FakeMessageLoop optionally using a SimpleTestClock to update the // time when Run() or RunOnce(true) are called and should block. explicit MockMessageLoop(base::SimpleTestClock* clock) : fake_loop_(clock) { // Redirect all actions to calling the underlying FakeMessageLoop by // default. For the overloaded methods, we need to disambiguate between the // different options by specifying the type of the method pointer. ON_CALL(*this, PostDelayedTask(::testing::_, ::testing::_, ::testing::_)) .WillByDefault(::testing::Invoke( &fake_loop_, static_cast<TaskId(FakeMessageLoop::*)( const base::Location&, const base::Closure&, base::TimeDelta)>( &FakeMessageLoop::PostDelayedTask))); ON_CALL(*this, WatchFileDescriptor( ::testing::_, ::testing::_, ::testing::_, ::testing::_, ::testing::_)) .WillByDefault(::testing::Invoke( &fake_loop_, static_cast<TaskId(FakeMessageLoop::*)( const base::Location&, int, WatchMode, bool, const base::Closure&)>( &FakeMessageLoop::WatchFileDescriptor))); ON_CALL(*this, CancelTask(::testing::_)) .WillByDefault(::testing::Invoke(&fake_loop_, &FakeMessageLoop::CancelTask)); ON_CALL(*this, RunOnce(::testing::_)) .WillByDefault(::testing::Invoke(&fake_loop_, &FakeMessageLoop::RunOnce)); } ~MockMessageLoop() override = default; MOCK_METHOD3(PostDelayedTask, TaskId(const base::Location& from_here, const base::Closure& task, base::TimeDelta delay)); using MessageLoop::PostDelayedTask; MOCK_METHOD5(WatchFileDescriptor, TaskId(const base::Location& from_here, int fd, WatchMode mode, bool persistent, const base::Closure& task)); using MessageLoop::WatchFileDescriptor; MOCK_METHOD1(CancelTask, bool(TaskId task_id)); MOCK_METHOD1(RunOnce, bool(bool may_block)); // Returns the actual FakeMessageLoop instance so default actions can be // override with other actions or call FakeMessageLoop* fake_loop() { return &fake_loop_; } private: FakeMessageLoop fake_loop_; DISALLOW_COPY_AND_ASSIGN(MockMessageLoop); }; } // namespace brillo #endif // LIBBRILLO_BRILLO_MESSAGE_LOOPS_MOCK_MESSAGE_LOOP_H_