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 "base/strings/string16.h" | 5 #include "base/strings/string16.h" |
6 #include "base/strings/string_util.h" | 6 #include "base/strings/string_util.h" |
7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
8 #include "content/public/browser/native_web_keyboard_event.h" | 8 #include "content/public/browser/native_web_keyboard_event.h" |
9 #include "content/public/common/web_preferences.h" | 9 #include "content/public/common/web_preferences.h" |
10 #include "content/public/test/render_view_test.h" | 10 #include "content/public/test/render_view_test.h" |
11 #include "content/renderer/render_view_impl.h" | 11 #include "content/renderer/render_view_impl.h" |
12 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
| 13 #include "third_party/WebKit/public/web/WebFrameContentDumper.h" |
13 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 14 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
14 | 15 |
15 #include <Carbon/Carbon.h> // for the kVK_* constants. | 16 #include <Carbon/Carbon.h> // for the kVK_* constants. |
16 #include <Cocoa/Cocoa.h> | 17 #include <Cocoa/Cocoa.h> |
17 | 18 |
| 19 using blink::WebFrameContentDumper; |
| 20 |
18 namespace content { | 21 namespace content { |
19 | 22 |
20 NSEvent* CmdDeadKeyEvent(NSEventType type, unsigned short code) { | 23 NSEvent* CmdDeadKeyEvent(NSEventType type, unsigned short code) { |
21 UniChar uniChar = 0; | 24 UniChar uniChar = 0; |
22 switch(code) { | 25 switch(code) { |
23 case kVK_UpArrow: | 26 case kVK_UpArrow: |
24 uniChar = NSUpArrowFunctionKey; | 27 uniChar = NSUpArrowFunctionKey; |
25 break; | 28 break; |
26 case kVK_DownArrow: | 29 case kVK_DownArrow: |
27 uniChar = NSDownArrowFunctionKey; | 30 uniChar = NSDownArrowFunctionKey; |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
97 view->set_send_content_state_immediately(true); | 100 view->set_send_content_state_immediately(true); |
98 LoadHTML(kRawHtml); | 101 LoadHTML(kRawHtml); |
99 render_thread_->sink().ClearMessages(); | 102 render_thread_->sink().ClearMessages(); |
100 | 103 |
101 const char* kArrowDownScrollDown = "40,false,false,true,false\n10144\np1"; | 104 const char* kArrowDownScrollDown = "40,false,false,true,false\n10144\np1"; |
102 view->OnSetEditCommandsForNextKeyEvent( | 105 view->OnSetEditCommandsForNextKeyEvent( |
103 EditCommands(1, EditCommand("moveToEndOfDocument", ""))); | 106 EditCommands(1, EditCommand("moveToEndOfDocument", ""))); |
104 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowDownKeyDown)); | 107 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowDownKeyDown)); |
105 ProcessPendingMessages(); | 108 ProcessPendingMessages(); |
106 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); | 109 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); |
107 output = GetMainFrame()->contentAsText(kMaxOutputCharacters); | 110 output = WebFrameContentDumper::dumpFrameTreeAsText(GetMainFrame(), |
| 111 kMaxOutputCharacters); |
108 EXPECT_EQ(kArrowDownScrollDown, base::UTF16ToASCII(output)); | 112 EXPECT_EQ(kArrowDownScrollDown, base::UTF16ToASCII(output)); |
109 | 113 |
110 const char* kArrowUpScrollUp = "38,false,false,true,false\n0\np1"; | 114 const char* kArrowUpScrollUp = "38,false,false,true,false\n0\np1"; |
111 view->OnSetEditCommandsForNextKeyEvent( | 115 view->OnSetEditCommandsForNextKeyEvent( |
112 EditCommands(1, EditCommand("moveToBeginningOfDocument", ""))); | 116 EditCommands(1, EditCommand("moveToBeginningOfDocument", ""))); |
113 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowUpKeyDown)); | 117 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowUpKeyDown)); |
114 ProcessPendingMessages(); | 118 ProcessPendingMessages(); |
115 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); | 119 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); |
116 output = GetMainFrame()->contentAsText(kMaxOutputCharacters); | 120 output = WebFrameContentDumper::dumpFrameTreeAsText(GetMainFrame(), |
| 121 kMaxOutputCharacters); |
117 EXPECT_EQ(kArrowUpScrollUp, base::UTF16ToASCII(output)); | 122 EXPECT_EQ(kArrowUpScrollUp, base::UTF16ToASCII(output)); |
118 | 123 |
119 // Now let javascript eat the key events -- no scrolling should happen. | 124 // Now let javascript eat the key events -- no scrolling should happen. |
120 // Set a scroll position slightly down the page to ensure that it does not | 125 // Set a scroll position slightly down the page to ensure that it does not |
121 // move. | 126 // move. |
122 ExecuteJavaScriptForTests("allowKeyEvents = false; window.scrollTo(0, 100)"); | 127 ExecuteJavaScriptForTests("allowKeyEvents = false; window.scrollTo(0, 100)"); |
123 | 128 |
124 const char* kArrowDownNoScroll = "40,false,false,true,false\n100\np1"; | 129 const char* kArrowDownNoScroll = "40,false,false,true,false\n100\np1"; |
125 view->OnSetEditCommandsForNextKeyEvent( | 130 view->OnSetEditCommandsForNextKeyEvent( |
126 EditCommands(1, EditCommand("moveToEndOfDocument", ""))); | 131 EditCommands(1, EditCommand("moveToEndOfDocument", ""))); |
127 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowDownKeyDown)); | 132 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowDownKeyDown)); |
128 ProcessPendingMessages(); | 133 ProcessPendingMessages(); |
129 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); | 134 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); |
130 output = GetMainFrame()->contentAsText(kMaxOutputCharacters); | 135 output = WebFrameContentDumper::dumpFrameTreeAsText(GetMainFrame(), |
| 136 kMaxOutputCharacters); |
131 EXPECT_EQ(kArrowDownNoScroll, base::UTF16ToASCII(output)); | 137 EXPECT_EQ(kArrowDownNoScroll, base::UTF16ToASCII(output)); |
132 | 138 |
133 const char* kArrowUpNoScroll = "38,false,false,true,false\n100\np1"; | 139 const char* kArrowUpNoScroll = "38,false,false,true,false\n100\np1"; |
134 view->OnSetEditCommandsForNextKeyEvent( | 140 view->OnSetEditCommandsForNextKeyEvent( |
135 EditCommands(1, EditCommand("moveToBeginningOfDocument", ""))); | 141 EditCommands(1, EditCommand("moveToBeginningOfDocument", ""))); |
136 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowUpKeyDown)); | 142 SendNativeKeyEvent(NativeWebKeyboardEvent(arrowUpKeyDown)); |
137 ProcessPendingMessages(); | 143 ProcessPendingMessages(); |
138 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); | 144 ExecuteJavaScriptForTests("scroll.textContent = window.pageYOffset"); |
139 output = GetMainFrame()->contentAsText(kMaxOutputCharacters); | 145 output = WebFrameContentDumper::dumpFrameTreeAsText(GetMainFrame(), |
| 146 kMaxOutputCharacters); |
140 EXPECT_EQ(kArrowUpNoScroll, base::UTF16ToASCII(output)); | 147 EXPECT_EQ(kArrowUpNoScroll, base::UTF16ToASCII(output)); |
141 } | 148 } |
142 | 149 |
143 } // namespace content | 150 } // namespace content |
OLD | NEW |