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

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

Issue 1023413002: Autofill: Refactor some FormFieldData pickling code. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 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_field_data_unittest.cc
diff --git a/components/autofill/core/common/form_field_data_unittest.cc b/components/autofill/core/common/form_field_data_unittest.cc
index fce7ffe4ac12d384590c0ef2a8c9a28a918f6d6d..186c074f93518e6572ad2e7eaaf368e72a268640 100644
--- a/components/autofill/core/common/form_field_data_unittest.cc
+++ b/components/autofill/core/common/form_field_data_unittest.cc
@@ -11,24 +11,57 @@
namespace autofill {
+namespace {
+
+void FillCommonFields(FormFieldData* data) {
+ data->label = base::ASCIIToUTF16("label");
+ data->name = base::ASCIIToUTF16("name");
+ data->value = base::ASCIIToUTF16("value");
+ data->form_control_type = "password";
+ data->autocomplete_attribute = "off";
+ data->max_length = 200;
+ data->is_autofilled = true;
+ data->is_checked = true;
+ data->is_checkable = true;
+ data->is_focusable = true;
+ data->should_autocomplete = false;
+ data->text_direction = base::i18n::RIGHT_TO_LEFT;
+ data->option_values.push_back(base::ASCIIToUTF16("First"));
+ data->option_values.push_back(base::ASCIIToUTF16("Second"));
+ data->option_contents.push_back(base::ASCIIToUTF16("First"));
+ data->option_contents.push_back(base::ASCIIToUTF16("Second"));
+}
+
+void WriteCommonSection1(const FormFieldData& data, Pickle* pickle) {
+ pickle->WriteString16(data.label);
+ pickle->WriteString16(data.name);
+ pickle->WriteString16(data.value);
+ pickle->WriteString(data.form_control_type);
+ pickle->WriteString(data.autocomplete_attribute);
+ pickle->WriteSizeT(data.max_length);
+ pickle->WriteBool(data.is_autofilled);
+ pickle->WriteBool(data.is_checked);
+ pickle->WriteBool(data.is_checkable);
+ pickle->WriteBool(data.is_focusable);
+ pickle->WriteBool(data.should_autocomplete);
+}
+
+void WriteCommonSection2(const FormFieldData& data, Pickle* pickle) {
+ pickle->WriteInt(data.text_direction);
+ pickle->WriteInt(static_cast<int>(data.option_values.size()));
+ for (auto s : data.option_values)
+ pickle->WriteString16(s);
+ pickle->WriteInt(static_cast<int>(data.option_contents.size()));
+ for (auto s : data.option_contents)
+ pickle->WriteString16(s);
+}
+
+} // namespace
+
TEST(FormFieldDataTest, SerializeAndDeserialize) {
FormFieldData data;
- data.label = base::ASCIIToUTF16("label");
- data.name = base::ASCIIToUTF16("name");
- data.value = base::ASCIIToUTF16("value");
- data.form_control_type = "password";
- data.autocomplete_attribute = "off";
- data.max_length = 200;
- data.is_autofilled = true;
- data.is_checked = true;
- data.is_checkable = true;
- data.is_focusable = true;
- data.should_autocomplete = false;
- data.text_direction = base::i18n::RIGHT_TO_LEFT;
- data.option_values.push_back(base::ASCIIToUTF16("First"));
- data.option_values.push_back(base::ASCIIToUTF16("Second"));
- data.option_contents.push_back(base::ASCIIToUTF16("First"));
- data.option_contents.push_back(base::ASCIIToUTF16("Second"));
+ FillCommonFields(&data);
+ data.role = FormFieldData::ROLE_ATTRIBUTE_PRESENTATION;
Pickle pickle;
SerializeFormFieldData(data, &pickle);
@@ -42,43 +75,12 @@ TEST(FormFieldDataTest, SerializeAndDeserialize) {
TEST(FormFieldDataTest, DeserializeVersion1) {
FormFieldData data;
- data.label = base::ASCIIToUTF16("label");
- data.name = base::ASCIIToUTF16("name");
- data.value = base::ASCIIToUTF16("value");
- data.form_control_type = "password";
- data.autocomplete_attribute = "off";
- data.max_length = 200;
- data.is_autofilled = true;
- data.is_checked = true;
- data.is_checkable = true;
- data.is_focusable = true;
- data.should_autocomplete = false;
- data.text_direction = base::i18n::RIGHT_TO_LEFT;
- data.option_values.push_back(base::ASCIIToUTF16("First"));
- data.option_values.push_back(base::ASCIIToUTF16("Second"));
- data.option_contents.push_back(base::ASCIIToUTF16("First"));
- data.option_contents.push_back(base::ASCIIToUTF16("Second"));
+ FillCommonFields(&data);
Pickle pickle;
pickle.WriteInt(1);
- pickle.WriteString16(data.label);
- pickle.WriteString16(data.name);
- pickle.WriteString16(data.value);
- pickle.WriteString(data.form_control_type);
- pickle.WriteString(data.autocomplete_attribute);
- pickle.WriteSizeT(data.max_length);
- pickle.WriteBool(data.is_autofilled);
- pickle.WriteBool(data.is_checked);
- pickle.WriteBool(data.is_checkable);
- pickle.WriteBool(data.is_focusable);
- pickle.WriteBool(data.should_autocomplete);
- pickle.WriteInt(data.text_direction);
- pickle.WriteInt(static_cast<int>(data.option_values.size()));
- for (auto s: data.option_values)
- pickle.WriteString16(s);
- pickle.WriteInt(static_cast<int>(data.option_contents.size()));
- for (auto s: data.option_contents)
- pickle.WriteString16(s);
+ WriteCommonSection1(data, &pickle);
+ WriteCommonSection2(data, &pickle);
PickleIterator iter(pickle);
FormFieldData actual;

Powered by Google App Engine
This is Rietveld 408576698