Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(167)

Unified Diff: components/autofill/core/common/form_data_unittest.cc

Issue 853523004: Autofill: Set requirements for number of recognized fields in an autofillable form (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase, change variable name Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/autofill/core/common/form_data_unittest.cc
diff --git a/components/autofill/core/common/form_data_unittest.cc b/components/autofill/core/common/form_data_unittest.cc
index 788e268ebe168088c5f79242d2b4c4a9bfc11dd8..3b75ab87492571c2e800ee83fcab73b2b61c1bb3 100644
--- a/components/autofill/core/common/form_data_unittest.cc
+++ b/components/autofill/core/common/form_data_unittest.cc
@@ -9,13 +9,15 @@
#include "components/autofill/core/common/form_field_data.h"
#include "testing/gtest/include/gtest/gtest.h"
+namespace autofill {
+
namespace {
// This function serializes the form data into the pickle in version one format.
// It should always be possible to deserialize it using DeserializeFormData(),
// even when version changes. See kPickleVersion in form_data.cc.
-void SerializeInVersion1Format(const autofill::FormData& form_data,
- Pickle* pickle) {
+void SerializeInVersion1Format(const FormData& form_data, Pickle* pickle) {
+ DCHECK_EQ(true, form_data.is_form_tag);
pickle->WriteInt(1);
pickle->WriteString16(form_data.name);
base::string16 method(base::ASCIIToUTF16("POST"));
@@ -29,10 +31,9 @@ void SerializeInVersion1Format(const autofill::FormData& form_data,
}
}
-// This function serializes the form data into the pickle in incorrect format
-// (no version number).
-void SerializeIncorrectFormat(const autofill::FormData& form_data,
- Pickle* pickle) {
+void SerializeInVersion2Format(const FormData& form_data, Pickle* pickle) {
+ DCHECK_EQ(true, form_data.is_form_tag);
+ pickle->WriteInt(2);
pickle->WriteString16(form_data.name);
pickle->WriteString(form_data.origin.spec());
pickle->WriteString(form_data.action.spec());
@@ -43,16 +44,24 @@ void SerializeIncorrectFormat(const autofill::FormData& form_data,
}
}
+// This function serializes the form data into the pickle in incorrect format
+// (no version number).
+void SerializeIncorrectFormat(const FormData& form_data, Pickle* pickle) {
+ pickle->WriteString16(form_data.name);
+ pickle->WriteString(form_data.origin.spec());
+ pickle->WriteString(form_data.action.spec());
+ pickle->WriteBool(form_data.user_submitted);
+ pickle->WriteInt(static_cast<int>(form_data.fields.size()));
+ for (size_t i = 0; i < form_data.fields.size(); ++i) {
+ SerializeFormFieldData(form_data.fields[i], pickle);
+ }
}
-namespace autofill {
-
-TEST(FormDataTest, SerializeAndDeserialize) {
- FormData data;
- data.name = base::ASCIIToUTF16("name");
- data.origin = GURL("origin");
- data.action = GURL("action");
- data.user_submitted = true;
+void FillInDummyFormData(FormData* data) {
+ data->name = base::ASCIIToUTF16("name");
+ data->origin = GURL("origin");
+ data->action = GURL("action");
+ data->user_submitted = true;
FormFieldData field_data;
field_data.label = base::ASCIIToUTF16("label");
@@ -72,13 +81,21 @@ TEST(FormDataTest, SerializeAndDeserialize) {
field_data.option_contents.push_back(base::ASCIIToUTF16("First"));
field_data.option_contents.push_back(base::ASCIIToUTF16("Second"));
- data.fields.push_back(field_data);
+ data->fields.push_back(field_data);
// Change a few fields.
field_data.max_length = 150;
field_data.option_values.push_back(base::ASCIIToUTF16("Third"));
field_data.option_contents.push_back(base::ASCIIToUTF16("Third"));
- data.fields.push_back(field_data);
+ data->fields.push_back(field_data);
+}
+
+} // namespace
+
+TEST(FormDataTest, SerializeAndDeserialize) {
+ FormData data;
+ FillInDummyFormData(&data);
+ data.is_form_tag = false;
Pickle pickle;
SerializeFormData(data, &pickle);
@@ -92,36 +109,7 @@ TEST(FormDataTest, SerializeAndDeserialize) {
TEST(FormDataTest, Serialize_v1_Deserialize_vCurrent) {
FormData data;
- data.name = base::ASCIIToUTF16("name");
- data.origin = GURL("origin");
- data.action = GURL("action");
- data.user_submitted = true;
-
- FormFieldData field_data;
- field_data.label = base::ASCIIToUTF16("label");
- field_data.name = base::ASCIIToUTF16("name");
- field_data.value = base::ASCIIToUTF16("value");
- field_data.form_control_type = "password";
- field_data.autocomplete_attribute = "off";
- field_data.max_length = 200;
- field_data.is_autofilled = true;
- field_data.is_checked = true;
- field_data.is_checkable = true;
- field_data.is_focusable = true;
- field_data.should_autocomplete = false;
- field_data.text_direction = base::i18n::RIGHT_TO_LEFT;
- field_data.option_values.push_back(base::ASCIIToUTF16("First"));
- field_data.option_values.push_back(base::ASCIIToUTF16("Second"));
- field_data.option_contents.push_back(base::ASCIIToUTF16("First"));
- field_data.option_contents.push_back(base::ASCIIToUTF16("Second"));
-
- data.fields.push_back(field_data);
-
- // Change a few fields.
- field_data.max_length = 150;
- field_data.option_values.push_back(base::ASCIIToUTF16("Third"));
- field_data.option_contents.push_back(base::ASCIIToUTF16("Third"));
- data.fields.push_back(field_data);
+ FillInDummyFormData(&data);
Pickle pickle;
SerializeInVersion1Format(data, &pickle);
@@ -133,38 +121,23 @@ TEST(FormDataTest, Serialize_v1_Deserialize_vCurrent) {
EXPECT_TRUE(actual.SameFormAs(data));
}
-TEST(FormDataTest, SerializeIncorrectFormatAndDeserialize) {
+TEST(FormDataTest, Serialize_v2_Deserialize_vCurrent) {
FormData data;
- data.name = base::ASCIIToUTF16("name");
- data.origin = GURL("origin");
- data.action = GURL("action");
- data.user_submitted = true;
+ FillInDummyFormData(&data);
- FormFieldData field_data;
- field_data.label = base::ASCIIToUTF16("label");
- field_data.name = base::ASCIIToUTF16("name");
- field_data.value = base::ASCIIToUTF16("value");
- field_data.form_control_type = "password";
- field_data.autocomplete_attribute = "off";
- field_data.max_length = 200;
- field_data.is_autofilled = true;
- field_data.is_checked = true;
- field_data.is_checkable = true;
- field_data.is_focusable = true;
- field_data.should_autocomplete = false;
- field_data.text_direction = base::i18n::RIGHT_TO_LEFT;
- field_data.option_values.push_back(base::ASCIIToUTF16("First"));
- field_data.option_values.push_back(base::ASCIIToUTF16("Second"));
- field_data.option_contents.push_back(base::ASCIIToUTF16("First"));
- field_data.option_contents.push_back(base::ASCIIToUTF16("Second"));
+ Pickle pickle;
+ SerializeInVersion2Format(data, &pickle);
- data.fields.push_back(field_data);
+ PickleIterator iter(pickle);
+ FormData actual;
+ EXPECT_TRUE(DeserializeFormData(&iter, &actual));
- // Change a few fields.
- field_data.max_length = 150;
- field_data.option_values.push_back(base::ASCIIToUTF16("Third"));
- field_data.option_contents.push_back(base::ASCIIToUTF16("Third"));
- data.fields.push_back(field_data);
+ EXPECT_TRUE(actual.SameFormAs(data));
+}
+
+TEST(FormDataTest, SerializeIncorrectFormatAndDeserialize) {
+ FormData data;
+ FillInDummyFormData(&data);
Pickle pickle;
SerializeIncorrectFormat(data, &pickle);

Powered by Google App Engine
This is Rietveld 408576698