Chromium Code Reviews| Index: chrome/browser/profile_resetter/automatic_profile_resetter_unittest.cc |
| diff --git a/chrome/browser/profile_resetter/automatic_profile_resetter_unittest.cc b/chrome/browser/profile_resetter/automatic_profile_resetter_unittest.cc |
| index f71af0c8a01b4159561453e3302fb923c225bbf3..fdcdd483aa2da79eca5e9a8d28783162be04fed6 100644 |
| --- a/chrome/browser/profile_resetter/automatic_profile_resetter_unittest.cc |
| +++ b/chrome/browser/profile_resetter/automatic_profile_resetter_unittest.cc |
| @@ -4,24 +4,35 @@ |
| #include <string> |
| -#include "base/basictypes.h" |
| +#include "base/bind.h" |
| #include "base/bind_helpers.h" |
| #include "base/metrics/field_trial.h" |
| +#include "base/prefs/pref_registry_simple.h" |
| +#include "base/prefs/testing_pref_service.h" |
| #include "base/run_loop.h" |
| +#include "base/test/test_simple_task_runner.h" |
| #include "base/threading/sequenced_worker_pool.h" |
| +#include "base/values.h" |
| #include "chrome/browser/profile_resetter/automatic_profile_resetter.h" |
| +#include "chrome/browser/profile_resetter/automatic_profile_resetter_delegate.h" |
| #include "chrome/browser/profile_resetter/automatic_profile_resetter_factory.h" |
| #include "chrome/browser/profile_resetter/automatic_profile_resetter_mementos.h" |
| #include "chrome/browser/profile_resetter/jtl_foundation.h" |
| #include "chrome/browser/profile_resetter/jtl_instructions.h" |
| #include "chrome/test/base/scoped_testing_local_state.h" |
| #include "chrome/test/base/testing_browser_process.h" |
| +#include "chrome/test/base/testing_pref_service_syncable.h" |
| #include "chrome/test/base/testing_profile.h" |
| +#include "components/user_prefs/pref_registry_syncable.h" |
| #include "content/public/browser/browser_thread.h" |
| #include "content/public/test/test_browser_thread_bundle.h" |
| #include "testing/gmock/include/gmock/gmock.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| +using testing::_; |
| +using testing::Invoke; |
| +using testing::Return; |
| + |
| namespace { |
| const char kAutomaticProfileResetStudyName[] = "AutomaticProfileReset"; |
| @@ -33,17 +44,122 @@ const char kTestHashSeed[] = "testing-hash-seed"; |
| const char kTestMementoValue[] = "01234567890123456789012345678901"; |
| const char kTestInvalidMementoValue[] = "12345678901234567890123456789012"; |
| +const char kTestPreferencePath[] = "testing.preference"; |
| +const char kTestPreferenceValue[] = "testing-preference-value"; |
| + |
| +const char kSearchURLAttributeKey[] = "search_url"; |
| +const char kTestSearchURL[] = "http://example.com/search?q={searchTerms}"; |
| +const char kTestSearchURL2[] = "http://google.com/?q={searchTerms}"; |
| + |
| +const char kTestModuleDigest[] = "01234567890123456789012345678901"; |
| +const char kTestModuleDigest2[] = "12345678901234567890123456789012"; |
| + |
| // Helpers ------------------------------------------------------------------ |
| +// A testing version of the AutomaticProfileResetter that differs from the real |
| +// one only in that it has its statistics reporting mocked out for verification. |
| +class AutomaticProfileResetterUnderTest : public AutomaticProfileResetter { |
| + public: |
| + explicit AutomaticProfileResetterUnderTest(Profile* profile) |
| + : AutomaticProfileResetter(profile) {} |
| + virtual ~AutomaticProfileResetterUnderTest() {} |
| + |
| + MOCK_METHOD2(ReportStatistics, void(uint32, uint32)); |
| + |
| + private: |
| + DISALLOW_COPY_AND_ASSIGN(AutomaticProfileResetterUnderTest); |
| +}; |
| + |
| class MockProfileResetterDelegate : public AutomaticProfileResetterDelegate { |
| public: |
| - MockProfileResetterDelegate() {} |
| + MockProfileResetterDelegate() |
| + : emulated_default_search_provider_is_managed_(false) {} |
| virtual ~MockProfileResetterDelegate() {} |
| + MOCK_METHOD0(EnumerateLoadedModulesIfNeeded, void()); |
| + MOCK_CONST_METHOD1(RequestCallbackWhenLoadedModulesAreEnumerated, |
| + void(const base::Closure&)); |
| + |
| + MOCK_METHOD0(LoadTemplateURLServiceIfNeeded, void()); |
| + MOCK_CONST_METHOD1(RequestCallbackWhenTemplateURLServiceIsLoaded, |
| + void(const base::Closure&)); |
| + |
| + MOCK_CONST_METHOD0(IsDefaultSearchProviderManaged, bool()); |
| + |
| + // GMock does not support the return type of scoped_ptr<> because scoped_ptr |
| + // is not copyable. This is a workaround which defines a "Mock" version for |
| + // each problematic function, and makes the original version call the mocked |
| + // method. Use the "Mock" versions for setting/testing expectations. |
|
Peter Kasting
2013/10/16 00:40:21
Is it possible to avoid GMock entirely and just us
engedy
2013/10/16 11:13:54
I got rid of these 3 abominations below and made t
|
| + |
| + MOCK_CONST_METHOD0(GetLoadedModuleNameDigestsMock, base::ListValue*()); |
| + virtual scoped_ptr<base::ListValue> GetLoadedModuleNameDigests() const { |
| + return scoped_ptr<base::ListValue>(GetLoadedModuleNameDigestsMock()); |
| + } |
| + |
| + MOCK_CONST_METHOD0(GetDefaultSearchProviderDetailsMock, |
| + base::DictionaryValue*()); |
| + virtual scoped_ptr<base::DictionaryValue> |
| + GetDefaultSearchProviderDetails() const { |
| + return scoped_ptr<base::DictionaryValue>( |
| + GetDefaultSearchProviderDetailsMock()); |
| + } |
| + |
| + MOCK_CONST_METHOD0(GetPrepopulatedSearchProvidersDetailsMock, |
| + base::ListValue*()); |
| + virtual scoped_ptr<base::ListValue> |
| + GetPrepopulatedSearchProvidersDetails() const { |
| + return scoped_ptr<base::ListValue>( |
| + GetPrepopulatedSearchProvidersDetailsMock()); |
| + } |
| + |
| MOCK_METHOD0(ShowPrompt, void()); |
| - MOCK_METHOD2(ReportStatistics, void(uint32, uint32)); |
| + |
| + static void ClosureInvoker(const base::Closure& closure) { closure.Run(); } |
| + |
| + void ExpectCallsToDependenciesSetUpMethods() { |
| + EXPECT_CALL(*this, EnumerateLoadedModulesIfNeeded()); |
| + EXPECT_CALL(*this, LoadTemplateURLServiceIfNeeded()); |
| + EXPECT_CALL(*this, RequestCallbackWhenLoadedModulesAreEnumerated(_)) |
| + .WillOnce(Invoke(ClosureInvoker)); |
| + EXPECT_CALL(*this, RequestCallbackWhenTemplateURLServiceIsLoaded(_)) |
| + .WillOnce(Invoke(ClosureInvoker)); |
| + } |
| + |
| + void ExpectCallsToGetterMethods() { |
| + EXPECT_CALL(*this, GetDefaultSearchProviderDetailsMock()) |
| + .WillRepeatedly(Invoke(&emulated_default_search_provider_details_, |
| + &base::DictionaryValue::DeepCopy)); |
| + EXPECT_CALL(*this, IsDefaultSearchProviderManaged()) |
| + .WillRepeatedly(Return(emulated_default_search_provider_is_managed_)); |
| + EXPECT_CALL(*this, GetPrepopulatedSearchProvidersDetailsMock()) |
| + .WillRepeatedly(Invoke(&emulated_search_providers_details_, |
| + &base::ListValue::DeepCopy)); |
| + EXPECT_CALL(*this, GetLoadedModuleNameDigestsMock()).WillRepeatedly( |
| + Invoke(&emulated_loaded_module_digests_, &base::ListValue::DeepCopy)); |
| + } |
| + |
| + base::DictionaryValue& emulated_default_search_provider_details() { |
| + return emulated_default_search_provider_details_; |
| + } |
| + |
| + base::ListValue& emulated_search_providers_details() { |
| + return emulated_search_providers_details_; |
| + } |
| + |
| + base::ListValue& emulated_loaded_module_digests() { |
| + return emulated_loaded_module_digests_; |
| + } |
| + |
| + void set_emulated_default_search_provider_is_managed(bool value) { |
| + emulated_default_search_provider_is_managed_ = value; |
| + } |
| private: |
| + base::DictionaryValue emulated_default_search_provider_details_; |
| + base::ListValue emulated_search_providers_details_; |
| + base::ListValue emulated_loaded_module_digests_; |
| + bool emulated_default_search_provider_is_managed_; |
| + |
| DISALLOW_COPY_AND_ASSIGN(MockProfileResetterDelegate); |
| }; |
| @@ -79,8 +195,8 @@ std::string GetHash(const std::string& input) { |
| // Encodes a Boolean argument value into JTL bytecode. |
| std::string EncodeBool(bool value) { return value ? VALUE_TRUE : VALUE_FALSE; } |
| -// Constructs a simple evaluation program to test that input/output works well. |
| -// It will emulate a scenario in which the reset criteria are satisfied as |
| +// Constructs a simple evaluation program to test that basic input/output works |
| +// well. It will emulate a scenario in which the reset criteria are satisfied as |
| // prescribed by |emulate_satisfied_criterion_{1|2}|, and will set bits in the |
| // combined status mask according to whether or not the memento values received |
| // in the input were as expected. |
| @@ -142,26 +258,192 @@ std::string ConstructProgram(bool emulate_satisfied_criterion_1, |
| return bytecode; |
| } |
| +// Constructs another evaluation program to specifically test that local state |
| +// and user preference values are included in the input as expected. We will |
| +// re-purpose the output bitmasks to channel out information about the outcome |
| +// of the checks. |
| +// |
| +// More specifically, the output of the program will be as follows: |
| +// { |
| +// "combined_status_mask_bit1": |
| +// (input["preferences.testing.preference"] == kTestPreferenceValue) |
| +// "combined_status_mask_bit2": |
| +// (input["local_state.testing.preference"] == kTestPreferenceValue) |
| +// "combined_status_mask_bit3": input["preferences_iuc.testing.preference"] |
| +// "combined_status_mask_bit4": input["local_state_iuc.testing.preference"] |
| +// } |
| +std::string ConstructProgramToCheckPreferences() { |
| + std::string bytecode; |
| + bytecode += OP_NAVIGATE(GetHash("preferences")); |
| + bytecode += OP_NAVIGATE(GetHash("testing")); |
| + bytecode += OP_NAVIGATE(GetHash("preference")); |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestPreferenceValue)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit1"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("local_state")); |
| + bytecode += OP_NAVIGATE(GetHash("testing")); |
| + bytecode += OP_NAVIGATE(GetHash("preference")); |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestPreferenceValue)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit2"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("preferences_iuc")); |
| + bytecode += OP_NAVIGATE(GetHash("testing")); |
| + bytecode += OP_NAVIGATE(GetHash("preference")); |
| + bytecode += OP_COMPARE_NODE_BOOL(EncodeBool(true)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit3"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("local_state_iuc")); |
| + bytecode += OP_NAVIGATE(GetHash("testing")); |
| + bytecode += OP_NAVIGATE(GetHash("preference")); |
| + bytecode += OP_COMPARE_NODE_BOOL(EncodeBool(true)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit4"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + return bytecode; |
| +} |
| + |
| +// Legend for the bitmask returned by the above program. |
| +enum CombinedStatusMaskLegendForCheckingPreferences { |
| + HAS_EXPECTED_USER_PREFERENCE = 1 << 0, |
| + HAS_EXPECTED_LOCAL_STATE_PREFERENCE = 1 << 1, |
| + USER_PREFERENCE_IS_USER_CONTROLLED = 1 << 2, |
| + LOCAL_STATE_IS_USER_CONTROLLED = 1 << 3, |
| +}; |
| + |
| +// Constructs yet another evaluation program to specifically test that default |
| +// and pre-populated search engines are included in the input as expected. We |
| +// will re-purpose the output bitmasks to channel out information about the |
| +// outcome of the checks. |
| +// |
| +// More specifically, the output of the program will be as follows: |
| +// { |
| +// "combined_status_mask_bit1": |
| +// (input["default_search_provider.search_url"] == kTestSearchURL) |
| +// "combined_status_mask_bit2": input["default_search_provider_iuc"] |
| +// "combined_status_mask_bit3": |
| +// (input["search_providers.*.search_url"] == kTestSearchURL) |
| +// "combined_status_mask_bit4": |
| +// (input["search_providers.*.search_url"] == kTestSearchURL2) |
| +// } |
| +std::string ConstructProgramToCheckSearchEngines() { |
| + std::string bytecode; |
| + bytecode += OP_NAVIGATE(GetHash("default_search_provider")); |
| + bytecode += OP_NAVIGATE(GetHash("search_url")); |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestSearchURL)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit1"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("default_search_provider_iuc")); |
| + bytecode += OP_COMPARE_NODE_BOOL(EncodeBool(true)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit2"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("search_providers")); |
| + bytecode += OP_NAVIGATE_ANY; |
| + bytecode += OP_NAVIGATE(GetHash("search_url")); |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestSearchURL)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit3"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("search_providers")); |
| + bytecode += OP_NAVIGATE_ANY; |
| + bytecode += OP_NAVIGATE(GetHash("search_url")); |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestSearchURL2)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit4"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + return bytecode; |
| +} |
| + |
| +// Legend for the bitmask returned by the above program. |
| +enum CombinedStatusMaskLegendForCheckingSearchEngines { |
| + HAS_EXPECTED_DEFAULT_SEARCH_PROVIDER = 1 << 0, |
| + DEFAULT_SEARCH_PROVIDER_IS_USER_CONTROLLED = 1 << 1, |
| + HAS_EXPECTED_PREPOPULATED_SEARCH_PROVIDER_1 = 1 << 2, |
| + HAS_EXPECTED_PREPOPULATED_SEARCH_PROVIDER_2 = 1 << 3, |
| +}; |
| + |
| +// Constructs yet another evaluation program to specifically test that loaded |
| +// module digests are included in the input as expected. We will re-purpose the |
| +// output bitmasks to channel out information about the outcome of the checks. |
| +// |
| +// More specifically, the output of the program will be as follows: |
| +// { |
| +// "combined_status_mask_bit1": |
| +// (input["loaded_modules.*"] == kTestModuleDigest) |
| +// "combined_status_mask_bit2": |
| +// (input["loaded_modules.*"] == kTestModuleDigest2) |
| +// } |
| +std::string ConstructProgramToCheckLoadedModuleDigests() { |
| + std::string bytecode; |
| + bytecode += OP_NAVIGATE(GetHash("loaded_modules")); |
| + bytecode += OP_NAVIGATE_ANY; |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestModuleDigest)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit1"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + bytecode += OP_NAVIGATE(GetHash("loaded_modules")); |
| + bytecode += OP_NAVIGATE_ANY; |
| + bytecode += OP_COMPARE_NODE_HASH(GetHash(kTestModuleDigest2)); |
| + bytecode += OP_STORE_BOOL(GetHash("combined_status_mask_bit2"), |
| + EncodeBool(true)); |
| + bytecode += OP_END_OF_SENTENCE; |
| + return bytecode; |
| +} |
| + |
| +// Legend for the bitmask returned by the above program. |
| +enum CombinedStatusMaskLegendForCheckingLoadedModules { |
| + HAS_EXPECTED_MODULE_DIGEST_1 = 1 << 0, |
| + HAS_EXPECTED_MODULE_DIGEST_2 = 1 << 1, |
| +}; |
| + |
| // Test fixtures ------------------------------------------------------------- |
| class AutomaticProfileResetterTestBase : public testing::Test { |
| protected: |
| explicit AutomaticProfileResetterTestBase( |
| const std::string& experiment_group_name) |
| - : local_state_(TestingBrowserProcess::GetGlobal()), |
| + : waiting_task_runner_(new base::TestSimpleTaskRunner), |
| + local_state_(TestingBrowserProcess::GetGlobal()), |
| + profile_(new TestingProfile()), |
| experiment_group_name_(experiment_group_name), |
| mock_delegate_(NULL) { |
| - // Make sure the factory is not optimized away, so prefs get registered. |
| + // Make sure the factory is not optimized away, so whatever preferences it |
| + // wants to register will actually get registered. |
| AutomaticProfileResetterFactory::GetInstance(); |
| + |
| + // Register some additional local state preferences for testing purposes. |
| + PrefRegistrySimple* local_state_registry = local_state_.Get()->registry(); |
| + DCHECK(local_state_registry); |
| + local_state_registry->RegisterStringPref(kTestPreferencePath, ""); |
| + |
| + // Register some additional user preferences for testing purposes. |
| + user_prefs::PrefRegistrySyncable* user_prefs_registry = |
| + profile_->GetTestingPrefService()->registry(); |
| + DCHECK(user_prefs_registry); |
| + user_prefs_registry->RegisterStringPref( |
| + kTestPreferencePath, |
| + "", |
| + user_prefs::PrefRegistrySyncable::UNSYNCABLE_PREF); |
| } |
| virtual void SetUp() OVERRIDE { |
| - profile_.reset(new TestingProfile()); |
| field_trials_.reset(new base::FieldTrialList(NULL)); |
| base::FieldTrialList::CreateFieldTrial(kAutomaticProfileResetStudyName, |
| experiment_group_name_); |
| - mock_delegate_ = new testing::StrictMock<MockProfileResetterDelegate>(); |
| - resetter_.reset(new AutomaticProfileResetter(profile_.get())); |
| + |
| + resetter_.reset(new testing::StrictMock<AutomaticProfileResetterUnderTest>( |
| + profile_.get())); |
| + |
| + scoped_ptr<MockProfileResetterDelegate> mock_delegate( |
| + new testing::StrictMock<MockProfileResetterDelegate>()); |
| + mock_delegate_ = mock_delegate.get(); |
| + resetter_->SetDelegateForTesting( |
| + mock_delegate.PassAs<AutomaticProfileResetterDelegate>()); |
| + resetter_->SetTaskRunnerForWaitingForTesting(waiting_task_runner_); |
| } |
| void SetTestingHashSeed(const std::string& hash_seed) { |
| @@ -173,22 +455,30 @@ class AutomaticProfileResetterTestBase : public testing::Test { |
| } |
| void UnleashResetterAndWait() { |
| - resetter_->Initialize(); |
| - resetter_->SetDelegateForTesting(mock_delegate_); // Takes ownership. |
| resetter_->SetHashSeedForTesting(testing_hash_seed_); |
| resetter_->SetProgramForTesting(testing_program_); |
| + |
| + resetter_->Activate(); |
| + |
| + if (waiting_task_runner_->HasPendingTask()) { |
| + EXPECT_EQ(base::TimeDelta::FromSeconds(55), |
| + waiting_task_runner_->NextPendingTaskDelay()); |
| + waiting_task_runner_->RunPendingTasks(); |
| + } |
| base::RunLoop().RunUntilIdle(); |
| content::BrowserThread::GetBlockingPool()->FlushForTesting(); |
| base::RunLoop().RunUntilIdle(); |
| } |
| TestingProfile* profile() { return profile_.get(); } |
| + TestingPrefServiceSimple* local_state() { return local_state_.Get(); } |
| MockProfileResetterDelegate& mock_delegate() { return *mock_delegate_; } |
| - AutomaticProfileResetter* resetter() { return resetter_.get(); } |
| + AutomaticProfileResetterUnderTest& resetter() { return *resetter_; } |
| private: |
| content::TestBrowserThreadBundle thread_bundle_; |
| + scoped_refptr<base::TestSimpleTaskRunner> waiting_task_runner_; |
| ScopedTestingLocalState local_state_; |
| scoped_ptr<TestingProfile> profile_; |
| scoped_ptr<base::FieldTrialList> field_trials_; |
| @@ -196,7 +486,7 @@ class AutomaticProfileResetterTestBase : public testing::Test { |
| std::string testing_program_; |
| std::string testing_hash_seed_; |
| - scoped_ptr<AutomaticProfileResetter> resetter_; |
| + scoped_ptr<AutomaticProfileResetterUnderTest> resetter_; |
| MockProfileResetterDelegate* mock_delegate_; |
| DISALLOW_COPY_AND_ASSIGN(AutomaticProfileResetterTestBase); |
| @@ -257,7 +547,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, ConditionsNotSatisfied) { |
| SetTestingProgram(ConstructProgram(false, false)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x00u, 0x00u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, 0x00u)); |
| UnleashResetterAndWait(); |
| @@ -278,7 +570,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, OneConditionSatisfied) { |
| SetTestingProgram(ConstructProgram(true, false)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x01u, 0x01u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x01u, 0x01u)); |
| UnleashResetterAndWait(); |
| @@ -299,7 +593,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, OtherConditionSatisfied) { |
| SetTestingProgram(ConstructProgram(false, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x02u, 0x01u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x02u, 0x01u)); |
| UnleashResetterAndWait(); |
| @@ -321,7 +617,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x01u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x01u)); |
| UnleashResetterAndWait(); |
| @@ -340,7 +638,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, AlreadyHadPrefHostedMemento) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x03u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x03u)); |
| UnleashResetterAndWait(); |
| @@ -359,7 +659,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, AlreadyHadLocalStateHostedMemento) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x05u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x05u)); |
| UnleashResetterAndWait(); |
| @@ -378,7 +680,9 @@ TEST_F(AutomaticProfileResetterTestDryRun, AlreadyHadFileHostedMemento) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x09u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x09u)); |
| UnleashResetterAndWait(); |
| @@ -416,7 +720,9 @@ TEST_F(AutomaticProfileResetterTest, ConditionsNotSatisfied) { |
| SetTestingProgram(ConstructProgram(false, false)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x00u, 0x00u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, 0x00u)); |
| UnleashResetterAndWait(); |
| @@ -437,8 +743,10 @@ TEST_F(AutomaticProfileResetterTest, OneConditionSatisfied) { |
| SetTestingProgram(ConstructProgram(true, false)); |
| SetTestingHashSeed(kTestHashSeed); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| EXPECT_CALL(mock_delegate(), ShowPrompt()); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x01u, 0x01u)); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x01u, 0x01u)); |
| UnleashResetterAndWait(); |
| @@ -459,8 +767,10 @@ TEST_F(AutomaticProfileResetterTest, OtherConditionSatisfied) { |
| SetTestingProgram(ConstructProgram(false, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| EXPECT_CALL(mock_delegate(), ShowPrompt()); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x02u, 0x01u)); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x02u, 0x01u)); |
| UnleashResetterAndWait(); |
| @@ -481,8 +791,10 @@ TEST_F(AutomaticProfileResetterTest, ConditionsSatisfiedAndInvalidMementos) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| EXPECT_CALL(mock_delegate(), ShowPrompt()); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x01u)); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x01u)); |
| UnleashResetterAndWait(); |
| @@ -501,7 +813,9 @@ TEST_F(AutomaticProfileResetterTest, PrefHostedMementoPreventsPrompt) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x03u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x03u)); |
| UnleashResetterAndWait(); |
| @@ -520,7 +834,9 @@ TEST_F(AutomaticProfileResetterTest, LocalStateHostedMementoPreventsPrompt) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x05u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x05u)); |
| UnleashResetterAndWait(); |
| @@ -539,7 +855,9 @@ TEST_F(AutomaticProfileResetterTest, FileHostedMementoPreventsPrompt) { |
| SetTestingProgram(ConstructProgram(true, true)); |
| SetTestingHashSeed(kTestHashSeed); |
| - EXPECT_CALL(mock_delegate(), ReportStatistics(0x03u, 0x09u)); |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + EXPECT_CALL(resetter(), ReportStatistics(0x03u, 0x09u)); |
| UnleashResetterAndWait(); |
| @@ -565,4 +883,148 @@ TEST_F(AutomaticProfileResetterTest, DoNothingWhenResourcesAreMissing) { |
| EXPECT_EQ("", memento_in_file.ReadValue()); |
| } |
| +// Please see comments above ConstructProgramToCheckPreferences() to understand |
| +// how the following tests work. |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputUserPreferencesCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckPreferences()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + PrefService* prefs = profile()->GetPrefs(); |
| + prefs->SetString(kTestPreferencePath, kTestPreferenceValue); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = |
| + HAS_EXPECTED_USER_PREFERENCE | USER_PREFERENCE_IS_USER_CONTROLLED; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputLocalStateCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckPreferences()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + PrefService* prefs = local_state(); |
| + prefs->SetString(kTestPreferencePath, kTestPreferenceValue); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = |
| + HAS_EXPECTED_LOCAL_STATE_PREFERENCE | LOCAL_STATE_IS_USER_CONTROLLED; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputManagedUserPreferencesCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckPreferences()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + TestingPrefServiceSyncable* prefs = profile()->GetTestingPrefService(); |
| + prefs->SetManagedPref(kTestPreferencePath, |
| + new base::StringValue(kTestPreferenceValue)); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = HAS_EXPECTED_USER_PREFERENCE; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputManagedLocalStateCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckPreferences()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + TestingPrefServiceSimple* prefs = local_state(); |
| + prefs->SetManagedPref(kTestPreferencePath, |
| + new base::StringValue(kTestPreferenceValue)); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = HAS_EXPECTED_LOCAL_STATE_PREFERENCE; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +// Please see comments above ConstructProgramToCheckSearchEngines() to |
| +// understand how the following tests work. |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputDefaultSearchProviderCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckSearchEngines()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + mock_delegate().emulated_default_search_provider_details().SetString( |
| + kSearchURLAttributeKey, kTestSearchURL); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = HAS_EXPECTED_DEFAULT_SEARCH_PROVIDER | |
| + DEFAULT_SEARCH_PROVIDER_IS_USER_CONTROLLED; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputSearchProviderManagedCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckSearchEngines()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + mock_delegate().emulated_default_search_provider_details().SetString( |
| + kSearchURLAttributeKey, kTestSearchURL); |
| + mock_delegate().set_emulated_default_search_provider_is_managed(true); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = HAS_EXPECTED_DEFAULT_SEARCH_PROVIDER; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputSearchProvidersCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckSearchEngines()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + base::DictionaryValue* search_provider_1 = new base::DictionaryValue; |
| + base::DictionaryValue* search_provider_2 = new base::DictionaryValue; |
| + search_provider_1->SetString(kSearchURLAttributeKey, kTestSearchURL); |
| + search_provider_2->SetString(kSearchURLAttributeKey, kTestSearchURL2); |
| + mock_delegate().emulated_search_providers_details().Append(search_provider_1); |
| + mock_delegate().emulated_search_providers_details().Append(search_provider_2); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = DEFAULT_SEARCH_PROVIDER_IS_USER_CONTROLLED | |
| + HAS_EXPECTED_PREPOPULATED_SEARCH_PROVIDER_1 | |
| + HAS_EXPECTED_PREPOPULATED_SEARCH_PROVIDER_2; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| +// Please see comments above ConstructProgramToCheckLoadedModuleDigests() to |
| +// understand how the following tests work. |
| + |
| +TEST_F(AutomaticProfileResetterTest, InputModuleDigestsCorrect) { |
| + SetTestingProgram(ConstructProgramToCheckLoadedModuleDigests()); |
| + SetTestingHashSeed(kTestHashSeed); |
| + |
| + mock_delegate().emulated_loaded_module_digests().AppendString( |
| + kTestModuleDigest); |
| + mock_delegate().emulated_loaded_module_digests().AppendString( |
| + kTestModuleDigest2); |
| + |
| + mock_delegate().ExpectCallsToDependenciesSetUpMethods(); |
| + mock_delegate().ExpectCallsToGetterMethods(); |
| + uint32 expected_mask = |
| + HAS_EXPECTED_MODULE_DIGEST_1 | HAS_EXPECTED_MODULE_DIGEST_2; |
| + EXPECT_CALL(resetter(), ReportStatistics(0x00u, expected_mask)); |
| + |
| + UnleashResetterAndWait(); |
| +} |
| + |
| } // namespace |