blob: db07d29dc5c14beec457568206ff5ef8a438a9b8 [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/common/input/input_param_traits.h"
#include "content/common/input/input_event.h"
#include "content/common/input/synthetic_gesture_params.h"
#include "content/common/input/synthetic_pinch_gesture_params.h"
#include "content/common/input/synthetic_smooth_scroll_gesture_params.h"
#include "content/common/input_messages.h"
#include "ipc/ipc_message.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/WebKit/public/web/WebInputEvent.h"
namespace content {
namespace {
typedef ScopedVector<InputEvent> InputEvents;
class InputParamTraitsTest : public testing::Test {
protected:
static void Compare(const InputEvent* a, const InputEvent* b) {
EXPECT_EQ(!!a->web_event, !!b->web_event);
if (a->web_event && b->web_event) {
const size_t a_size = a->web_event->size;
ASSERT_EQ(a_size, b->web_event->size);
EXPECT_EQ(0, memcmp(a->web_event.get(), b->web_event.get(), a_size));
}
EXPECT_EQ(a->latency_info.latency_components.size(),
b->latency_info.latency_components.size());
EXPECT_EQ(a->is_keyboard_shortcut, b->is_keyboard_shortcut);
}
static void Compare(const InputEvents* a, const InputEvents* b) {
for (size_t i = 0; i < a->size(); ++i)
Compare((*a)[i], (*b)[i]);
}
static void Compare(const SyntheticSmoothScrollGestureParams* a,
const SyntheticSmoothScrollGestureParams* b) {
EXPECT_EQ(a->gesture_source_type, b->gesture_source_type);
EXPECT_EQ(a->anchor, b->anchor);
EXPECT_EQ(a->distances.size(), b->distances.size());
for (size_t i = 0; i < a->distances.size(); i++)
EXPECT_EQ(a->distances[i], b->distances[i]);
EXPECT_EQ(a->prevent_fling, b->prevent_fling);
EXPECT_EQ(a->speed_in_pixels_s, b->speed_in_pixels_s);
}
static void Compare(const SyntheticPinchGestureParams* a,
const SyntheticPinchGestureParams* b) {
EXPECT_EQ(a->gesture_source_type, b->gesture_source_type);
EXPECT_EQ(a->scale_factor, b->scale_factor);
EXPECT_EQ(a->anchor, b->anchor);
EXPECT_EQ(a->relative_pointer_speed_in_pixels_s,
b->relative_pointer_speed_in_pixels_s);
}
static void Compare(const SyntheticTapGestureParams* a,
const SyntheticTapGestureParams* b) {
EXPECT_EQ(a->gesture_source_type, b->gesture_source_type);
EXPECT_EQ(a->position, b->position);
EXPECT_EQ(a->duration_ms, b->duration_ms);
}
static void Compare(const SyntheticGesturePacket* a,
const SyntheticGesturePacket* b) {
ASSERT_EQ(!!a, !!b);
if (!a) return;
ASSERT_EQ(!!a->gesture_params(), !!b->gesture_params());
if (!a->gesture_params()) return;
ASSERT_EQ(a->gesture_params()->GetGestureType(),
b->gesture_params()->GetGestureType());
switch (a->gesture_params()->GetGestureType()) {
case SyntheticGestureParams::SMOOTH_SCROLL_GESTURE:
Compare(SyntheticSmoothScrollGestureParams::Cast(a->gesture_params()),
SyntheticSmoothScrollGestureParams::Cast(b->gesture_params()));
break;
case SyntheticGestureParams::PINCH_GESTURE:
Compare(SyntheticPinchGestureParams::Cast(a->gesture_params()),
SyntheticPinchGestureParams::Cast(b->gesture_params()));
break;
case SyntheticGestureParams::TAP_GESTURE:
Compare(SyntheticTapGestureParams::Cast(a->gesture_params()),
SyntheticTapGestureParams::Cast(b->gesture_params()));
break;
}
}
static void Verify(const InputEvents& events_in) {
IPC::Message msg;
IPC::ParamTraits<InputEvents>::Write(&msg, events_in);
InputEvents events_out;
PickleIterator iter(msg);
EXPECT_TRUE(IPC::ParamTraits<InputEvents>::Read(&msg, &iter, &events_out));
Compare(&events_in, &events_out);
// Perform a sanity check that logging doesn't explode.
std::string events_in_string;
IPC::ParamTraits<InputEvents>::Log(events_in, &events_in_string);
std::string events_out_string;
IPC::ParamTraits<InputEvents>::Log(events_out, &events_out_string);
ASSERT_FALSE(events_in_string.empty());
EXPECT_EQ(events_in_string, events_out_string);
}
static void Verify(const SyntheticGesturePacket& packet_in) {
IPC::Message msg;
IPC::ParamTraits<SyntheticGesturePacket>::Write(&msg, packet_in);
SyntheticGesturePacket packet_out;
PickleIterator iter(msg);
EXPECT_TRUE(IPC::ParamTraits<SyntheticGesturePacket>::Read(&msg, &iter,
&packet_out));
Compare(&packet_in, &packet_out);
// Perform a sanity check that logging doesn't explode.
std::string packet_in_string;
IPC::ParamTraits<SyntheticGesturePacket>::Log(packet_in, &packet_in_string);
std::string packet_out_string;
IPC::ParamTraits<SyntheticGesturePacket>::Log(packet_out,
&packet_out_string);
ASSERT_FALSE(packet_in_string.empty());
EXPECT_EQ(packet_in_string, packet_out_string);
}
};
TEST_F(InputParamTraitsTest, UninitializedEvents) {
InputEvent event;
IPC::Message msg;
IPC::WriteParam(&msg, event);
InputEvent event_out;
PickleIterator iter(msg);
EXPECT_FALSE(IPC::ReadParam(&msg, &iter, &event_out));
}
TEST_F(InputParamTraitsTest, InitializedEvents) {
InputEvents events;
ui::LatencyInfo latency;
blink::WebKeyboardEvent key_event;
key_event.type = blink::WebInputEvent::RawKeyDown;
key_event.nativeKeyCode = 5;
events.push_back(new InputEvent(key_event, latency, false));
blink::WebMouseWheelEvent wheel_event;
wheel_event.type = blink::WebInputEvent::MouseWheel;
wheel_event.deltaX = 10;
latency.AddLatencyNumber(ui::INPUT_EVENT_LATENCY_BEGIN_RWH_COMPONENT, 1, 1);
events.push_back(new InputEvent(wheel_event, latency, false));
blink::WebMouseEvent mouse_event;
mouse_event.type = blink::WebInputEvent::MouseDown;
mouse_event.x = 10;
latency.AddLatencyNumber(ui::INPUT_EVENT_LATENCY_UI_COMPONENT, 2, 2);
events.push_back(new InputEvent(mouse_event, latency, false));
blink::WebGestureEvent gesture_event;
gesture_event.type = blink::WebInputEvent::GestureScrollBegin;
gesture_event.x = -1;
events.push_back(new InputEvent(gesture_event, latency, false));
blink::WebTouchEvent touch_event;
touch_event.type = blink::WebInputEvent::TouchStart;
touch_event.touchesLength = 1;
touch_event.touches[0].radiusX = 1;
events.push_back(new InputEvent(touch_event, latency, false));
Verify(events);
}
TEST_F(InputParamTraitsTest, InvalidSyntheticGestureParams) {
IPC::Message msg;
// Write invalid value for SyntheticGestureParams::GestureType.
WriteParam(&msg, -3);
SyntheticGesturePacket packet_out;
PickleIterator iter(msg);
ASSERT_FALSE(
IPC::ParamTraits<SyntheticGesturePacket>::Read(&msg, &iter, &packet_out));
}
TEST_F(InputParamTraitsTest, SyntheticSmoothScrollGestureParams) {
scoped_ptr<SyntheticSmoothScrollGestureParams> gesture_params(
new SyntheticSmoothScrollGestureParams);
gesture_params->gesture_source_type = SyntheticGestureParams::TOUCH_INPUT;
gesture_params->anchor.SetPoint(234, 345);
gesture_params->distances.push_back(gfx::Vector2d(123, -789));
gesture_params->distances.push_back(gfx::Vector2d(-78, 43));
gesture_params->prevent_fling = false;
gesture_params->speed_in_pixels_s = 456;
ASSERT_EQ(SyntheticGestureParams::SMOOTH_SCROLL_GESTURE,
gesture_params->GetGestureType());
SyntheticGesturePacket packet_in;
packet_in.set_gesture_params(gesture_params.PassAs<SyntheticGestureParams>());
Verify(packet_in);
}
TEST_F(InputParamTraitsTest, SyntheticPinchGestureParams) {
scoped_ptr<SyntheticPinchGestureParams> gesture_params(
new SyntheticPinchGestureParams);
gesture_params->gesture_source_type = SyntheticGestureParams::TOUCH_INPUT;
gesture_params->scale_factor = 2.3f;
gesture_params->anchor.SetPoint(234, 345);
gesture_params->relative_pointer_speed_in_pixels_s = 456;
ASSERT_EQ(SyntheticGestureParams::PINCH_GESTURE,
gesture_params->GetGestureType());
SyntheticGesturePacket packet_in;
packet_in.set_gesture_params(gesture_params.PassAs<SyntheticGestureParams>());
Verify(packet_in);
}
TEST_F(InputParamTraitsTest, SyntheticTapGestureParams) {
scoped_ptr<SyntheticTapGestureParams> gesture_params(
new SyntheticTapGestureParams);
gesture_params->gesture_source_type = SyntheticGestureParams::TOUCH_INPUT;
gesture_params->position.SetPoint(798, 233);
gesture_params->duration_ms = 13;
ASSERT_EQ(SyntheticGestureParams::TAP_GESTURE,
gesture_params->GetGestureType());
SyntheticGesturePacket packet_in;
packet_in.set_gesture_params(gesture_params.PassAs<SyntheticGestureParams>());
Verify(packet_in);
}
} // namespace
} // namespace content