OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <set> | 5 #include <set> |
6 #include <string> | 6 #include <string> |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/file_util.h" | 9 #include "base/file_util.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/path_service.h" | 11 #include "base/path_service.h" |
12 #include "base/string_util.h" | 12 #include "base/string_util.h" |
13 #include "base/string16.h" | 13 #include "base/string16.h" |
14 #include "base/strings/string_split.h" | 14 #include "base/strings/string_split.h" |
15 #include "base/utf_string_conversions.h" | 15 #include "base/utf_string_conversions.h" |
| 16 #include "content/browser/accessibility/accessibility_tree_formatter.h" |
16 #include "content/browser/accessibility/browser_accessibility.h" | 17 #include "content/browser/accessibility/browser_accessibility.h" |
17 #include "content/browser/accessibility/browser_accessibility_manager.h" | 18 #include "content/browser/accessibility/browser_accessibility_manager.h" |
18 #include "content/browser/accessibility/dump_accessibility_tree_helper.h" | |
19 #include "content/browser/renderer_host/render_view_host_impl.h" | 19 #include "content/browser/renderer_host/render_view_host_impl.h" |
20 #include "content/port/browser/render_widget_host_view_port.h" | 20 #include "content/port/browser/render_widget_host_view_port.h" |
21 #include "content/public/browser/web_contents.h" | 21 #include "content/public/browser/web_contents.h" |
22 #include "content/public/common/content_paths.h" | 22 #include "content/public/common/content_paths.h" |
23 #include "content/public/test/test_utils.h" | 23 #include "content/public/test/test_utils.h" |
24 #include "content/shell/shell.h" | 24 #include "content/shell/shell.h" |
25 #include "content/test/content_browser_test.h" | 25 #include "content/test/content_browser_test.h" |
26 #include "content/test/content_browser_test_utils.h" | 26 #include "content/test/content_browser_test_utils.h" |
27 #include "testing/gtest/include/gtest/gtest.h" | 27 #include "testing/gtest/include/gtest/gtest.h" |
28 | 28 |
29 namespace content { | 29 namespace content { |
30 | 30 |
31 namespace { | 31 namespace { |
32 | 32 |
33 const char kCommentToken = '#'; | 33 const char kCommentToken = '#'; |
34 const char kMarkSkipFile[] = "#<skip"; | 34 const char kMarkSkipFile[] = "#<skip"; |
35 const char kMarkEndOfFile[] = "<-- End-of-file -->"; | 35 const char kMarkEndOfFile[] = "<-- End-of-file -->"; |
36 const char kSignalDiff[] = "*"; | 36 const char kSignalDiff[] = "*"; |
37 | 37 |
38 } // namespace | 38 } // namespace |
39 | 39 |
40 typedef DumpAccessibilityTreeHelper::Filter Filter; | 40 typedef AccessibilityTreeFormatter::Filter Filter; |
41 | 41 |
42 // This test takes a snapshot of the platform BrowserAccessibility tree and | 42 // This test takes a snapshot of the platform BrowserAccessibility tree and |
43 // tests it against an expected baseline. | 43 // tests it against an expected baseline. |
44 // | 44 // |
45 // The flow of the test is as outlined below. | 45 // The flow of the test is as outlined below. |
46 // 1. Load an html file from chrome/test/data/accessibility. | 46 // 1. Load an html file from chrome/test/data/accessibility. |
47 // 2. Read the expectation. | 47 // 2. Read the expectation. |
48 // 3. Browse to the page and serialize the platform specific tree into a human | 48 // 3. Browse to the page and serialize the platform specific tree into a human |
49 // readable string. | 49 // readable string. |
50 // 4. Perform a comparison between actual and expected and fail if they do not | 50 // 4. Perform a comparison between actual and expected and fail if they do not |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
84 } | 84 } |
85 | 85 |
86 void ParseFilters(const std::string& test_html, | 86 void ParseFilters(const std::string& test_html, |
87 std::vector<Filter>* filters) { | 87 std::vector<Filter>* filters) { |
88 std::vector<std::string> lines; | 88 std::vector<std::string> lines; |
89 base::SplitString(test_html, '\n', &lines); | 89 base::SplitString(test_html, '\n', &lines); |
90 for (std::vector<std::string>::const_iterator iter = lines.begin(); | 90 for (std::vector<std::string>::const_iterator iter = lines.begin(); |
91 iter != lines.end(); | 91 iter != lines.end(); |
92 ++iter) { | 92 ++iter) { |
93 const std::string& line = *iter; | 93 const std::string& line = *iter; |
94 const std::string& allow_empty_str = helper_.GetAllowEmptyString(); | 94 const std::string& allow_empty_str = |
95 const std::string& allow_str = helper_.GetAllowString(); | 95 AccessibilityTreeFormatter::GetAllowEmptyString(); |
96 const std::string& deny_str = helper_.GetDenyString(); | 96 const std::string& allow_str = |
| 97 AccessibilityTreeFormatter::GetAllowString(); |
| 98 const std::string& deny_str = |
| 99 AccessibilityTreeFormatter::GetDenyString(); |
97 if (StartsWithASCII(line, allow_empty_str, true)) { | 100 if (StartsWithASCII(line, allow_empty_str, true)) { |
98 filters->push_back( | 101 filters->push_back( |
99 Filter(UTF8ToUTF16(line.substr(allow_empty_str.size())), | 102 Filter(UTF8ToUTF16(line.substr(allow_empty_str.size())), |
100 Filter::ALLOW_EMPTY)); | 103 Filter::ALLOW_EMPTY)); |
101 } else if (StartsWithASCII(line, allow_str, true)) { | 104 } else if (StartsWithASCII(line, allow_str, true)) { |
102 filters->push_back(Filter(UTF8ToUTF16(line.substr(allow_str.size())), | 105 filters->push_back(Filter(UTF8ToUTF16(line.substr(allow_str.size())), |
103 Filter::ALLOW)); | 106 Filter::ALLOW)); |
104 } else if (StartsWithASCII(line, deny_str, true)) { | 107 } else if (StartsWithASCII(line, deny_str, true)) { |
105 filters->push_back(Filter(UTF8ToUTF16(line.substr(deny_str.size())), | 108 filters->push_back(Filter(UTF8ToUTF16(line.substr(deny_str.size())), |
106 Filter::DENY)); | 109 Filter::DENY)); |
107 } | 110 } |
108 } | 111 } |
109 } | 112 } |
110 | 113 |
111 void RunTest(const base::FilePath::CharType* file_path); | 114 void RunTest(const base::FilePath::CharType* file_path); |
112 | |
113 DumpAccessibilityTreeHelper helper_; | |
114 }; | 115 }; |
115 | 116 |
116 void DumpAccessibilityTreeTest::RunTest( | 117 void DumpAccessibilityTreeTest::RunTest( |
117 const base::FilePath::CharType* file_path) { | 118 const base::FilePath::CharType* file_path) { |
118 NavigateToURL(shell(), GURL("about:blank")); | 119 NavigateToURL(shell(), GURL("about:blank")); |
119 RenderWidgetHostViewPort* host_view = static_cast<RenderWidgetHostViewPort*>( | 120 RenderWidgetHostViewPort* host_view = static_cast<RenderWidgetHostViewPort*>( |
120 shell()->web_contents()->GetRenderWidgetHostView()); | 121 shell()->web_contents()->GetRenderWidgetHostView()); |
121 RenderWidgetHostImpl* host = | 122 RenderWidgetHostImpl* host = |
122 RenderWidgetHostImpl::From(host_view->GetRenderWidgetHost()); | 123 RenderWidgetHostImpl::From(host_view->GetRenderWidgetHost()); |
123 RenderViewHostImpl* view_host = static_cast<RenderViewHostImpl*>(host); | 124 RenderViewHostImpl* view_host = static_cast<RenderViewHostImpl*>(host); |
124 view_host->set_save_accessibility_tree_for_testing(true); | 125 view_host->set_save_accessibility_tree_for_testing(true); |
125 view_host->SetAccessibilityMode(AccessibilityModeComplete); | 126 view_host->SetAccessibilityMode(AccessibilityModeComplete); |
126 | 127 |
127 // Setup test paths. | 128 // Setup test paths. |
128 base::FilePath dir_test_data; | 129 base::FilePath dir_test_data; |
129 ASSERT_TRUE(PathService::Get(DIR_TEST_DATA, &dir_test_data)); | 130 ASSERT_TRUE(PathService::Get(DIR_TEST_DATA, &dir_test_data)); |
130 base::FilePath test_path( | 131 base::FilePath test_path( |
131 dir_test_data.Append(FILE_PATH_LITERAL("accessibility"))); | 132 dir_test_data.Append(FILE_PATH_LITERAL("accessibility"))); |
132 ASSERT_TRUE(file_util::PathExists(test_path)) | 133 ASSERT_TRUE(file_util::PathExists(test_path)) |
133 << test_path.LossyDisplayName(); | 134 << test_path.LossyDisplayName(); |
134 | 135 |
135 base::FilePath html_file = test_path.Append(base::FilePath(file_path)); | 136 base::FilePath html_file = test_path.Append(base::FilePath(file_path)); |
136 // Output the test path to help anyone who encounters a failure and needs | 137 // Output the test path to help anyone who encounters a failure and needs |
137 // to know where to look. | 138 // to know where to look. |
138 printf("Testing: %s\n", html_file.MaybeAsASCII().c_str()); | 139 printf("Testing: %s\n", html_file.MaybeAsASCII().c_str()); |
139 | 140 |
140 std::string html_contents; | 141 std::string html_contents; |
141 file_util::ReadFileToString(html_file, &html_contents); | 142 file_util::ReadFileToString(html_file, &html_contents); |
142 | 143 |
143 // Parse filters in the test file. | |
144 std::vector<Filter> filters; | |
145 AddDefaultFilters(&filters); | |
146 ParseFilters(html_contents, &filters); | |
147 helper_.SetFilters(filters); | |
148 | |
149 // Read the expected file. | 144 // Read the expected file. |
150 std::string expected_contents_raw; | 145 std::string expected_contents_raw; |
151 base::FilePath expected_file = | 146 base::FilePath expected_file = |
152 base::FilePath(html_file.RemoveExtension().value() + | 147 base::FilePath(html_file.RemoveExtension().value() + |
153 helper_.GetExpectedFileSuffix()); | 148 AccessibilityTreeFormatter::GetExpectedFileSuffix()); |
154 file_util::ReadFileToString( | 149 file_util::ReadFileToString(expected_file, &expected_contents_raw); |
155 expected_file, | |
156 &expected_contents_raw); | |
157 | 150 |
158 // Tolerate Windows-style line endings (\r\n) in the expected file: | 151 // Tolerate Windows-style line endings (\r\n) in the expected file: |
159 // normalize by deleting all \r from the file (if any) to leave only \n. | 152 // normalize by deleting all \r from the file (if any) to leave only \n. |
160 std::string expected_contents; | 153 std::string expected_contents; |
161 RemoveChars(expected_contents_raw, "\r", &expected_contents); | 154 RemoveChars(expected_contents_raw, "\r", &expected_contents); |
162 | 155 |
163 if (!expected_contents.compare(0, strlen(kMarkSkipFile), kMarkSkipFile)) { | 156 if (!expected_contents.compare(0, strlen(kMarkSkipFile), kMarkSkipFile)) { |
164 printf("Skipping this test on this platform.\n"); | 157 printf("Skipping this test on this platform.\n"); |
165 return; | 158 return; |
166 } | 159 } |
167 | 160 |
168 // Load the page. | 161 // Load the page. |
169 string16 html_contents16; | 162 string16 html_contents16; |
170 html_contents16 = UTF8ToUTF16(html_contents); | 163 html_contents16 = UTF8ToUTF16(html_contents); |
171 GURL url = GetTestUrl("accessibility", | 164 GURL url = GetTestUrl("accessibility", |
172 html_file.BaseName().MaybeAsASCII().c_str()); | 165 html_file.BaseName().MaybeAsASCII().c_str()); |
173 scoped_refptr<MessageLoopRunner> loop_runner(new MessageLoopRunner); | 166 scoped_refptr<MessageLoopRunner> loop_runner(new MessageLoopRunner); |
174 view_host->SetAccessibilityLoadCompleteCallbackForTesting( | 167 view_host->SetAccessibilityLoadCompleteCallbackForTesting( |
175 loop_runner->QuitClosure()); | 168 loop_runner->QuitClosure()); |
176 NavigateToURL(shell(), url); | 169 NavigateToURL(shell(), url); |
177 | 170 |
178 // Wait for the tree. | 171 // Wait for the tree. |
179 loop_runner->Run(); | 172 loop_runner->Run(); |
180 | 173 |
| 174 AccessibilityTreeFormatter formatter( |
| 175 host_view->GetBrowserAccessibilityManager()->GetRoot()); |
| 176 |
| 177 // Parse filters in the test file. |
| 178 std::vector<Filter> filters; |
| 179 AddDefaultFilters(&filters); |
| 180 ParseFilters(html_contents, &filters); |
| 181 formatter.SetFilters(filters); |
| 182 |
181 // Perform a diff (or write the initial baseline). | 183 // Perform a diff (or write the initial baseline). |
182 string16 actual_contents_utf16; | 184 string16 actual_contents_utf16; |
183 helper_.DumpAccessibilityTree( | 185 formatter.FormatAccessibilityTree(&actual_contents_utf16); |
184 host_view->GetBrowserAccessibilityManager()->GetRoot(), | |
185 &actual_contents_utf16); | |
186 std::string actual_contents = UTF16ToUTF8(actual_contents_utf16); | 186 std::string actual_contents = UTF16ToUTF8(actual_contents_utf16); |
187 std::vector<std::string> actual_lines, expected_lines; | 187 std::vector<std::string> actual_lines, expected_lines; |
188 Tokenize(actual_contents, "\n", &actual_lines); | 188 Tokenize(actual_contents, "\n", &actual_lines); |
189 Tokenize(expected_contents, "\n", &expected_lines); | 189 Tokenize(expected_contents, "\n", &expected_lines); |
190 // Marking the end of the file with a line of text ensures that | 190 // Marking the end of the file with a line of text ensures that |
191 // file length differences are found. | 191 // file length differences are found. |
192 expected_lines.push_back(kMarkEndOfFile); | 192 expected_lines.push_back(kMarkEndOfFile); |
193 actual_lines.push_back(kMarkEndOfFile); | 193 actual_lines.push_back(kMarkEndOfFile); |
194 | 194 |
195 std::vector<int> diff_lines = DiffLines(expected_lines, actual_lines); | 195 std::vector<int> diff_lines = DiffLines(expected_lines, actual_lines); |
(...skipping 16 matching lines...) Expand all Loading... |
212 expected_lines[line].c_str()); | 212 expected_lines[line].c_str()); |
213 } | 213 } |
214 printf("\nActual\n"); | 214 printf("\nActual\n"); |
215 printf("------\n"); | 215 printf("------\n"); |
216 printf("%s\n", actual_contents.c_str()); | 216 printf("%s\n", actual_contents.c_str()); |
217 } | 217 } |
218 | 218 |
219 if (!file_util::PathExists(expected_file)) { | 219 if (!file_util::PathExists(expected_file)) { |
220 base::FilePath actual_file = | 220 base::FilePath actual_file = |
221 base::FilePath(html_file.RemoveExtension().value() + | 221 base::FilePath(html_file.RemoveExtension().value() + |
222 helper_.GetActualFileSuffix()); | 222 AccessibilityTreeFormatter::GetActualFileSuffix()); |
223 | 223 |
224 EXPECT_TRUE(file_util::WriteFile( | 224 EXPECT_TRUE(file_util::WriteFile( |
225 actual_file, actual_contents.c_str(), actual_contents.size())); | 225 actual_file, actual_contents.c_str(), actual_contents.size())); |
226 | 226 |
227 ADD_FAILURE() << "No expectation found. Create it by doing:\n" | 227 ADD_FAILURE() << "No expectation found. Create it by doing:\n" |
228 << "mv " << actual_file.LossyDisplayName() << " " | 228 << "mv " << actual_file.LossyDisplayName() << " " |
229 << expected_file.LossyDisplayName(); | 229 << expected_file.LossyDisplayName(); |
230 } | 230 } |
231 } | 231 } |
232 | 232 |
(...skipping 202 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
435 | 435 |
436 IN_PROC_BROWSER_TEST_F(DumpAccessibilityTreeTest, AccessibilityUl) { | 436 IN_PROC_BROWSER_TEST_F(DumpAccessibilityTreeTest, AccessibilityUl) { |
437 RunTest(FILE_PATH_LITERAL("ul.html")); | 437 RunTest(FILE_PATH_LITERAL("ul.html")); |
438 } | 438 } |
439 | 439 |
440 IN_PROC_BROWSER_TEST_F(DumpAccessibilityTreeTest, AccessibilityWbr) { | 440 IN_PROC_BROWSER_TEST_F(DumpAccessibilityTreeTest, AccessibilityWbr) { |
441 RunTest(FILE_PATH_LITERAL("wbr.html")); | 441 RunTest(FILE_PATH_LITERAL("wbr.html")); |
442 } | 442 } |
443 | 443 |
444 } // namespace content | 444 } // namespace content |
OLD | NEW |