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

Unified Diff: chrome/browser/ui/webui/options/password_manager_handler_unittest.cc

Issue 1193143003: Enable import/export of passwords into/from Password Manager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: comments Created 5 years, 5 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
Index: chrome/browser/ui/webui/options/password_manager_handler_unittest.cc
diff --git a/chrome/browser/ui/webui/options/password_manager_handler_unittest.cc b/chrome/browser/ui/webui/options/password_manager_handler_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..31f2e1459b9f03779962c7842d4f60f763af0d05
--- /dev/null
+++ b/chrome/browser/ui/webui/options/password_manager_handler_unittest.cc
@@ -0,0 +1,160 @@
+// Copyright 2015 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 "base/metrics/histogram.h"
+#include "base/metrics/statistics_recorder.h"
+#include "base/strings/utf_string_conversions.h"
+#include "chrome/browser/password_manager/mock_password_store_service.h"
+#include "chrome/browser/password_manager/password_store_factory.h"
+#include "chrome/browser/ui/passwords/password_manager_presenter.h"
+#include "chrome/browser/ui/webui/options/password_manager_handler.h"
+#include "chrome/test/base/testing_profile.h"
+#include "components/password_manager/core/browser/mock_password_store.h"
+#include "content/public/test/test_browser_thread_bundle.h"
+#include "content/public/test/test_web_ui.h"
+#include "testing/gmock/include/gmock/gmock.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using password_manager::MockPasswordStore;
+
+class MockPasswordManagerPresenter : public PasswordManagerPresenter {
+ public:
+ explicit MockPasswordManagerPresenter(PasswordUIView* handler)
+ : PasswordManagerPresenter(handler) {}
+ ~MockPasswordManagerPresenter() override {}
+
+ MOCK_METHOD0(IsUserAuthenticated, bool());
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(MockPasswordManagerPresenter);
+};
+
+class DummyPasswordManagerHandler : public PasswordUIView {
+ public:
+ explicit DummyPasswordManagerHandler(Profile* profile)
+ : profile_(profile), password_manager_presenter_(this) {
+ password_manager_presenter_.Initialize();
+ }
+ ~DummyPasswordManagerHandler() override {}
+ Profile* GetProfile() override;
+
+ void ShowPassword(size_t,
+ const std::string&,
+ const std::string&,
+ const base::string16&) override {}
+ void SetPasswordList(const ScopedVector<autofill::PasswordForm>&,
+ bool) override {}
+ void SetPasswordExceptionList(
+ const ScopedVector<autofill::PasswordForm>&) override {}
+
+#if !defined(OS_ANDROID)
+ gfx::NativeWindow GetNativeWindow() const override;
+#endif
+ private:
+ Profile* profile_;
+ PasswordManagerPresenter password_manager_presenter_;
+ DISALLOW_COPY_AND_ASSIGN(DummyPasswordManagerHandler);
+};
+
+#if !defined(OS_ANDROID)
+gfx::NativeWindow DummyPasswordManagerHandler::GetNativeWindow() const {
+ return NULL;
+}
+#endif
+Profile* DummyPasswordManagerHandler::GetProfile() {
+ return profile_;
+}
+
+class PasswordManagerHandlerTest : public testing::Test {
+ protected:
+ PasswordManagerHandlerTest() {}
+ ~PasswordManagerHandlerTest() override {
+ delete handler_;
+ delete dummy_handler_;
+ }
+
+ void SetUp() override {
+ UMA_HISTOGRAM_COUNTS("PasswordManager.ImportedPasswordsPerUserInCSV", 0);
+ UMA_HISTOGRAM_ENUMERATION("PasswordManager.ImportPasswordFromCSVResult", 0,
+ 3);
+ PasswordStoreFactory::GetInstance()->SetTestingFactory(
+ &profile_, MockPasswordStoreService::Build);
+ dummy_handler_ = new DummyPasswordManagerHandler(&profile_);
+ handler_ = new options::PasswordManagerHandler(
+ new MockPasswordManagerPresenter(dummy_handler_));
+ handler_->set_web_ui(&web_ui_);
+ }
+
+ MockPasswordManagerPresenter* GetPresenter() {
+ return static_cast<MockPasswordManagerPresenter*>(
+ handler_->password_manager_presenter_.get());
+ }
+
+ MockPasswordStore* GetPasswordStore() {
+ return static_cast<MockPasswordStore*>(GetPresenter()->GetPasswordStore());
+ }
+
+ void ExportPassword() { handler_->HandlePasswordExport(NULL); }
+
+ void ImportPassword() {
+ autofill::PasswordForm form(MakeForm());
+ std::vector<autofill::PasswordForm> passwordForms;
+ passwordForms.push_back(form);
+ passwordForms.push_back(form);
+ handler_->ImportPasswordFileRead(
+ password_manager::PasswordImporter::SUCCESS, passwordForms);
+ }
+
+ autofill::PasswordForm MakeForm() {
+ autofill::PasswordForm form;
+ GURL origin("http://test.com");
+ form.origin = origin;
+ form.username_element = base::ASCIIToUTF16("Email");
+ form.username_value = base::ASCIIToUTF16("test@test.com");
+ form.password_element = base::ASCIIToUTF16("Password");
+ form.password_value = base::ASCIIToUTF16("abcdef");
+ return form;
+ }
+
+ private:
+ content::TestBrowserThreadBundle thread_bundle_;
+ TestingProfile profile_;
+ options::PasswordManagerHandler* handler_;
+ DummyPasswordManagerHandler* dummy_handler_;
+ content::TestWebUI web_ui_;
+
+ DISALLOW_COPY_AND_ASSIGN(PasswordManagerHandlerTest);
+};
+
+MATCHER_P(FormMatches, form, "") {
+ return form.signon_realm == arg.signon_realm && form.origin == arg.origin &&
+ form.action == arg.action &&
+ form.username_element == arg.username_element &&
+ form.password_element == arg.password_element &&
+ form.new_password_element == arg.new_password_element &&
+ form.submit_element == arg.submit_element;
+}
+
+TEST_F(PasswordManagerHandlerTest, PasswordImport) {
+ autofill::PasswordForm form(MakeForm());
+ base::HistogramBase* imported_passwords =
+ base::StatisticsRecorder::FindHistogram(
+ "PasswordManager.ImportedPasswordsPerUserInCSV");
+ base::HistogramBase* import_result_enum =
+ base::StatisticsRecorder::FindHistogram(
+ "PasswordManager.ImportPasswordFromCSVResult");
+ scoped_ptr<base::HistogramSamples> imported_count_samples(
+ imported_passwords->SnapshotSamples());
+ scoped_ptr<base::HistogramSamples> import_result_enum_samples(
+ import_result_enum->SnapshotSamples());
+ EXPECT_CALL(*GetPasswordStore(), AddLogin(FormMatches(form))).Times(2);
+ ImportPassword();
+ EXPECT_EQ(imported_count_samples->TotalCount(), 1);
+ EXPECT_EQ(import_result_enum_samples->GetCount(0), 1);
+}
+
+TEST_F(PasswordManagerHandlerTest, PasswordExport) {
+ EXPECT_CALL(*GetPresenter(), IsUserAuthenticated());
+ ExportPassword();
+}

Powered by Google App Engine
This is Rietveld 408576698