summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/common/gpu_plugin.cc3
-rw-r--r--webkit/data/layout_tests/platform/chromium-win/LayoutTests/http/tests/plugins/plugin-document-has-focus-expected.txt3
-rw-r--r--webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/README10
-rw-r--r--webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/keyboard-events-expected.txt11
-rw-r--r--webkit/tools/layout_tests/test_expectations.txt5
-rw-r--r--webkit/tools/npapi_layout_test_plugin/PluginObject.cpp1
-rw-r--r--webkit/tools/npapi_layout_test_plugin/PluginObject.h1
-rw-r--r--webkit/tools/npapi_layout_test_plugin/main.cpp24
-rw-r--r--webkit/tools/test_shell/event_sending_controller.cc14
-rw-r--r--webkit/tools/test_shell/event_sending_controller.h16
-rw-r--r--webkit/tools/test_shell/test_shell.h3
-rw-r--r--webkit/tools/test_shell/test_shell_win.cc18
-rw-r--r--webkit/tools/test_shell/test_webview_delegate.cc3
13 files changed, 72 insertions, 40 deletions
diff --git a/chrome/common/gpu_plugin.cc b/chrome/common/gpu_plugin.cc
index d9d67db..af009f9 100644
--- a/chrome/common/gpu_plugin.cc
+++ b/chrome/common/gpu_plugin.cc
@@ -2,10 +2,11 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include "chrome/common/gpu_plugin.h"
+
#include "base/command_line.h"
#include "base/string_util.h"
#include "chrome/common/chrome_switches.h"
-#include "chrome/common/gpu_plugin.h"
#include "gpu/gpu_plugin/gpu_plugin.h"
#include "webkit/glue/plugins/plugin_list.h"
diff --git a/webkit/data/layout_tests/platform/chromium-win/LayoutTests/http/tests/plugins/plugin-document-has-focus-expected.txt b/webkit/data/layout_tests/platform/chromium-win/LayoutTests/http/tests/plugins/plugin-document-has-focus-expected.txt
new file mode 100644
index 0000000..07a9506
--- /dev/null
+++ b/webkit/data/layout_tests/platform/chromium-win/LayoutTests/http/tests/plugins/plugin-document-has-focus-expected.txt
@@ -0,0 +1,3 @@
+CONSOLE MESSAGE: line 1: PLUGIN: keyDown 'A'
+CONSOLE MESSAGE: line 1: PLUGIN: keyUp 'A'
+This tests that a full page plugin gets keyboard focus without the need to first click it. \ No newline at end of file
diff --git a/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/README b/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/README
index b3f7df8..5e2667d 100644
--- a/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/README
+++ b/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/README
@@ -4,4 +4,12 @@ inner-html-display-none
-----------------------
The only difference is whitespace differences in the
-way functions are printed. \ No newline at end of file
+way functions are printed.
+
+
+keyboard-events
+---------------
+
+On Windows, windowless plugins get the shift state of the keyboard by quering the OS, since the
+WM_KEYDOWN message doesn't contain that information. This is impossible to simulate through
+eventSender(). \ No newline at end of file
diff --git a/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/keyboard-events-expected.txt b/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/keyboard-events-expected.txt
new file mode 100644
index 0000000..c944349
--- /dev/null
+++ b/webkit/data/layout_tests/platform/chromium-win/LayoutTests/plugins/keyboard-events-expected.txt
@@ -0,0 +1,11 @@
+CONSOLE MESSAGE: line 17: PLUGIN: getFocusEvent
+CONSOLE MESSAGE: line 17: PLUGIN: mouseDown at (20, 20)
+CONSOLE MESSAGE: line 18: PLUGIN: mouseUp at (20, 20)
+CONSOLE MESSAGE: line 21: PLUGIN: keyDown 'A'
+CONSOLE MESSAGE: line 21: PLUGIN: keyUp 'A'
+CONSOLE MESSAGE: line 22: PLUGIN: keyDown 'B'
+CONSOLE MESSAGE: line 22: PLUGIN: keyUp 'B'
+CONSOLE MESSAGE: line 23: PLUGIN: keyDown 'C'
+CONSOLE MESSAGE: line 23: PLUGIN: keyUp 'C'
+
+This test checks if a plug-in can receive keyboard events sent from eventSender. This is a test for Bug 34936.
diff --git a/webkit/tools/layout_tests/test_expectations.txt b/webkit/tools/layout_tests/test_expectations.txt
index 7975fa8..662c89a 100644
--- a/webkit/tools/layout_tests/test_expectations.txt
+++ b/webkit/tools/layout_tests/test_expectations.txt
@@ -2790,7 +2790,6 @@ BUG37896 WIN DEBUG : fast/text/firstline/001.html = PASS CRASH
BUG37896 LINUX MAC DEBUG : fast/text/firstline/001.html = PASS CRASH TIMEOUT
// Added in http://trac.webkit.org/changeset/55587
BUG37896 : media/video-preload.html = TEXT
-BUG37896 : plugins/keyboard-events.html = TEXT
BUG37896 LINUX DEBUG : fast/images/svg-as-background.html = TIMEOUT
BUG37869 LINUX : fast/images/animated-svg-as-image.html = IMAGE
BUG37869 MAC LINUX SKIP : inspector/timeline-network-resource.html = CRASH
@@ -2832,3 +2831,7 @@ BUG36415 : fast/events/touch/basic-multi-touch-events.html = TEXT
// Most touch tests flaky on WIN for reasons currently unknown.
BUG38347 WIN : fast/events/touch = TEXT PASS
+
+// Need to implement NPP_HandleEvent in the layout_test_plugin
+BUG38353 MAC LINUX : plugins/keyboard-events.html = TEXT
+BUG38353 MAC LINUX : http/tests/plugins/plugin-document-has-focus.html = TEXT
diff --git a/webkit/tools/npapi_layout_test_plugin/PluginObject.cpp b/webkit/tools/npapi_layout_test_plugin/PluginObject.cpp
index 4b310ef..026d74f 100644
--- a/webkit/tools/npapi_layout_test_plugin/PluginObject.cpp
+++ b/webkit/tools/npapi_layout_test_plugin/PluginObject.cpp
@@ -982,6 +982,7 @@ static NPObject *pluginAllocate(NPP npp, NPClass *theClass)
newInstance->testDocumentOpenInDestroyStream = FALSE;
newInstance->testWindowOpen = FALSE;
+ newInstance->testKeyboardFocusForPlugins = FALSE;
return (NPObject*)newInstance;
}
diff --git a/webkit/tools/npapi_layout_test_plugin/PluginObject.h b/webkit/tools/npapi_layout_test_plugin/PluginObject.h
index 5cab228..8cd63ef 100644
--- a/webkit/tools/npapi_layout_test_plugin/PluginObject.h
+++ b/webkit/tools/npapi_layout_test_plugin/PluginObject.h
@@ -38,6 +38,7 @@ typedef struct {
NPStream* stream;
NPBool testWindowOpen;
NPBool testDocumentOpenInDestroyStream;
+ NPBool testKeyboardFocusForPlugins;
char* onStreamLoad;
char* onStreamDestroy;
char* onURLNotify;
diff --git a/webkit/tools/npapi_layout_test_plugin/main.cpp b/webkit/tools/npapi_layout_test_plugin/main.cpp
index a644d03..9ff3ebb 100644
--- a/webkit/tools/npapi_layout_test_plugin/main.cpp
+++ b/webkit/tools/npapi_layout_test_plugin/main.cpp
@@ -140,7 +140,8 @@ NPError NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode, int16 argc, ch
obj->testDocumentOpenInDestroyStream = TRUE;
} else if (strcasecmp(argn[i], "testwindowopen") == 0) {
obj->testWindowOpen = TRUE;
- }
+ } else if (strcasecmp(argn[i], "src") == 0 && strstr(argv[i], "plugin-document-has-focus.pl"))
+ obj->testKeyboardFocusForPlugins = TRUE;
}
instance->pdata = obj;
@@ -182,13 +183,18 @@ NPError NPP_SetWindow(NPP instance, NPWindow *window)
if (obj->logSetWindow) {
log(instance, "NPP_SetWindow: %d %d", (int)window->width, (int)window->height);
fflush(stdout);
- obj->logSetWindow = false;
+ obj->logSetWindow = FALSE;
}
if (obj->testWindowOpen) {
testWindowOpen(instance);
obj->testWindowOpen = FALSE;
}
+
+ if (obj->testKeyboardFocusForPlugins) {
+ obj->eventLogging = true;
+ executeScript(obj, "eventSender.keyDown('A');");
+ }
}
return NPERR_NO_ERROR;
@@ -292,17 +298,17 @@ int16 NPP_HandleEvent(NPP instance, void *event)
case WM_RBUTTONDBLCLK:
break;
case WM_MOUSEMOVE:
- log(instance, "adjustCursorEvent");
break;
case WM_KEYUP:
- // TODO(tc): We need to convert evt->wParam from virtual-key code
- // to key code.
- log(instance, "NOTIMPLEMENTED: keyUp '%c'", ' ');
+ log(instance, "keyUp '%c'", MapVirtualKey(evt->wParam, MAPVK_VK_TO_CHAR));
+ if (obj->testKeyboardFocusForPlugins) {
+ obj->eventLogging = false;
+ obj->testKeyboardFocusForPlugins = FALSE;
+ executeScript(obj, "layoutTestController.notifyDone();");
+ }
break;
case WM_KEYDOWN:
- // TODO(tc): We need to convert evt->wParam from virtual-key code
- // to key code.
- log(instance, "NOTIMPLEMENTED: keyDown '%c'", ' ');
+ log(instance, "keyDown '%c'", MapVirtualKey(evt->wParam, MAPVK_VK_TO_CHAR));
break;
case WM_SETCURSOR:
break;
diff --git a/webkit/tools/test_shell/event_sending_controller.cc b/webkit/tools/test_shell/event_sending_controller.cc
index 2ab01a0..9cc100f 100644
--- a/webkit/tools/test_shell/event_sending_controller.cc
+++ b/webkit/tools/test_shell/event_sending_controller.cc
@@ -60,7 +60,6 @@ using WebKit::WebTouchEvent;
using WebKit::WebTouchPoint;
using WebKit::WebView;
-TestShell* EventSendingController::shell_ = NULL;
gfx::Point EventSendingController::last_mouse_pos_;
WebMouseEvent::Button EventSendingController::pressed_button_ =
WebMouseEvent::ButtonNone;
@@ -252,13 +251,8 @@ enum KeyLocationCode {
} // anonymous namespace
EventSendingController::EventSendingController(TestShell* shell)
- : ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) {
- // Set static shell_ variable since we can't do it in an initializer list.
- // We also need to be careful not to assign shell_ to new windows which are
- // temporary.
- if (NULL == shell_)
- shell_ = shell;
-
+ : ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)),
+ shell_(shell) {
// Initialize the map that associates methods of this class with the names
// they will use when called by JavaScript. The actual binding of those
// names to their methods will be done by calling BindToJavaScript() (defined
@@ -338,12 +332,10 @@ void EventSendingController::Reset() {
touch_points.clear();
}
-// static
WebView* EventSendingController::webview() {
return shell_->webView();
}
-// static
void EventSendingController::DoDragDrop(const WebKit::WebPoint &event_pos,
const WebDragData& drag_data,
WebDragOperationsMask mask) {
@@ -451,7 +443,6 @@ void EventSendingController::mouseUp(
}
}
-// static
void EventSendingController::DoMouseUp(const WebMouseEvent& e) {
webview()->handleInputEvent(e);
@@ -530,7 +521,6 @@ void EventSendingController::mouseWheelTo(
}
}
-// static
void EventSendingController::DoMouseMove(const WebMouseEvent& e) {
last_mouse_pos_.SetPoint(e.x, e.y);
diff --git a/webkit/tools/test_shell/event_sending_controller.h b/webkit/tools/test_shell/event_sending_controller.h
index 4c3c9f2..da7e4df 100644
--- a/webkit/tools/test_shell/event_sending_controller.h
+++ b/webkit/tools/test_shell/event_sending_controller.h
@@ -41,9 +41,9 @@ class EventSendingController : public CppBoundClass {
void Reset();
// Simulate drag&drop system call.
- static void DoDragDrop(const WebKit::WebPoint &event_pos,
- const WebKit::WebDragData& drag_data,
- WebKit::WebDragOperationsMask operations_mask);
+ void DoDragDrop(const WebKit::WebPoint &event_pos,
+ const WebKit::WebDragData& drag_data,
+ WebKit::WebDragOperationsMask operations_mask);
// JS callback methods.
void mouseDown(const CppArgumentList& args, CppVariant* result);
@@ -93,17 +93,17 @@ class EventSendingController : public CppBoundClass {
private:
// Returns the test shell's webview.
- static WebKit::WebView* webview();
+ WebKit::WebView* webview();
// Returns true if dragMode is true.
bool drag_mode() { return dragMode.isBool() && dragMode.ToBoolean(); }
// Sometimes we queue up mouse move and mouse up events for drag drop
// handling purposes. These methods dispatch the event.
- static void DoMouseMove(const WebKit::WebMouseEvent& e);
- static void DoMouseUp(const WebKit::WebMouseEvent& e);
+ void DoMouseMove(const WebKit::WebMouseEvent& e);
+ void DoMouseUp(const WebKit::WebMouseEvent& e);
static void DoLeapForward(int milliseconds);
- static void ReplaySavedEvents();
+ void ReplaySavedEvents();
// Helper to return the button type given a button code
static WebKit::WebMouseEvent::Button GetButtonTypeFromButtonNumber(
@@ -125,7 +125,7 @@ class EventSendingController : public CppBoundClass {
ScopedRunnableMethodFactory<EventSendingController> method_factory_;
// Non-owning pointer. The LayoutTestController is owned by the host.
- static TestShell* shell_;
+ TestShell* shell_;
// Location of last mouseMoveTo event.
static gfx::Point last_mouse_pos_;
diff --git a/webkit/tools/test_shell/test_shell.h b/webkit/tools/test_shell/test_shell.h
index 10f6371..9595a47 100644
--- a/webkit/tools/test_shell/test_shell.h
+++ b/webkit/tools/test_shell/test_shell.h
@@ -156,6 +156,9 @@ public:
TestNavigationController* navigation_controller() {
return navigation_controller_.get();
}
+ EventSendingController* event_sending_controller() {
+ return event_sending_controller_.get();
+ }
// Resets the LayoutTestController and EventSendingController. Should be
// called before loading a page, since some end-editing event notifications
diff --git a/webkit/tools/test_shell/test_shell_win.cc b/webkit/tools/test_shell/test_shell_win.cc
index 8ce1bcb..8d7f8ec7 100644
--- a/webkit/tools/test_shell/test_shell_win.cc
+++ b/webkit/tools/test_shell/test_shell_win.cc
@@ -275,13 +275,17 @@ bool TestShell::RunFileTest(const TestParams& params) {
if (inspector_test_mode_)
shell->ShowDevTools();
- shell->test_is_preparing_ = true;
- shell->set_test_params(&params);
- shell->LoadURL(GURL(params.test_url));
-
- shell->test_is_preparing_ = false;
- shell->WaitTestFinished();
- shell->set_test_params(NULL);
+ GURL url(params.test_url);
+ if (url.is_valid()) { // Don't hang if we have an invalid path.
+ shell->test_is_preparing_ = true;
+ shell->set_test_params(&params);
+ shell->LoadURL(url);
+ shell->test_is_preparing_ = false;
+ shell->WaitTestFinished();
+ shell->set_test_params(NULL);
+ } else {
+ NOTREACHED() << "Invalid url: " << url.spec();
+ }
return true;
}
diff --git a/webkit/tools/test_shell/test_webview_delegate.cc b/webkit/tools/test_shell/test_webview_delegate.cc
index a03569c..5a1f2e4 100644
--- a/webkit/tools/test_shell/test_webview_delegate.cc
+++ b/webkit/tools/test_shell/test_webview_delegate.cc
@@ -558,7 +558,8 @@ void TestWebViewDelegate::startDragging(
// When running a test, we need to fake a drag drop operation otherwise
// Windows waits for real mouse events to know when the drag is over.
- EventSendingController::DoDragDrop(mouse_coords, mutable_drag_data, mask);
+ shell_->event_sending_controller()->DoDragDrop(
+ mouse_coords, mutable_drag_data, mask);
} else {
// TODO(tc): Drag and drop is disabled in the test shell because we need
// to be able to convert from WebDragData to an IDataObject.