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

Unified Diff: chromeos/components/tether/initializer_unittest.cc

Issue 2801353002: [CrOS Tether] Fill out the Initializer class. Tether will now initialize fully once the flag is ena… (Closed)
Patch Set: Added missing dep. Created 3 years, 8 months 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 | « chromeos/components/tether/initializer.cc ('k') | chromeos/components/tether/local_device_data_provider.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chromeos/components/tether/initializer_unittest.cc
diff --git a/chromeos/components/tether/initializer_unittest.cc b/chromeos/components/tether/initializer_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..aae57a86a3dbf716bd3ec558eeaed7762de33cbf
--- /dev/null
+++ b/chromeos/components/tether/initializer_unittest.cc
@@ -0,0 +1,180 @@
+// Copyright 2017 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/components/tether/initializer.h"
+
+#include <memory>
+
+#include "base/memory/ptr_util.h"
+#include "base/message_loop/message_loop.h"
+#include "base/test/scoped_task_environment.h"
+#include "chromeos/components/tether/active_host.h"
+#include "chromeos/components/tether/fake_notification_presenter.h"
+#include "chromeos/components/tether/host_scan_device_prioritizer.h"
+#include "chromeos/dbus/dbus_thread_manager.h"
+#include "chromeos/network/network_connect.h"
+#include "chromeos/network/network_handler.h"
+#include "chromeos/network/network_state_test.h"
+#include "components/cryptauth/cryptauth_device_manager.h"
+#include "components/cryptauth/cryptauth_enroller.h"
+#include "components/cryptauth/cryptauth_enrollment_manager.h"
+#include "components/cryptauth/fake_cryptauth_gcm_manager.h"
+#include "components/cryptauth/fake_cryptauth_service.h"
+#include "components/cryptauth/proto/cryptauth_api.pb.h"
+#include "components/cryptauth/secure_message_delegate.h"
+#include "components/prefs/testing_pref_service.h"
+#include "components/signin/core/browser/fake_profile_oauth2_token_service.h"
+#include "device/bluetooth/test/mock_bluetooth_adapter.h"
+#include "testing/gmock/include/gmock/gmock.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "third_party/cros_system_api/dbus/shill/dbus-constants.h"
+
+using testing::NiceMock;
+
+namespace chromeos {
+
+namespace tether {
+
+namespace {
+
+class MockCryptAuthDeviceManager : public cryptauth::CryptAuthDeviceManager {
+ public:
+ ~MockCryptAuthDeviceManager() override {}
+
+ MOCK_CONST_METHOD0(GetTetherHosts,
+ std::vector<cryptauth::ExternalDeviceInfo>());
+};
+
+class MockCryptAuthEnrollmentManager
+ : public cryptauth::CryptAuthEnrollmentManager {
+ public:
+ explicit MockCryptAuthEnrollmentManager(
+ cryptauth::FakeCryptAuthGCMManager* fake_cryptauth_gcm_manager)
+ : cryptauth::CryptAuthEnrollmentManager(
+ nullptr /* clock */,
+ nullptr /* enroller_factory */,
+ nullptr /* secure_message_delegate */,
+ cryptauth::GcmDeviceInfo(),
+ fake_cryptauth_gcm_manager,
+ nullptr /* pref_service */) {}
+ ~MockCryptAuthEnrollmentManager() override {}
+
+ MOCK_CONST_METHOD0(GetUserPrivateKey, std::string());
+};
+
+class MockNetworkConnect : public NetworkConnect {
+ public:
+ MockNetworkConnect() : NetworkConnect() {}
+ ~MockNetworkConnect() override {}
+
+ MOCK_METHOD1(ConnectToNetworkId, void(const std::string&));
+ MOCK_METHOD1(DisconnectFromNetworkId, void(const std::string&));
+ MOCK_METHOD2(MaybeShowConfigureUI,
+ bool(const std::string&, const std::string&));
+ MOCK_METHOD2(SetTechnologyEnabled,
+ void(const chromeos::NetworkTypePattern&, bool));
+ MOCK_METHOD1(ShowMobileSetup, void(const std::string&));
+ MOCK_METHOD3(ConfigureNetworkIdAndConnect,
+ void(const std::string&, const base::DictionaryValue&, bool));
+ MOCK_METHOD2(CreateConfigurationAndConnect,
+ void(base::DictionaryValue*, bool));
+ MOCK_METHOD2(CreateConfiguration, void(base::DictionaryValue*, bool));
+ MOCK_METHOD1(SetTetherDelegate, void(NetworkConnect::TetherDelegate*));
+};
+
+} // namespace
+
+class InitializerTest : public NetworkStateTest {
+ protected:
+ InitializerTest() : NetworkStateTest() {}
+ ~InitializerTest() override {}
+
+ void SetUp() override {
+ DBusThreadManager::Initialize();
+ NetworkHandler::Initialize();
+ NetworkStateTest::SetUp();
+
+ test_pref_service_ = base::MakeUnique<TestingPrefServiceSimple>();
+ HostScanDevicePrioritizer::RegisterPrefs(test_pref_service_->registry());
+ ActiveHost::RegisterPrefs(test_pref_service_->registry());
+ }
+
+ void TearDown() override {
+ ShutdownNetworkState();
+ NetworkStateTest::TearDown();
+ DBusThreadManager::Shutdown();
+ }
+
+ void InitializeAndDestroy(
+ cryptauth::CryptAuthService* cryptauth_service,
+ std::unique_ptr<NotificationPresenter> notification_presenter,
+ PrefService* pref_service,
+ ProfileOAuth2TokenService* token_service,
+ NetworkStateHandler* network_state_handler,
+ NetworkConnect* network_connect,
+ scoped_refptr<device::BluetoothAdapter> adapter) {
+ Initializer* initializer = new Initializer(
+ cryptauth_service, std::move(notification_presenter), pref_service,
+ token_service, network_state_handler, network_connect);
+ initializer->OnBluetoothAdapterAdvertisingIntervalSet(adapter);
+ delete initializer;
+ }
+
+ base::test::ScopedTaskEnvironment scoped_task_environment_;
+
+ std::unique_ptr<TestingPrefServiceSimple> test_pref_service_;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(InitializerTest);
+};
+
+// This test ensures that Initializer's destructor runs in the correct order and
+// results in a correct clean-up of all created components. If the destructor
+// were to result in an error being thrown, this test would fail.
+TEST_F(InitializerTest, TestCreateAndDestroy) {
+ std::unique_ptr<NiceMock<MockCryptAuthDeviceManager>> mock_device_manager =
+ base::WrapUnique(new NiceMock<MockCryptAuthDeviceManager>());
+
+ std::unique_ptr<cryptauth::FakeCryptAuthGCMManager>
+ fake_cryptauth_gcm_manager =
+ base::MakeUnique<cryptauth::FakeCryptAuthGCMManager>(
+ "registrationId");
+
+ std::unique_ptr<NiceMock<MockCryptAuthEnrollmentManager>>
+ mock_enrollment_manager =
+ base::WrapUnique(new NiceMock<MockCryptAuthEnrollmentManager>(
+ fake_cryptauth_gcm_manager.get()));
+
+ std::unique_ptr<cryptauth::FakeCryptAuthService> fake_cryptauth_service =
+ base::MakeUnique<cryptauth::FakeCryptAuthService>();
+ fake_cryptauth_service->set_cryptauth_device_manager(
+ mock_device_manager.get());
+ fake_cryptauth_service->set_cryptauth_enrollment_manager(
+ mock_enrollment_manager.get());
+
+ std::unique_ptr<TestingPrefServiceSimple> test_pref_service =
+ base::MakeUnique<TestingPrefServiceSimple>();
+
+ std::unique_ptr<FakeProfileOAuth2TokenService> fake_token_service =
+ base::MakeUnique<FakeProfileOAuth2TokenService>();
+
+ std::unique_ptr<MockNetworkConnect> mock_network_connect =
+ base::WrapUnique(new NiceMock<MockNetworkConnect>);
+
+ scoped_refptr<NiceMock<device::MockBluetoothAdapter>> mock_adapter =
+ make_scoped_refptr(new NiceMock<device::MockBluetoothAdapter>());
+
+ // Call an instance method of the test instead of initializing and destroying
+ // here because the friend relationship between Initializer and
+ // InitializerTest only applies to the class itself, not these test functions.
+ InitializeAndDestroy(fake_cryptauth_service.get(),
+ base::MakeUnique<FakeNotificationPresenter>(),
+ test_pref_service_.get(), fake_token_service.get(),
+ network_state_handler(), mock_network_connect.get(),
+ mock_adapter);
+}
+
+} // namespace tether
+
+} // namespace chromeos
« no previous file with comments | « chromeos/components/tether/initializer.cc ('k') | chromeos/components/tether/local_device_data_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698