| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "components/password_manager/core/browser/password_manager_internals_se
rvice.h" | 5 #include "components/password_manager/core/browser/password_manager_internals_se
rvice.h" |
| 6 | 6 |
| 7 #include "chrome/test/base/testing_profile.h" | 7 #include "chrome/test/base/testing_profile.h" |
| 8 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 8 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
| 9 #include "components/password_manager/content/browser/password_manager_internals
_service_factory.h" | 9 #include "components/password_manager/content/browser/password_manager_internals
_service_factory.h" |
| 10 #include "components/password_manager/core/browser/log_receiver.h" | 10 #include "components/password_manager/core/browser/log_receiver.h" |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 public: | 22 public: |
| 23 MockLogReceiver() {} | 23 MockLogReceiver() {} |
| 24 | 24 |
| 25 MOCK_METHOD1(LogSavePasswordProgress, void(const std::string&)); | 25 MOCK_METHOD1(LogSavePasswordProgress, void(const std::string&)); |
| 26 }; | 26 }; |
| 27 | 27 |
| 28 enum ProfileType { NORMAL_PROFILE, INCOGNITO_PROFILE }; | 28 enum ProfileType { NORMAL_PROFILE, INCOGNITO_PROFILE }; |
| 29 | 29 |
| 30 scoped_ptr<TestingProfile> CreateProfile(ProfileType type) { | 30 scoped_ptr<TestingProfile> CreateProfile(ProfileType type) { |
| 31 TestingProfile::Builder builder; | 31 TestingProfile::Builder builder; |
| 32 if (type == INCOGNITO_PROFILE) | |
| 33 builder.SetIncognito(); | |
| 34 scoped_ptr<TestingProfile> profile(builder.Build()); | 32 scoped_ptr<TestingProfile> profile(builder.Build()); |
| 35 #if !defined(NDEBUG) | 33 #if !defined(NDEBUG) |
| 36 // During the test cases, the profiles may get created on the same address. To | 34 // During the test cases, the profiles may get created on the same address. To |
| 37 // avoid over-zealous asserts we need to mark the newly created one as "live". | 35 // avoid over-zealous asserts we need to mark the newly created one as "live". |
| 38 // See declaration of MarkBrowserContextLiveForTesting for more details. | 36 // See declaration of MarkBrowserContextLiveForTesting for more details. |
| 39 BrowserContextDependencyManager::GetInstance() | 37 BrowserContextDependencyManager::GetInstance() |
| 40 ->MarkBrowserContextLiveForTesting(profile.get()); | 38 ->MarkBrowserContextLiveForTesting(profile.get()); |
| 39 if (type == INCOGNITO_PROFILE) { |
| 40 BrowserContextDependencyManager::GetInstance() |
| 41 ->MarkBrowserContextLiveForTesting(profile->GetOffTheRecordProfile()); |
| 42 } |
| 41 #endif | 43 #endif |
| 42 return profile.Pass(); | 44 return profile.Pass(); |
| 43 } | 45 } |
| 44 | 46 |
| 45 } // namespace | 47 } // namespace |
| 46 | 48 |
| 47 // When the profile is not incognito, it should be possible to activate the | 49 // When the profile is not incognito, it should be possible to activate the |
| 48 // service. | 50 // service. |
| 49 TEST(PasswordManagerInternalsServiceTest, ServiceActiveNonIncognito) { | 51 TEST(PasswordManagerInternalsServiceTest, ServiceActiveNonIncognito) { |
| 50 scoped_ptr<TestingProfile> profile(CreateProfile(NORMAL_PROFILE)); | 52 scoped_ptr<TestingProfile> profile(CreateProfile(NORMAL_PROFILE)); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 62 service->ProcessLog(kTestText); | 64 service->ProcessLog(kTestText); |
| 63 | 65 |
| 64 service->UnregisterReceiver(&receiver); | 66 service->UnregisterReceiver(&receiver); |
| 65 } | 67 } |
| 66 | 68 |
| 67 // When the browser profile is incognito, it should not be possible to activate | 69 // When the browser profile is incognito, it should not be possible to activate |
| 68 // the service. | 70 // the service. |
| 69 TEST(PasswordManagerInternalsServiceTest, ServiceNotActiveIncognito) { | 71 TEST(PasswordManagerInternalsServiceTest, ServiceNotActiveIncognito) { |
| 70 scoped_ptr<TestingProfile> profile(CreateProfile(INCOGNITO_PROFILE)); | 72 scoped_ptr<TestingProfile> profile(CreateProfile(INCOGNITO_PROFILE)); |
| 71 ASSERT_TRUE(profile); | 73 ASSERT_TRUE(profile); |
| 74 |
| 75 Profile* incognito_profile = profile->GetOffTheRecordProfile(); |
| 72 PasswordManagerInternalsService* service = | 76 PasswordManagerInternalsService* service = |
| 73 PasswordManagerInternalsServiceFactory::GetForBrowserContext( | 77 PasswordManagerInternalsServiceFactory::GetForBrowserContext( |
| 74 profile.get()); | 78 incognito_profile); |
| 75 // BrowserContextKeyedBaseFactory::GetBrowserContextToUse should return NULL | 79 // BrowserContextKeyedBaseFactory::GetBrowserContextToUse should return NULL |
| 76 // for |profile|, because |profile| is incognito. Therefore the returned | 80 // for |profile|, because |profile| is incognito. Therefore the returned |
| 77 // |service| should also be NULL. | 81 // |service| should also be NULL. |
| 78 EXPECT_FALSE(service); | 82 EXPECT_FALSE(service); |
| 79 } | 83 } |
| OLD | NEW |