summaryrefslogtreecommitdiffstats
path: root/chromeos/network/network_connection_handler_unittest.cc
diff options
context:
space:
mode:
authorstevenjb@chromium.org <stevenjb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-05-14 04:37:56 +0000
committerstevenjb@chromium.org <stevenjb@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-05-14 04:37:56 +0000
commit534190554ff15076010b53f879e8c17dc0ccb8b8 (patch)
tree68ff6b92205ddc09ef62a18c947eaeedf994f00d /chromeos/network/network_connection_handler_unittest.cc
parent9c48757cc3a705f6bb635747333dd3baccc48019 (diff)
downloadchromium_src-534190554ff15076010b53f879e8c17dc0ccb8b8.zip
chromium_src-534190554ff15076010b53f879e8c17dc0ccb8b8.tar.gz
chromium_src-534190554ff15076010b53f879e8c17dc0ccb8b8.tar.bz2
Add NetworkConnectionHandler class
This moves NetworkConfigurationHandler::Connect -> NetworkConnectionHandler::ConnectToNetwork and adds error handling and certificate checking. Depends on https://codereview.chromium.org/14522013/ Test with --use-new-network-configuration-handlers BUG=235243 Review URL: https://chromiumcodereview.appspot.com/14566009 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@199893 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chromeos/network/network_connection_handler_unittest.cc')
-rw-r--r--chromeos/network/network_connection_handler_unittest.cc210
1 files changed, 210 insertions, 0 deletions
diff --git a/chromeos/network/network_connection_handler_unittest.cc b/chromeos/network/network_connection_handler_unittest.cc
new file mode 100644
index 0000000..7b4ab2b
--- /dev/null
+++ b/chromeos/network/network_connection_handler_unittest.cc
@@ -0,0 +1,210 @@
+// Copyright (c) 2012 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 "chromeos/network/network_connection_handler.h"
+
+#include "base/bind.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/message_loop.h"
+#include "chromeos/dbus/dbus_thread_manager.h"
+#include "chromeos/dbus/shill_manager_client.h"
+#include "chromeos/dbus/shill_service_client.h"
+#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/network/network_state_handler.h"
+#include "chromeos/network/onc/onc_utils.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "third_party/cros_system_api/dbus/service_constants.h"
+
+namespace {
+
+const char* kSuccessResult = "success";
+
+} // namespace
+
+namespace chromeos {
+
+class NetworkConnectionHandlerTest : public testing::Test {
+ public:
+ NetworkConnectionHandlerTest() {
+ }
+ virtual ~NetworkConnectionHandlerTest() {
+ }
+
+ virtual void SetUp() OVERRIDE {
+ // Initialize DBusThreadManager with a stub implementation.
+ DBusThreadManager::InitializeWithStub();
+ message_loop_.RunUntilIdle();
+ DBusThreadManager::Get()->GetShillServiceClient()->GetTestInterface()
+ ->ClearServices();
+ message_loop_.RunUntilIdle();
+ NetworkStateHandler::Initialize();
+ NetworkConfigurationHandler::Initialize();
+ NetworkConnectionHandler::Initialize();
+ }
+
+ virtual void TearDown() OVERRIDE {
+ NetworkConnectionHandler::Shutdown();
+ NetworkConfigurationHandler::Shutdown();
+ NetworkStateHandler::Shutdown();
+ DBusThreadManager::Shutdown();
+ }
+
+ protected:
+ bool Configure(const std::string& json_string) {
+ scoped_ptr<base::DictionaryValue> json_dict =
+ onc::ReadDictionaryFromJson(json_string);
+ if (!json_dict) {
+ LOG(ERROR) << "Error parsing json: " << json_string;
+ return false;
+ }
+ DBusThreadManager::Get()->GetShillManagerClient()->ConfigureService(
+ *json_dict,
+ ObjectPathCallback(), ShillManagerClient::ErrorCallback());
+ message_loop_.RunUntilIdle();
+ return true;
+ }
+
+ void Connect(const std::string& service_path) {
+ NetworkConnectionHandler::Get()->ConnectToNetwork(
+ service_path,
+ base::Bind(&NetworkConnectionHandlerTest::SuccessCallback,
+ base::Unretained(this)),
+ base::Bind(&NetworkConnectionHandlerTest::ErrorCallback,
+ base::Unretained(this)));
+ message_loop_.RunUntilIdle();
+ }
+
+ void Disconnect(const std::string& service_path) {
+ NetworkConnectionHandler::Get()->DisconnectNetwork(
+ service_path,
+ base::Bind(&NetworkConnectionHandlerTest::SuccessCallback,
+ base::Unretained(this)),
+ base::Bind(&NetworkConnectionHandlerTest::ErrorCallback,
+ base::Unretained(this)));
+ message_loop_.RunUntilIdle();
+ }
+
+ void SuccessCallback() {
+ result_ = kSuccessResult;
+ }
+
+ void ErrorCallback(const std::string& error_name,
+ scoped_ptr<base::DictionaryValue> error_data) {
+ result_ = error_name;
+ }
+
+ std::string GetResultAndReset() {
+ std::string result;
+ result.swap(result_);
+ return result;
+ }
+
+ std::string GetServiceStringProperty(const std::string& service_path,
+ const std::string& key) {
+ std::string result;
+ const base::DictionaryValue* properties =
+ DBusThreadManager::Get()->GetShillServiceClient()->GetTestInterface()->
+ GetServiceProperties(service_path);
+ if (properties)
+ properties->GetStringWithoutPathExpansion(key, &result);
+ return result;
+ }
+
+ MessageLoopForUI message_loop_;
+ std::string result_;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(NetworkConnectionHandlerTest);
+};
+
+namespace {
+
+const char* kConfigConnectable =
+ "{ \"GUID\": \"wifi0\", \"Type\": \"wifi\", \"State\": \"idle\" }";
+const char* kConfigConnected =
+ "{ \"GUID\": \"wifi1\", \"Type\": \"wifi\", \"State\": \"online\" }";
+const char* kConfigConnecting =
+ "{ \"GUID\": \"wifi2\", \"Type\": \"wifi\", \"State\": \"association\" }";
+const char* kConfigRequiresPassphrase =
+ "{ \"GUID\": \"wifi3\", \"Type\": \"wifi\", "
+ "\"PassphraseRequired\": true }";
+const char* kConfigRequiresActivation =
+ "{ \"GUID\": \"cellular1\", \"Type\": \"cellular\","
+ " \"Cellular.ActivationState\": \"not-activated\" }";
+
+} // namespace
+
+TEST_F(NetworkConnectionHandlerTest, NetworkConnectionHandlerConnectSuccess) {
+ EXPECT_TRUE(Configure(kConfigConnectable));
+ Connect("wifi0");
+ EXPECT_EQ(kSuccessResult, GetResultAndReset());
+ EXPECT_EQ(flimflam::kStateOnline,
+ GetServiceStringProperty("wifi0", flimflam::kStateProperty));
+}
+
+// Handles basic failure cases.
+TEST_F(NetworkConnectionHandlerTest, NetworkConnectionHandlerConnectFailure) {
+ Connect("no-network");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorNotFound, GetResultAndReset());
+
+ EXPECT_TRUE(Configure(kConfigConnected));
+ Connect("wifi1");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorConnected, GetResultAndReset());
+
+ EXPECT_TRUE(Configure(kConfigConnecting));
+ Connect("wifi2");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorConnecting, GetResultAndReset());
+
+ EXPECT_TRUE(Configure(kConfigRequiresPassphrase));
+ Connect("wifi3");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorPassphraseRequired,
+ GetResultAndReset());
+
+ EXPECT_TRUE(Configure(kConfigRequiresActivation));
+ Connect("cellular1");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorActivationRequired,
+ GetResultAndReset());
+}
+
+namespace {
+
+const char* kConfigRequiresCertificate =
+ "{ \"GUID\": \"wifi4\", \"Type\": \"wifi\", \"Connectable\": false,"
+ " \"Security\": \"802_1x\","
+ " \"UIData\": \"{"
+ " \\\"certificate_type\\\": \\\"pattern\\\","
+ " \\\"certificate_pattern\\\": {"
+ " \\\"Subject\\\": { \\\"CommonName\\\": \\\"Foo\\\" }"
+ " } }\" }";
+
+} // namespace
+
+// Handle certificates. TODO(stevenjb): Add certificate stubs to improve
+// test coverage.
+TEST_F(NetworkConnectionHandlerTest,
+ NetworkConnectionHandlerConnectCertificate) {
+ EXPECT_TRUE(Configure(kConfigRequiresCertificate));
+ Connect("wifi4");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorCertificateRequired,
+ GetResultAndReset());
+}
+
+TEST_F(NetworkConnectionHandlerTest,
+ NetworkConnectionHandlerDisconnectSuccess) {
+ EXPECT_TRUE(Configure(kConfigConnected));
+ Disconnect("wifi1");
+ EXPECT_EQ(kSuccessResult, GetResultAndReset());
+}
+
+TEST_F(NetworkConnectionHandlerTest,
+ NetworkConnectionHandlerDisconnectFailure) {
+ Connect("no-network");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorNotFound, GetResultAndReset());
+
+ EXPECT_TRUE(Configure(kConfigConnectable));
+ Disconnect("wifi0");
+ EXPECT_EQ(NetworkConnectionHandler::kErrorNotConnected, GetResultAndReset());
+}
+
+} // namespace chromeos