Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "components/autofill/core/common/autofill_util.h" | |
| 6 | |
| 7 #include "base/command_line.h" | |
| 8 #include "base/strings/utf_string_conversions.h" | |
| 9 #include "components/autofill/core/common/autofill_switches.h" | |
| 10 #include "testing/gtest/include/gtest/gtest.h" | |
| 11 | |
| 12 namespace autofill { | |
| 13 | |
| 14 // Tests for ContainsTokenThatStartsWith(). | |
| 15 TEST(AutofillUtilTest, ContainsTokenThatStartsWith) { | |
| 16 // ContainsTokenThatStartsWith should not work yet without a flag. | |
| 17 EXPECT_FALSE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 18 base::ASCIIToUTF16("a"), false)); | |
| 19 | |
| 20 // Token matching is currently behind a flag. | |
| 21 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 22 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 23 | |
| 24 EXPECT_TRUE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
|
please use gerrit instead
2015/06/29 22:06:29
Use an array of structs similar to the next test c
Pritam Nikam
2015/06/30 15:05:51
Done.
| |
| 25 base::ASCIIToUTF16("a"), false)); | |
| 26 EXPECT_TRUE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 27 base::ASCIIToUTF16("b"), false)); | |
| 28 EXPECT_TRUE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 29 base::ASCIIToUTF16("Ab"), false)); | |
| 30 EXPECT_FALSE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 31 base::ASCIIToUTF16("Ab"), true)); | |
| 32 EXPECT_TRUE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 33 base::ASCIIToUTF16("cd"), true)); | |
| 34 EXPECT_FALSE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 35 base::ASCIIToUTF16("d"), false)); | |
| 36 EXPECT_FALSE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 37 base::ASCIIToUTF16("b@"), true)); | |
| 38 EXPECT_FALSE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab@cd.b"), | |
| 39 base::ASCIIToUTF16("cd.b"), false)); | |
| 40 EXPECT_FALSE(ContainsTokenThatStartsWith(base::string16(), | |
| 41 base::ASCIIToUTF16("ab"), false)); | |
| 42 EXPECT_FALSE(ContainsTokenThatStartsWith(base::string16(), | |
| 43 base::ASCIIToUTF16("ab"), true)); | |
| 44 EXPECT_TRUE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab"), | |
| 45 base::string16(), false)); | |
| 46 EXPECT_TRUE(ContainsTokenThatStartsWith(base::ASCIIToUTF16("ab"), | |
| 47 base::string16(), true)); | |
| 48 } | |
| 49 | |
| 50 // Tests for GetTextSelectionStart(). | |
| 51 TEST(AutofillUtilTest, GetTextSelectionStart) { | |
| 52 const struct { | |
| 53 base::string16 field_suggestion; | |
|
please use gerrit instead
2015/06/29 22:06:29
Use "char*" instead of "base::string16". Don't bas
Pritam Nikam
2015/06/30 15:05:51
Done.
| |
| 54 base::string16 field_contents; | |
| 55 size_t expected_start; | |
| 56 } test_cases[] = { | |
| 57 {base::ASCIIToUTF16("ab@cd.b"), base::ASCIIToUTF16("a"), 1}, | |
| 58 {base::ASCIIToUTF16("ab@cd.b"), base::ASCIIToUTF16("Ab"), 2}, | |
| 59 {base::ASCIIToUTF16("ab@cd.b"), base::ASCIIToUTF16("cd"), 5}, | |
| 60 {base::ASCIIToUTF16("ab@cd.b"), base::ASCIIToUTF16("ab@c"), 4}, | |
| 61 {base::ASCIIToUTF16("ab@cd.b"), base::ASCIIToUTF16("cd.b"), 7}, | |
| 62 {base::ASCIIToUTF16("ab@cd.b"), base::ASCIIToUTF16("b"), 7}, | |
| 63 {base::ASCIIToUTF16("ba.a.ab"), base::ASCIIToUTF16("a.a"), 6}, | |
| 64 {base::ASCIIToUTF16("texample@example.com"), | |
| 65 base::ASCIIToUTF16("example"), | |
| 66 16}}; | |
| 67 | |
| 68 for (size_t i = 0; i < arraysize(test_cases); ++i) { | |
| 69 SCOPED_TRACE(testing::Message() | |
| 70 << "suggestion = " << test_cases[i].field_suggestion | |
| 71 << ", contents = " << test_cases[i].field_contents); | |
| 72 | |
| 73 size_t start = GetTextSelectionStart(test_cases[i].field_suggestion, | |
| 74 test_cases[i].field_contents); | |
| 75 EXPECT_EQ(test_cases[i].expected_start, start); | |
| 76 } | |
| 77 } | |
| 78 | |
| 79 } // autofill | |
| OLD | NEW |