// Copyright (c) 2010 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 #include #include "chrome/browser/autofill/autofill_xml_parser.h" #include "chrome/browser/autofill/field_types.h" #include "testing/gtest/include/gtest/gtest.h" #include "third_party/libjingle/source/talk/xmllite/xmlparser.h" namespace { TEST(AutoFillQueryXmlParserTest, BasicQuery) { // An XML string representing a basic query response. std::string xml = "" "" "" "" "" ""; // Create a vector of AutoFillFieldTypes, to assign the parsed field types to. std::vector field_types; UploadRequired upload_required = USE_UPLOAD_RATES; // Create a parser. AutoFillQueryXmlParser parse_handler(&field_types, &upload_required); buzz::XmlParser parser(&parse_handler); parser.Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(parse_handler.succeeded()); EXPECT_EQ(upload_required, USE_UPLOAD_RATES); ASSERT_EQ(4U, field_types.size()); EXPECT_EQ(NO_SERVER_DATA, field_types[0]); EXPECT_EQ(UNKNOWN_TYPE, field_types[1]); EXPECT_EQ(NAME_FIRST, field_types[2]); EXPECT_EQ(EMPTY_TYPE, field_types[3]); } // Test parsing the upload required attribute. TEST(AutoFillQueryXmlParserTest, TestUploadRequired) { std::vector field_types; UploadRequired upload_required = USE_UPLOAD_RATES; std::string xml = "" "" ""; scoped_ptr parse_handler( new AutoFillQueryXmlParser(&field_types, &upload_required)); scoped_ptr parser(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(parse_handler->succeeded()); EXPECT_EQ(UPLOAD_REQUIRED, upload_required); ASSERT_EQ(1U, field_types.size()); EXPECT_EQ(NO_SERVER_DATA, field_types[0]); field_types.clear(); xml = "" "" ""; parse_handler.reset( new AutoFillQueryXmlParser(&field_types, &upload_required)); parser.reset(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(parse_handler->succeeded()); EXPECT_EQ(upload_required, UPLOAD_NOT_REQUIRED); ASSERT_EQ(1U, field_types.size()); EXPECT_EQ(NO_SERVER_DATA, field_types[0]); field_types.clear(); xml = "" "" ""; parse_handler.reset( new AutoFillQueryXmlParser(&field_types, &upload_required)); parser.reset(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(parse_handler->succeeded()); EXPECT_EQ(upload_required, USE_UPLOAD_RATES); ASSERT_EQ(1U, field_types.size()); EXPECT_EQ(NO_SERVER_DATA, field_types[0]); } // Test badly formed XML queries. TEST(AutoFillQueryXmlParserTest, ParseErrors) { std::vector field_types; UploadRequired upload_required = USE_UPLOAD_RATES; // Test no AutoFill type. std::string xml = "" "" ""; scoped_ptr parse_handler( new AutoFillQueryXmlParser(&field_types, &upload_required)); scoped_ptr parser(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_FALSE(parse_handler->succeeded()); EXPECT_EQ(upload_required, USE_UPLOAD_RATES); ASSERT_EQ(0U, field_types.size()); // Test an incorrect AutoFill type. xml = "" "" ""; parse_handler.reset( new AutoFillQueryXmlParser(&field_types, &upload_required)); parser.reset(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(parse_handler->succeeded()); EXPECT_EQ(upload_required, USE_UPLOAD_RATES); ASSERT_EQ(1U, field_types.size()); // AutoFillType was out of range and should be set to NO_SERVER_DATA. EXPECT_EQ(NO_SERVER_DATA, field_types[0]); // Test an incorrect AutoFill type. field_types.clear(); xml = "" "" ""; // Parse fails but an entry is still added to field_types. parse_handler.reset( new AutoFillQueryXmlParser(&field_types, &upload_required)); parser.reset(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_FALSE(parse_handler->succeeded()); EXPECT_EQ(upload_required, USE_UPLOAD_RATES); ASSERT_EQ(1U, field_types.size()); EXPECT_EQ(NO_SERVER_DATA, field_types[0]); } // Test successfull upload response. TEST(AutoFillUploadXmlParser, TestSuccessfulResponse) { std::string xml = ""; double positive = 0; double negative = 0; AutoFillUploadXmlParser parse_handler(&positive, &negative); buzz::XmlParser parser(&parse_handler); parser.Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(parse_handler.succeeded()); EXPECT_DOUBLE_EQ(0.5, positive); EXPECT_DOUBLE_EQ(0.3, negative); } // Test failed upload response. TEST(AutoFillUploadXmlParser, TestFailedResponse) { std::string xml = ""; double positive = 0; double negative = 0; scoped_ptr parse_handler( new AutoFillUploadXmlParser(&positive, &negative)); scoped_ptr parser(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(!parse_handler->succeeded()); EXPECT_DOUBLE_EQ(0, positive); EXPECT_DOUBLE_EQ(0.3, negative); // Partially parsed. negative = 0; xml = "Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(!parse_handler->succeeded()); EXPECT_DOUBLE_EQ(0, positive); EXPECT_DOUBLE_EQ(0, negative); xml = "bad data"; parse_handler.reset(new AutoFillUploadXmlParser(&positive, &negative)); parser.reset(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(!parse_handler->succeeded()); EXPECT_DOUBLE_EQ(0, positive); EXPECT_DOUBLE_EQ(0, negative); xml = ""; parse_handler.reset(new AutoFillUploadXmlParser(&positive, &negative)); parser.reset(new buzz::XmlParser(parse_handler.get())); parser->Parse(xml.c_str(), xml.length(), true); EXPECT_TRUE(!parse_handler->succeeded()); EXPECT_DOUBLE_EQ(0, positive); EXPECT_DOUBLE_EQ(0, negative); } } // namespace