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 |