Chromium Code Reviews| Index: chrome/browser/password_manager/password_manager_browsertest.cc |
| diff --git a/chrome/browser/password_manager/password_manager_browsertest.cc b/chrome/browser/password_manager/password_manager_browsertest.cc |
| index 79aacd5ba1bcdec70db6b217f5e0dfb8e2906ad9..88350112d6bc667b13de369e4839395677caadb8 100644 |
| --- a/chrome/browser/password_manager/password_manager_browsertest.cc |
| +++ b/chrome/browser/password_manager/password_manager_browsertest.cc |
| @@ -21,6 +21,7 @@ |
| #include "components/infobars/core/infobar.h" |
| #include "components/infobars/core/infobar_manager.h" |
| #include "components/password_manager/core/browser/test_password_store.h" |
| +#include "components/password_manager/core/common/password_manager_switches.h" |
| #include "content/public/browser/render_view_host.h" |
| #include "content/public/browser/web_contents.h" |
| #include "content/public/browser/web_contents_observer.h" |
| @@ -162,6 +163,8 @@ class PasswordManagerBrowserTest : public InProcessBrowserTest { |
| if (!embedded_test_server()->Started()) |
| ASSERT_TRUE(embedded_test_server()->InitializeAndWaitUntilReady()); |
| + ASSERT_FALSE(CommandLine::ForCurrentProcess()->HasSwitch( |
| + password_manager::switches::kEnableAutomaticPasswordSaving)); |
| NavigationObserver observer(WebContents()); |
| GURL url = embedded_test_server()->GetURL(path); |
| ui_test_utils::NavigateToURL(browser(), url); |
| @@ -647,3 +650,45 @@ IN_PROC_BROWSER_TEST_F(PasswordManagerBrowserTest, |
| observer.Wait(); |
| EXPECT_FALSE(observer.infobar_shown()); |
| } |
| + |
| +IN_PROC_BROWSER_TEST_F(PasswordManagerBrowserTest, |
| + PromptWhenEnableAutomaticPasswordSavingSwitchIsNotSet) { |
| + NavigateToFile("/password/password_form.html"); |
| + |
| + // Fill a form and submit through a <input type="submit"> button. |
| + NavigationObserver observer(WebContents()); |
| + std::string fill_and_submit = |
| + "document.getElementById('username_field').value = 'temp';" |
| + "document.getElementById('password_field').value = 'random';" |
| + "document.getElementById('input_submit_button').click()"; |
| + ASSERT_TRUE(content::ExecuteScript(RenderViewHost(), fill_and_submit)); |
| + observer.Wait(); |
| + EXPECT_TRUE(observer.infobar_shown()); |
| +} |
| + |
| +IN_PROC_BROWSER_TEST_F(PasswordManagerBrowserTest, |
| + DontPromptWhenEnableAutomaticPasswordSavingSwitchIsSet) { |
| + password_manager::TestPasswordStore* password_store = |
| + static_cast<password_manager::TestPasswordStore*> |
| + PasswordStoreFactory::GetForProfile(browser()->profile(), |
| + Profile::IMPLICIT_ACCESS).get(); |
| + |
| + EXPECT_EQ(password_store->stored_passwords().size(), 0); |
|
vabr (Chromium)
2014/04/29 13:58:46
nit: Please revert the order:
0u, password_store->
rchtara
2014/04/29 14:25:03
Done.
|
| + |
| + NavigateToFile("/password/password_form.html"); |
| + |
| + // Enable the enable-automatic-password-saving switch |
| + CommandLine::ForCurrentProcess()->AppendSwitch( |
| + password_manager::switches::kEnableAutomaticPasswordSaving); |
| + |
| + // Fill a form and submit through a <input type="submit"> button. |
| + NavigationObserver observer(WebContents()); |
| + std::string fill_and_submit = |
| + "document.getElementById('username_field').value = 'temp';" |
| + "document.getElementById('password_field').value = 'random';" |
| + "document.getElementById('input_submit_button').click()"; |
| + ASSERT_TRUE(content::ExecuteScript(RenderViewHost(), fill_and_submit)); |
| + observer.Wait(); |
| + EXPECT_FALSE(observer.infobar_shown()); |
| + EXPECT_EQ(password_store->stored_passwords().size(), 1); |
|
vabr (Chromium)
2014/04/29 13:58:46
ditto: please revert the order:
1u, password_store
rchtara
2014/04/29 14:25:03
Done.
|
| +} |