Index: chrome/browser/autofill/password_autofill_manager_unittest.cc |
diff --git a/chrome/browser/autofill/password_autofill_manager_unittest.cc b/chrome/browser/autofill/password_autofill_manager_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b0cd9939c32306840e51b2187bc8eaa7d0c102bc |
--- /dev/null |
+++ b/chrome/browser/autofill/password_autofill_manager_unittest.cc |
@@ -0,0 +1,83 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/compiler_specific.h" |
+#include "base/utf_string_conversions.h" |
+#include "chrome/browser/autofill/password_autofill_manager.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace { |
+ |
+// The name of the username/password element in the form. |
+const char* const kUsernameName = "username"; |
+const char* const kPasswordName = "password"; |
+ |
+const char* const kAliceUsername = "alice"; |
+const char* const kAlicePassword = "password"; |
+ |
+const char* const kValue = "password"; |
+ |
+} // namespace |
+ |
+class PasswordAutofillManagerTest : public testing::Test { |
+ protected: |
+ PasswordAutofillManagerTest() : password_autofill_manager_(NULL) {} |
+ |
+ virtual void SetUp() OVERRIDE { |
+ // Add a preferred login and an additional login to the FillData. |
+ string16 username1 = ASCIIToUTF16(kAliceUsername); |
+ string16 password1 = ASCIIToUTF16(kAlicePassword); |
+ |
+ username_field_.name = ASCIIToUTF16(kUsernameName); |
+ username_field_.value = username1; |
+ fill_data_.basic_data.fields.push_back(username_field_); |
+ |
+ webkit::forms::FormField password_field; |
+ password_field.name = ASCIIToUTF16(kPasswordName); |
+ password_field.value = password1; |
+ fill_data_.basic_data.fields.push_back(password_field); |
+ |
+ password_autofill_manager_.AddPasswordFormMapping(username_field_, |
+ fill_data_); |
+ } |
+ |
+ PasswordAutofillManager* password_autofill_manager() { |
+ return &password_autofill_manager_; |
+ } |
+ |
+ const webkit::forms::FormField& username_field() { return username_field_; } |
+ |
+ private: |
+ webkit::forms::PasswordFormFillData fill_data_; |
+ webkit::forms::FormField username_field_; |
+ |
+ PasswordAutofillManager password_autofill_manager_; |
+}; |
+ |
+TEST_F(PasswordAutofillManagerTest, DidAcceptAutofillSuggestion) { |
+ EXPECT_TRUE(password_autofill_manager()->DidAcceptAutofillSuggestion( |
+ username_field(), ASCIIToUTF16(kValue))); |
+ |
+ webkit::forms::FormField invalid_username; |
+ invalid_username.name = ASCIIToUTF16(kUsernameName); |
+ invalid_username.value = ASCIIToUTF16("no_user"); |
Ilya Sherman
2012/03/22 01:20:06
It looks like you've removed the test for the case
csharp
2012/03/23 15:25:24
Added back.
|
+ |
+ EXPECT_FALSE(password_autofill_manager()->DidAcceptAutofillSuggestion( |
+ invalid_username, ASCIIToUTF16(kValue))); |
+ |
+ password_autofill_manager()->Reset(); |
+ |
+ EXPECT_FALSE(password_autofill_manager()->DidAcceptAutofillSuggestion( |
+ username_field(), ASCIIToUTF16(kValue))); |
+} |
+ |
+TEST_F(PasswordAutofillManagerTest, DidClearAutofillSelection) { |
+ EXPECT_TRUE(password_autofill_manager()->DidClearAutofillSelection( |
+ username_field())); |
+ |
+ password_autofill_manager()->Reset(); |
+ |
+ EXPECT_FALSE(password_autofill_manager()->DidClearAutofillSelection( |
+ username_field())); |
+} |