1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- #ifndef UPDATE_ENGINE_DBUS_TEST_UTILS_H_
- #define UPDATE_ENGINE_DBUS_TEST_UTILS_H_
- #include <set>
- #include <string>
- #include <base/bind.h>
- #include <brillo/message_loops/message_loop.h>
- #include <gmock/gmock.h>
- namespace chromeos_update_engine {
- namespace dbus_test_utils {
- #define MOCK_SIGNAL_HANDLER_EXPECT_SIGNAL_HANDLER( \
- mock_signal_handler, mock_proxy, signal) \
- do { \
- EXPECT_CALL((mock_proxy), \
- Register##signal##SignalHandler(::testing::_, ::testing::_)) \
- .WillOnce(::chromeos_update_engine::dbus_test_utils::GrabCallbacks( \
- &(mock_signal_handler))); \
- } while (false)
- template <typename T>
- class MockSignalHandler {
- public:
- MockSignalHandler() = default;
- ~MockSignalHandler() {
- if (callback_connected_task_ != brillo::MessageLoop::kTaskIdNull)
- brillo::MessageLoop::current()->CancelTask(callback_connected_task_);
- }
-
- bool IsHandlerRegistered() const { return signal_callback_ != nullptr; }
- const base::Callback<T>& signal_callback() { return *signal_callback_.get(); }
- void GrabCallbacks(
- const base::Callback<T>& signal_callback,
- dbus::ObjectProxy::OnConnectedCallback on_connected_callback) {
- signal_callback_.reset(new base::Callback<T>(signal_callback));
- on_connected_callback_.reset(
- new dbus::ObjectProxy::OnConnectedCallback(on_connected_callback));
-
- callback_connected_task_ = brillo::MessageLoop::current()->PostTask(
- FROM_HERE,
- base::Bind(&MockSignalHandler<T>::OnCallbackConnected,
- base::Unretained(this)));
- }
- private:
- void OnCallbackConnected() {
- callback_connected_task_ = brillo::MessageLoop::kTaskIdNull;
- on_connected_callback_->Run("", "", true);
- }
- brillo::MessageLoop::TaskId callback_connected_task_{
- brillo::MessageLoop::kTaskIdNull};
- std::unique_ptr<base::Callback<T>> signal_callback_;
- std::unique_ptr<dbus::ObjectProxy::OnConnectedCallback>
- on_connected_callback_;
- };
- ACTION_P(GrabCallbacks, mock_signal_handler) {
- mock_signal_handler->GrabCallbacks(arg0, arg1);
- }
- }
- }
- #endif
|