Chromium Code Reviews| Index: components/password_manager/core/browser/password_manager_unittest.cc |
| diff --git a/components/password_manager/core/browser/password_manager_unittest.cc b/components/password_manager/core/browser/password_manager_unittest.cc |
| index a3cc8fc2cd5e185535fcbbe8030a4773d8b52119..bf3efe7e6b22d7e559ed846189ed90bb32fec175 100644 |
| --- a/components/password_manager/core/browser/password_manager_unittest.cc |
| +++ b/components/password_manager/core/browser/password_manager_unittest.cc |
| @@ -1037,4 +1037,47 @@ TEST_F(PasswordManagerTest, SavingSignupForms_NoActionMatch) { |
| form_to_save->Save(); |
| } |
| +TEST_F(PasswordManagerTest, FormSubmittedChangedWithAutofillResponse) { |
| + // Test that observing that a newly submitted form differs from provisionally |
|
vabr (Chromium)
2015/03/26 09:43:55
I still struggle to understand, partly because the
dvadym
2015/03/26 12:29:13
Thanks, comment for test changed to yours.
|
| + // saved one due to autoflll predictions caused another field to be identified |
| + // as username. |
| + EXPECT_CALL(driver_, FillPasswordForm(_)).Times(Exactly(0)); |
| + std::vector<PasswordForm> observed; |
| + PasswordForm form(MakeSimpleForm()); |
| + observed.push_back(form); |
| + // The initial load. |
| + manager()->OnPasswordFormsParsed(&driver_, observed); |
| + // The initial layout. |
| + manager()->OnPasswordFormsRendered(&driver_, observed, true); |
| + |
| + // Simulate that based on autofill server username prediction, the username |
| + // of the form changed from the default candidate("Email") to something else. |
| + // Set the parsed_using_autofill_predictions bit to true to make sure that |
| + // choice of username is accepted by PasswordManager, otherwise the form |
| + // will rejected as not equal to provionally saved one. |
|
vabr (Chromium)
2015/03/26 09:43:55
Aren't we telling the password manager, that |form
vabr (Chromium)
2015/03/26 09:43:55
will rejected -> will be rejected
provionally -> t
dvadym
2015/03/26 12:29:13
Added comment
// Note that during initial parsi
dvadym
2015/03/26 12:29:13
Done.
|
| + form.username_element = ASCIIToUTF16("Username"); |
| + form.parsed_using_autofill_predictions = true; |
| + // And the form submit contract is to call ProvisionallySavePassword. |
| + manager()->ProvisionallySavePassword(form); |
| + |
| + scoped_ptr<PasswordFormManager> form_to_save; |
| + EXPECT_CALL(client_, |
| + PromptUserToSavePasswordPtr( |
| + _, CredentialSourceType::CREDENTIAL_SOURCE_PASSWORD_MANAGER)) |
| + .WillOnce(WithArg<0>(SaveToScopedPtr(&form_to_save))); |
| + |
| + // Now the password manager waits for the navigation to complete. |
| + observed.clear(); |
| + // The post-navigation load. |
| + manager()->OnPasswordFormsParsed(&driver_, observed); |
| + // The post-navigation layout. |
| + manager()->OnPasswordFormsRendered(&driver_, observed, true); |
| + |
| + ASSERT_TRUE(form_to_save); |
| + EXPECT_CALL(*store_, AddLogin(FormMatches(form))); |
| + |
| + // Simulate saving the form, as if the info bar was accepted. |
| + form_to_save->Save(); |
| +} |
| + |
| } // namespace password_manager |