OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <stddef.h> | 5 #include <stddef.h> |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/base_paths.h" | 9 #include "base/base_paths.h" |
10 #include "base/files/file_enumerator.h" | 10 #include "base/files/file_enumerator.h" |
(...skipping 21 matching lines...) Expand all Loading... | |
32 #include "chrome/test/base/ui_test_utils.h" | 32 #include "chrome/test/base/ui_test_utils.h" |
33 #include "components/zoom/page_zoom.h" | 33 #include "components/zoom/page_zoom.h" |
34 #include "components/zoom/test/zoom_test_utils.h" | 34 #include "components/zoom/test/zoom_test_utils.h" |
35 #include "components/zoom/zoom_controller.h" | 35 #include "components/zoom/zoom_controller.h" |
36 #include "content/public/browser/browser_accessibility_state.h" | 36 #include "content/public/browser/browser_accessibility_state.h" |
37 #include "content/public/browser/browser_plugin_guest_manager.h" | 37 #include "content/public/browser/browser_plugin_guest_manager.h" |
38 #include "content/public/browser/download_item.h" | 38 #include "content/public/browser/download_item.h" |
39 #include "content/public/browser/download_manager.h" | 39 #include "content/public/browser/download_manager.h" |
40 #include "content/public/browser/notification_observer.h" | 40 #include "content/public/browser/notification_observer.h" |
41 #include "content/public/browser/notification_registrar.h" | 41 #include "content/public/browser/notification_registrar.h" |
42 #include "content/public/browser/notification_service.h" | |
42 #include "content/public/browser/plugin_service.h" | 43 #include "content/public/browser/plugin_service.h" |
43 #include "content/public/browser/render_process_host.h" | 44 #include "content/public/browser/render_process_host.h" |
44 #include "content/public/browser/render_view_host.h" | 45 #include "content/public/browser/render_view_host.h" |
45 #include "content/public/browser/render_widget_host.h" | 46 #include "content/public/browser/render_widget_host.h" |
46 #include "content/public/browser/web_contents.h" | 47 #include "content/public/browser/web_contents.h" |
47 #include "content/public/test/browser_test_utils.h" | 48 #include "content/public/test/browser_test_utils.h" |
48 #include "extensions/browser/extension_registry.h" | 49 #include "extensions/browser/extension_registry.h" |
49 #include "extensions/common/manifest_handlers/mime_types_handler.h" | 50 #include "extensions/common/manifest_handlers/mime_types_handler.h" |
50 #include "extensions/test/result_catcher.h" | 51 #include "extensions/test/result_catcher.h" |
51 #include "net/test/embedded_test_server/embedded_test_server.h" | 52 #include "net/test/embedded_test_server/embedded_test_server.h" |
(...skipping 526 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
578 " paragraph\n" | 579 " paragraph\n" |
579 " staticText '3'\n" | 580 " staticText '3'\n" |
580 " inlineTextBox '3'\n"; | 581 " inlineTextBox '3'\n"; |
581 | 582 |
582 // Using ASSERT_TRUE deliberately instead of ASSERT_EQ or ASSERT_STREQ | 583 // Using ASSERT_TRUE deliberately instead of ASSERT_EQ or ASSERT_STREQ |
583 // in order to print a more readable message if the strings differ. | 584 // in order to print a more readable message if the strings differ. |
584 ASSERT_TRUE(expected_ax_tree == ax_tree_dump) | 585 ASSERT_TRUE(expected_ax_tree == ax_tree_dump) |
585 << "Expected:\n" << expected_ax_tree | 586 << "Expected:\n" << expected_ax_tree |
586 << "\n\nActual:\n" << ax_tree_dump; | 587 << "\n\nActual:\n" << ax_tree_dump; |
587 } | 588 } |
589 | |
590 IN_PROC_BROWSER_TEST_F(PDFExtensionTest, LinkMiddleClick) { | |
591 GURL test_pdf_url(embedded_test_server()->GetURL("/pdf/test-link.pdf")); | |
592 ui_test_utils::NavigateToURL(browser(), test_pdf_url); | |
593 | |
594 content::WebContents* web_contents = | |
595 browser()->tab_strip_model()->GetActiveWebContents(); | |
596 ASSERT_TRUE(pdf_extension_test_util::EnsurePDFHasLoaded(web_contents)); | |
597 | |
598 int x; | |
599 ASSERT_TRUE(content::ExecuteScriptAndExtractInt( | |
600 web_contents, | |
601 "window.addEventListener('message', function(event) {" | |
602 " if (event.data.type == 'getLinkPositionReply')" | |
603 " window.domAutomationController.send(Math.floor(event.data.x));" | |
604 " window.removeEventListener(event.type, arguments.callee);" | |
605 "});" | |
606 "document.getElementsByTagName('embed')[0].postMessage(" | |
607 " {type: 'getLinkPosition'});", | |
608 &x)); | |
609 | |
610 int y; | |
611 ASSERT_TRUE(content::ExecuteScriptAndExtractInt( | |
612 web_contents, | |
613 "window.addEventListener('message', function(event) {" | |
614 " if (event.data.type == 'getLinkPositionReply')" | |
615 " window.domAutomationController.send(Math.floor(event.data.y));" | |
616 " window.removeEventListener(event.type, arguments.callee);" | |
617 "});" | |
618 "document.getElementsByTagName('embed')[0].postMessage(" | |
619 " {type: 'getLinkPosition'});", | |
Lei Zhang
2016/07/08 18:02:35
It feels like a bit more work to have to post 2 ge
jaepark
2016/07/08 20:58:16
Done.
| |
620 &y)); | |
621 | |
622 gfx::Point point(x, y); | |
623 content::WindowedNotificationObserver observer( | |
624 chrome::NOTIFICATION_TAB_ADDED, | |
625 content::NotificationService::AllSources()); | |
626 content::SimulateMouseClickAt(web_contents, 0, | |
627 blink::WebMouseEvent::ButtonMiddle, point); | |
628 observer.Wait(); | |
629 | |
630 int tab_count = browser()->tab_strip_model()->count(); | |
631 ASSERT_EQ(2, tab_count); | |
632 | |
633 const GURL& url = | |
634 browser()->tab_strip_model()->GetActiveWebContents()->GetURL(); | |
635 ASSERT_EQ(std::string("https://www.google.com/"), url.spec()); | |
Lei Zhang
2016/07/08 18:02:35
Can we do example.com and add:
host_resolver()->A
jaepark
2016/07/08 20:58:16
Done.
| |
636 } | |
637 | |
OLD | NEW |