Commit 88f4fec3 authored by Jdragon's avatar Jdragon Committed by Commit Bot

Skip password_manager_util in credential unittests

This patch means skip password_manager_utils
by creating one instance of that cleaner
and using a mock CredentialsCleaner::Observer.

Bug: 889983
Change-Id: I246133064540887c06104c85c97fad1ba7b7aed9
Reviewed-on: https://chromium-review.googlesource.com/c/1257495Reviewed-by: default avatarVaclav Brozek <vabr@chromium.org>
Commit-Queue: Jaeyong Bae <jdragon.bae@gmail.com>
Cr-Commit-Position: refs/heads/master@{#596521}
parent 837b3c20
...@@ -4,7 +4,6 @@ ...@@ -4,7 +4,6 @@
#include "components/password_manager/core/browser/blacklisted_duplicates_cleaner.h" #include "components/password_manager/core/browser/blacklisted_duplicates_cleaner.h"
#include "base/bind_helpers.h"
#include "base/stl_util.h" #include "base/stl_util.h"
#include "base/test/metrics/histogram_tester.h" #include "base/test/metrics/histogram_tester.h"
#include "base/test/scoped_task_environment.h" #include "base/test/scoped_task_environment.h"
...@@ -13,10 +12,21 @@ ...@@ -13,10 +12,21 @@
#include "components/password_manager/core/common/password_manager_pref_names.h" #include "components/password_manager/core/common/password_manager_pref_names.h"
#include "components/prefs/pref_registry_simple.h" #include "components/prefs/pref_registry_simple.h"
#include "components/prefs/testing_pref_service.h" #include "components/prefs/testing_pref_service.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h" #include "testing/gtest/include/gtest/gtest.h"
namespace password_manager { namespace password_manager {
class MockCredentialsCleanerObserver : public CredentialsCleaner::Observer {
public:
MockCredentialsCleanerObserver() = default;
~MockCredentialsCleanerObserver() override = default;
MOCK_METHOD0(CleaningCompleted, void());
private:
DISALLOW_COPY_AND_ASSIGN(MockCredentialsCleanerObserver);
};
class BlacklistedDuplicatesCleanerTest : public ::testing::Test { class BlacklistedDuplicatesCleanerTest : public ::testing::Test {
public: public:
BlacklistedDuplicatesCleanerTest() = default; BlacklistedDuplicatesCleanerTest() = default;
...@@ -88,8 +98,11 @@ TEST_F(BlacklistedDuplicatesCleanerTest, RemoveBlacklistedDuplicates) { ...@@ -88,8 +98,11 @@ TEST_F(BlacklistedDuplicatesCleanerTest, RemoveBlacklistedDuplicates) {
prefs()->registry()->RegisterBooleanPref( prefs()->registry()->RegisterBooleanPref(
prefs::kCredentialsWithWrongSignonRealmRemoved, true); prefs::kCredentialsWithWrongSignonRealmRemoved, true);
password_manager_util::RemoveUselessCredentials(store(), prefs(), 0, MockCredentialsCleanerObserver observer;
base::NullCallback()); auto cleaner =
std::make_unique<BlacklistedDuplicatesCleaner>(store(), prefs());
EXPECT_CALL(observer, CleaningCompleted);
cleaner->StartCleaning(&observer);
scoped_task_environment.RunUntilIdle(); scoped_task_environment.RunUntilIdle();
// Check that one of the next two forms was removed. // Check that one of the next two forms was removed.
...@@ -101,8 +114,9 @@ TEST_F(BlacklistedDuplicatesCleanerTest, RemoveBlacklistedDuplicates) { ...@@ -101,8 +114,9 @@ TEST_F(BlacklistedDuplicatesCleanerTest, RemoveBlacklistedDuplicates) {
EXPECT_FALSE( EXPECT_FALSE(
prefs()->GetBoolean(prefs::kDuplicatedBlacklistedCredentialsRemoved)); prefs()->GetBoolean(prefs::kDuplicatedBlacklistedCredentialsRemoved));
password_manager_util::RemoveUselessCredentials(store(), prefs(), 0, cleaner = std::make_unique<BlacklistedDuplicatesCleaner>(store(), prefs());
base::NullCallback()); EXPECT_CALL(observer, CleaningCompleted);
cleaner->StartCleaning(&observer);
scoped_task_environment.RunUntilIdle(); scoped_task_environment.RunUntilIdle();
EXPECT_TRUE( EXPECT_TRUE(
prefs()->GetBoolean(prefs::kDuplicatedBlacklistedCredentialsRemoved)); prefs()->GetBoolean(prefs::kDuplicatedBlacklistedCredentialsRemoved));
......
...@@ -4,7 +4,6 @@ ...@@ -4,7 +4,6 @@
#include "components/password_manager/core/browser/invalid_realm_credential_cleaner.h" #include "components/password_manager/core/browser/invalid_realm_credential_cleaner.h"
#include "base/bind_helpers.h"
#include "base/stl_util.h" #include "base/stl_util.h"
#include "base/strings/utf_string_conversions.h" #include "base/strings/utf_string_conversions.h"
#include "base/test/scoped_task_environment.h" #include "base/test/scoped_task_environment.h"
...@@ -13,6 +12,7 @@ ...@@ -13,6 +12,7 @@
#include "components/password_manager/core/common/password_manager_pref_names.h" #include "components/password_manager/core/common/password_manager_pref_names.h"
#include "components/prefs/pref_registry_simple.h" #include "components/prefs/pref_registry_simple.h"
#include "components/prefs/testing_pref_service.h" #include "components/prefs/testing_pref_service.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h" #include "testing/gtest/include/gtest/gtest.h"
namespace password_manager { namespace password_manager {
...@@ -54,11 +54,6 @@ const GURL kOrigins[] = {GURL("https://example.org/path-0/"), ...@@ -54,11 +54,6 @@ const GURL kOrigins[] = {GURL("https://example.org/path-0/"),
const base::string16 kUsernames[] = {base::ASCIIToUTF16("user0"), const base::string16 kUsernames[] = {base::ASCIIToUTF16("user0"),
base::ASCIIToUTF16("user1")}; base::ASCIIToUTF16("user1")};
// TODO(http://crbug.com/889983): This callback is needed to be passed to
// function that does the clean-up, but is not used. Remove it once the function
// is skipped.
auto null_callback = base::NullCallback();
bool StoreContains(TestPasswordStore* store, bool StoreContains(TestPasswordStore* store,
const autofill::PasswordForm& form) { const autofill::PasswordForm& form) {
const auto it = store->stored_passwords().find(form.signon_realm); const auto it = store->stored_passwords().find(form.signon_realm);
...@@ -93,6 +88,16 @@ MigrationFormsPair GetCredentialsFrom(bool is_blacklisted, ...@@ -93,6 +88,16 @@ MigrationFormsPair GetCredentialsFrom(bool is_blacklisted,
} // namespace } // namespace
class MockCredentialsCleanerObserver : public CredentialsCleaner::Observer {
public:
MockCredentialsCleanerObserver() = default;
~MockCredentialsCleanerObserver() override = default;
MOCK_METHOD0(CleaningCompleted, void());
private:
DISALLOW_COPY_AND_ASSIGN(MockCredentialsCleanerObserver);
};
// This test checks that HTML credentials are correctly removed for the case // This test checks that HTML credentials are correctly removed for the case
// when both (HTTP and HTTPS credentials) are blacklisted, or both are not // when both (HTTP and HTTPS credentials) are blacklisted, or both are not
// blacklsited. // blacklsited.
...@@ -218,8 +223,10 @@ TEST(InvalidRealmCredentialCleanerTest, ...@@ -218,8 +223,10 @@ TEST(InvalidRealmCredentialCleanerTest,
prefs.registry()->RegisterBooleanPref( prefs.registry()->RegisterBooleanPref(
prefs::kCredentialsWithWrongSignonRealmRemoved, false); prefs::kCredentialsWithWrongSignonRealmRemoved, false);
password_manager_util::RemoveUselessCredentials(password_store, &prefs, 0, MockCredentialsCleanerObserver observer;
null_callback); InvalidRealmCredentialCleaner cleaner(password_store, &prefs);
EXPECT_CALL(observer, CleaningCompleted);
cleaner.StartCleaning(&observer);
scoped_task_environment.RunUntilIdle(); scoped_task_environment.RunUntilIdle();
EXPECT_EQ(StoreContains(password_store.get(), https_form), EXPECT_EQ(StoreContains(password_store.get(), https_form),
...@@ -358,8 +365,10 @@ TEST(InvalidRealmCredentialCleanerTest, ...@@ -358,8 +365,10 @@ TEST(InvalidRealmCredentialCleanerTest,
prefs.registry()->RegisterBooleanPref( prefs.registry()->RegisterBooleanPref(
prefs::kCredentialsWithWrongSignonRealmRemoved, false); prefs::kCredentialsWithWrongSignonRealmRemoved, false);
password_manager_util::RemoveUselessCredentials(password_store, &prefs, 0, MockCredentialsCleanerObserver observer;
null_callback); InvalidRealmCredentialCleaner cleaner(password_store, &prefs);
EXPECT_CALL(observer, CleaningCompleted);
cleaner.StartCleaning(&observer);
scoped_task_environment.RunUntilIdle(); scoped_task_environment.RunUntilIdle();
EXPECT_NE(StoreContains(password_store.get(), https_form), EXPECT_NE(StoreContains(password_store.get(), https_form),
...@@ -398,8 +407,10 @@ TEST(InvalidRealmCredentialCleanerTest, ...@@ -398,8 +407,10 @@ TEST(InvalidRealmCredentialCleanerTest,
prefs.registry()->RegisterBooleanPref( prefs.registry()->RegisterBooleanPref(
prefs::kCredentialsWithWrongSignonRealmRemoved, false); prefs::kCredentialsWithWrongSignonRealmRemoved, false);
password_manager_util::RemoveUselessCredentials(password_store, &prefs, 0, MockCredentialsCleanerObserver observer;
null_callback); InvalidRealmCredentialCleaner cleaner(password_store, &prefs);
EXPECT_CALL(observer, CleaningCompleted);
cleaner.StartCleaning(&observer);
scoped_task_environment.RunUntilIdle(); scoped_task_environment.RunUntilIdle();
// Check that credentials were not deleted. // Check that credentials were not deleted.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment