Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(131)

Unified Diff: net/base/network_change_notifier_linux_unittest.cc

Issue 8578013: Revert "Offline state detection for linux, using new D-Bus library." (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/base/network_change_notifier_linux.cc ('k') | net/net.gyp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
« no previous file with comments | « net/base/network_change_notifier_linux.cc ('k') | net/net.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698