Index: net/base/network_change_notifier_linux_unittest.cc |
diff --git a/net/base/network_change_notifier_linux_unittest.cc b/net/base/network_change_notifier_linux_unittest.cc |
deleted file mode 100644 |
index c97092ac87daf93483d4754f887bd5c9a2acfe7d..0000000000000000000000000000000000000000 |
--- a/net/base/network_change_notifier_linux_unittest.cc |
+++ /dev/null |
@@ -1,227 +0,0 @@ |
-// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#include "net/base/network_change_notifier_linux.h" |
- |
-#include "base/bind.h" |
-#include "base/message_loop_proxy.h" |
-#include "base/synchronization/waitable_event.h" |
-#include "dbus/mock_bus.h" |
-#include "dbus/mock_object_proxy.h" |
-#include "dbus/message.h" |
-#include "testing/gmock/include/gmock/gmock.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
- |
-namespace net { |
- |
-using testing::_; |
-using testing::DoAll; |
-using testing::InvokeWithoutArgs; |
-using testing::Return; |
-using testing::SaveArg; |
- |
-class NetworkChangeNotifierLinuxTest : public testing::Test { |
- protected: |
- // A subset of the NetworkManager-defined constants used in |
- // the tests below. See network_change_notifier_linux.cc |
- // for the full list. |
- enum { |
- NM_STATE_DISCONNECTED = 20, |
- NM_STATE_DISCONNECTING = 30, |
- NM_STATE_CONNECTED_SITE = 70, |
- NM_STATE_CONNECTED_GLOBAL = 70 |
- }; |
- |
- NetworkChangeNotifierLinuxTest() |
- : initialized_(false, false) {} |
- |
- virtual void SetUp() { |
- dbus::Bus::Options options; |
- options.bus_type = dbus::Bus::SYSTEM; |
- mock_bus_ = new dbus::MockBus(options); |
- |
- mock_object_proxy_ = new dbus::MockObjectProxy(mock_bus_.get(), |
- "service_name", |
- "service_path"); |
- EXPECT_CALL(*mock_bus_, GetObjectProxy(_, _)) |
- .WillOnce(Return(mock_object_proxy_.get())); |
- |
- EXPECT_CALL(*mock_object_proxy_, CallMethod(_, _, _)) |
- .WillOnce(SaveArg<2>(&response_callback_)); |
- EXPECT_CALL(*mock_object_proxy_, ConnectToSignal(_, _, _, _)) |
- .WillOnce( |
- DoAll( |
- SaveArg<2>(&signal_callback_), |
- InvokeWithoutArgs( |
- this, |
- &NetworkChangeNotifierLinuxTest::Initialize))); |
- |
- notifier_.reset(NetworkChangeNotifierLinux::CreateForTest(mock_bus_.get())); |
- |
- initialized_.Wait(); |
- } |
- |
- void Initialize() { |
- notifier_thread_proxy_ = base::MessageLoopProxy::current(); |
- initialized_.Signal(); |
- } |
- |
- void RunOnNotifierThread(const base::Closure& callback) { |
- base::WaitableEvent event(false, false); |
- notifier_thread_proxy_->PostTask(FROM_HERE, base::Bind( |
- &RunOnNotifierThreadHelper, callback, &event)); |
- event.Wait(); |
- // Run any tasks queued on the main thread, e.g. by |
- // ObserverListThreadSafe. |
- MessageLoop::current()->RunAllPending(); |
- } |
- |
- void SendResponse(uint32 state) { |
- scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty()); |
- dbus::MessageWriter writer(response.get()); |
- writer.AppendUint32(state); |
- RunOnNotifierThread(base::Bind(response_callback_, response.get())); |
- } |
- |
- void SendSignal(uint32 state) { |
- dbus::Signal signal("org.freedesktop.NetworkManager", "StateChanged"); |
- dbus::MessageWriter writer(&signal); |
- writer.AppendUint32(state); |
- RunOnNotifierThread(base::Bind(signal_callback_, &signal)); |
- } |
- |
- dbus::ObjectProxy::ResponseCallback response_callback_; |
- dbus::ObjectProxy::SignalCallback signal_callback_; |
- |
- // Allows creating a new NetworkChangeNotifier. Must be created before |
- // |notifier_| and destroyed after it to avoid DCHECK failures. |
- NetworkChangeNotifier::DisableForTest disable_for_test_; |
- scoped_ptr<NetworkChangeNotifier> notifier_; |
- |
- private: |
- static void RunOnNotifierThreadHelper(const base::Closure& callback, |
- base::WaitableEvent* event) { |
- callback.Run(); |
- event->Signal(); |
- } |
- |
- base::WaitableEvent initialized_; |
- |
- // Valid only after initialized_ is signaled. |
- scoped_refptr<base::MessageLoopProxy> notifier_thread_proxy_; |
- |
- scoped_refptr<dbus::MockBus> mock_bus_; |
- scoped_refptr<dbus::MockObjectProxy> mock_object_proxy_; |
-}; |
- |
-namespace { |
- |
-class OfflineObserver : public NetworkChangeNotifier::OnlineStateObserver { |
- public: |
- OfflineObserver() |
- : notification_count(0), |
- last_online_value(true) { |
- NetworkChangeNotifier::AddOnlineStateObserver(this); |
- } |
- |
- ~OfflineObserver() { |
- NetworkChangeNotifier::RemoveOnlineStateObserver(this); |
- } |
- |
- virtual void OnOnlineStateChanged(bool online) OVERRIDE { |
- notification_count++; |
- last_online_value = online; |
- } |
- |
- int notification_count; |
- bool last_online_value; |
-}; |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, Offline) { |
- SendResponse(NM_STATE_DISCONNECTED); |
- EXPECT_TRUE(NetworkChangeNotifier::IsOffline()); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, Online) { |
- SendResponse(NM_STATE_CONNECTED_GLOBAL); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, OfflineThenOnline) { |
- OfflineObserver observer; |
- |
- SendResponse(NM_STATE_DISCONNECTED); |
- EXPECT_TRUE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(0, observer.notification_count); |
- |
- SendSignal(NM_STATE_CONNECTED_GLOBAL); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(1, observer.notification_count); |
- EXPECT_TRUE(observer.last_online_value); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, MultipleStateChanges) { |
- OfflineObserver observer; |
- |
- SendResponse(NM_STATE_CONNECTED_GLOBAL); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(0, observer.notification_count); |
- |
- SendSignal(NM_STATE_DISCONNECTED); |
- EXPECT_TRUE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(1, observer.notification_count); |
- EXPECT_FALSE(observer.last_online_value); |
- |
- SendSignal(NM_STATE_CONNECTED_GLOBAL); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(2, observer.notification_count); |
- EXPECT_TRUE(observer.last_online_value); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, IgnoreContinuedOnlineState) { |
- OfflineObserver observer; |
- |
- SendResponse(NM_STATE_CONNECTED_SITE); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(0, observer.notification_count); |
- |
- SendSignal(NM_STATE_CONNECTED_GLOBAL); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(0, observer.notification_count); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, IgnoreContinuedOfflineState) { |
- OfflineObserver observer; |
- |
- SendResponse(NM_STATE_DISCONNECTING); |
- EXPECT_TRUE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(0, observer.notification_count); |
- |
- SendSignal(NM_STATE_DISCONNECTED); |
- EXPECT_TRUE(NetworkChangeNotifier::IsOffline()); |
- EXPECT_EQ(0, observer.notification_count); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, NullResponse) { |
- RunOnNotifierThread(base::Bind( |
- response_callback_, static_cast<dbus::Response*>(NULL))); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, EmptyResponse) { |
- scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty()); |
- RunOnNotifierThread(base::Bind(response_callback_, response.get())); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
-} |
- |
-TEST_F(NetworkChangeNotifierLinuxTest, InvalidResponse) { |
- scoped_ptr<dbus::Response> response(dbus::Response::CreateEmpty()); |
- dbus::MessageWriter writer(response.get()); |
- writer.AppendUint16(20); // Uint16 instead of the expected Uint32 |
- RunOnNotifierThread(base::Bind(response_callback_, response.get())); |
- EXPECT_FALSE(NetworkChangeNotifier::IsOffline()); |
-} |
- |
-} // namespace |
-} // namespace net |