Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chromeos/network/network_connection_handler.h" | 5 #include "chromeos/network/network_connection_handler.h" |
| 6 | 6 |
| 7 #include <map> | 7 #include <map> |
| 8 #include <memory> | 8 #include <memory> |
| 9 #include <set> | 9 #include <set> |
| 10 | 10 |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/callback.h" | 12 #include "base/callback.h" |
| 13 #include "base/files/file_util.h" | 13 #include "base/files/file_util.h" |
| 14 #include "base/json/json_reader.h" | 14 #include "base/json/json_reader.h" |
| 15 #include "base/macros.h" | 15 #include "base/macros.h" |
| 16 #include "base/message_loop/message_loop.h" | 16 #include "base/message_loop/message_loop.h" |
| 17 #include "base/run_loop.h" | 17 #include "base/run_loop.h" |
| 18 #include "base/strings/stringprintf.h" | 18 #include "base/strings/stringprintf.h" |
| 19 #include "base/test/scoped_task_scheduler.h" | |
| 19 #include "chromeos/cert_loader.h" | 20 #include "chromeos/cert_loader.h" |
| 20 #include "chromeos/dbus/dbus_thread_manager.h" | 21 #include "chromeos/dbus/dbus_thread_manager.h" |
| 21 #include "chromeos/dbus/shill_device_client.h" | 22 #include "chromeos/dbus/shill_device_client.h" |
| 22 #include "chromeos/dbus/shill_manager_client.h" | 23 #include "chromeos/dbus/shill_manager_client.h" |
| 23 #include "chromeos/dbus/shill_profile_client.h" | 24 #include "chromeos/dbus/shill_profile_client.h" |
| 24 #include "chromeos/dbus/shill_service_client.h" | 25 #include "chromeos/dbus/shill_service_client.h" |
| 25 #include "chromeos/network/managed_network_configuration_handler_impl.h" | 26 #include "chromeos/network/managed_network_configuration_handler_impl.h" |
| 26 #include "chromeos/network/network_configuration_handler.h" | 27 #include "chromeos/network/network_configuration_handler.h" |
| 27 #include "chromeos/network/network_connection_observer.h" | 28 #include "chromeos/network/network_connection_observer.h" |
| 28 #include "chromeos/network/network_profile_handler.h" | 29 #include "chromeos/network/network_profile_handler.h" |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 92 std::map<std::string, std::string> results_; | 93 std::map<std::string, std::string> results_; |
| 93 | 94 |
| 94 DISALLOW_COPY_AND_ASSIGN(TestNetworkConnectionObserver); | 95 DISALLOW_COPY_AND_ASSIGN(TestNetworkConnectionObserver); |
| 95 }; | 96 }; |
| 96 | 97 |
| 97 } // namespace | 98 } // namespace |
| 98 | 99 |
| 99 class NetworkConnectionHandlerTest : public testing::Test { | 100 class NetworkConnectionHandlerTest : public testing::Test { |
| 100 public: | 101 public: |
| 101 NetworkConnectionHandlerTest() | 102 NetworkConnectionHandlerTest() |
| 102 : test_manager_client_(nullptr), test_service_client_(nullptr) {} | 103 : test_manager_client_(nullptr), |
| 104 test_service_client_(nullptr), | |
| 105 scoped_task_scheduler_(&message_loop_) {} | |
| 103 | 106 |
| 104 ~NetworkConnectionHandlerTest() override {} | 107 ~NetworkConnectionHandlerTest() override {} |
| 105 | 108 |
| 106 void SetUp() override { | 109 void SetUp() override { |
| 107 ASSERT_TRUE(test_nssdb_.is_open()); | 110 ASSERT_TRUE(test_nssdb_.is_open()); |
| 108 | 111 |
| 109 // Use the same DB for public and private slot. | 112 // Use the same DB for public and private slot. |
| 110 test_nsscertdb_.reset(new net::NSSCertDatabaseChromeOS( | 113 test_nsscertdb_.reset(new net::NSSCertDatabaseChromeOS( |
| 111 crypto::ScopedPK11Slot(PK11_ReferenceSlot(test_nssdb_.slot())), | 114 crypto::ScopedPK11Slot(PK11_ReferenceSlot(test_nssdb_.slot())), |
| 112 crypto::ScopedPK11Slot(PK11_ReferenceSlot(test_nssdb_.slot())))); | 115 crypto::ScopedPK11Slot(PK11_ReferenceSlot(test_nssdb_.slot())))); |
| 113 test_nsscertdb_->SetSlowTaskRunnerForTest(message_loop_.task_runner()); | |
| 114 | 116 |
| 115 CertLoader::Initialize(); | 117 CertLoader::Initialize(); |
| 116 CertLoader::ForceHardwareBackedForTesting(); | 118 CertLoader::ForceHardwareBackedForTesting(); |
| 117 | 119 |
| 118 DBusThreadManager::Initialize(); | 120 DBusThreadManager::Initialize(); |
| 119 DBusThreadManager* dbus_manager = DBusThreadManager::Get(); | 121 DBusThreadManager* dbus_manager = DBusThreadManager::Get(); |
| 120 test_manager_client_ = | 122 test_manager_client_ = |
| 121 dbus_manager->GetShillManagerClient()->GetTestInterface(); | 123 dbus_manager->GetShillManagerClient()->GetTestInterface(); |
| 122 test_service_client_ = | 124 test_service_client_ = |
| 123 dbus_manager->GetShillServiceClient()->GetTestInterface(); | 125 dbus_manager->GetShillServiceClient()->GetTestInterface(); |
| (...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 302 std::unique_ptr<NetworkConfigurationHandler> network_config_handler_; | 304 std::unique_ptr<NetworkConfigurationHandler> network_config_handler_; |
| 303 std::unique_ptr<NetworkConnectionHandler> network_connection_handler_; | 305 std::unique_ptr<NetworkConnectionHandler> network_connection_handler_; |
| 304 std::unique_ptr<TestNetworkConnectionObserver> network_connection_observer_; | 306 std::unique_ptr<TestNetworkConnectionObserver> network_connection_observer_; |
| 305 std::unique_ptr<ManagedNetworkConfigurationHandlerImpl> | 307 std::unique_ptr<ManagedNetworkConfigurationHandlerImpl> |
| 306 managed_config_handler_; | 308 managed_config_handler_; |
| 307 std::unique_ptr<NetworkProfileHandler> network_profile_handler_; | 309 std::unique_ptr<NetworkProfileHandler> network_profile_handler_; |
| 308 ShillManagerClient::TestInterface* test_manager_client_; | 310 ShillManagerClient::TestInterface* test_manager_client_; |
| 309 ShillServiceClient::TestInterface* test_service_client_; | 311 ShillServiceClient::TestInterface* test_service_client_; |
| 310 crypto::ScopedTestNSSDB test_nssdb_; | 312 crypto::ScopedTestNSSDB test_nssdb_; |
| 311 std::unique_ptr<net::NSSCertDatabaseChromeOS> test_nsscertdb_; | 313 std::unique_ptr<net::NSSCertDatabaseChromeOS> test_nsscertdb_; |
| 312 base::MessageLoopForUI message_loop_; | 314 base::MessageLoopForUI message_loop_; |
|
stevenjb
2017/02/03 18:01:04
It doesn't look like we use/need this at all here?
fdoray
2017/02/03 19:23:07
In theory, the test could depend on MessageLoopFor
stevenjb
2017/02/03 20:04:50
Yeah, we shouldn't need that any more for this uni
| |
| 315 base::test::ScopedTaskScheduler scoped_task_scheduler_; | |
| 313 std::string result_; | 316 std::string result_; |
| 314 | 317 |
| 315 private: | 318 private: |
| 316 DISALLOW_COPY_AND_ASSIGN(NetworkConnectionHandlerTest); | 319 DISALLOW_COPY_AND_ASSIGN(NetworkConnectionHandlerTest); |
| 317 }; | 320 }; |
| 318 | 321 |
| 319 namespace { | 322 namespace { |
| 320 | 323 |
| 321 const char* kNoNetwork = "no-network"; | 324 const char* kNoNetwork = "no-network"; |
| 322 const char* kWifi0 = "wifi0"; | 325 const char* kWifi0 = "wifi0"; |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 490 Connect(kNoNetwork); | 493 Connect(kNoNetwork); |
| 491 EXPECT_EQ(NetworkConnectionHandler::kErrorConfigureFailed, | 494 EXPECT_EQ(NetworkConnectionHandler::kErrorConfigureFailed, |
| 492 GetResultAndReset()); | 495 GetResultAndReset()); |
| 493 | 496 |
| 494 EXPECT_TRUE(Configure(kConfigConnectable)); | 497 EXPECT_TRUE(Configure(kConfigConnectable)); |
| 495 Disconnect(kWifi0); | 498 Disconnect(kWifi0); |
| 496 EXPECT_EQ(NetworkConnectionHandler::kErrorNotConnected, GetResultAndReset()); | 499 EXPECT_EQ(NetworkConnectionHandler::kErrorNotConnected, GetResultAndReset()); |
| 497 } | 500 } |
| 498 | 501 |
| 499 } // namespace chromeos | 502 } // namespace chromeos |
| OLD | NEW |