Index: ui/events/event_unittest.cc |
diff --git a/ui/events/event_unittest.cc b/ui/events/event_unittest.cc |
index c766b95ee2f0463fcab9df182319c5d1fda14935..38ad283b5a9b6923cea437c51502563f772e6b92 100644 |
--- a/ui/events/event_unittest.cc |
+++ b/ui/events/event_unittest.cc |
@@ -6,7 +6,8 @@ |
#include "testing/gtest/include/gtest/gtest.h" |
#include "ui/events/event.h" |
#include "ui/events/event_utils.h" |
-#include "ui/events/keycodes/dom4/keycode_converter.h" |
+#include "ui/events/keycodes/dom/dom_code.h" |
+#include "ui/events/keycodes/dom/keycode_converter.h" |
#include "ui/events/test/events_test_utils.h" |
#if defined(USE_X11) |
@@ -17,6 +18,24 @@ |
namespace ui { |
+TEST(EventTest, NoNativeEvent) { |
+ KeyEvent keyev(ET_KEY_PRESSED, VKEY_SPACE, EF_NONE); |
+ EXPECT_FALSE(keyev.HasNativeEvent()); |
+} |
+ |
+TEST(EventTest, NativeEvent) { |
+#if defined(OS_WIN) |
+ MSG native_event = { NULL, WM_KEYUP, VKEY_A, 0 }; |
+ KeyEvent keyev(native_event); |
+ EXPECT_TRUE(keyev.HasNativeEvent()); |
+#elif defined(USE_X11) |
+ ScopedXI2Event event; |
+ event.InitKeyEvent(ET_KEY_RELEASED, VKEY_A, EF_NONE); |
+ KeyEvent keyev(event); |
+ EXPECT_TRUE(keyev.HasNativeEvent()); |
+#endif |
+} |
+ |
TEST(EventTest, GetCharacter) { |
// Check if Control+Enter returns 10. |
KeyEvent keyev1(ET_KEY_PRESSED, VKEY_RETURN, EF_CONTROL_DOWN); |
@@ -24,11 +43,23 @@ TEST(EventTest, GetCharacter) { |
// Check if Enter returns 13. |
KeyEvent keyev2(ET_KEY_PRESSED, VKEY_RETURN, EF_NONE); |
EXPECT_EQ(13, keyev2.GetCharacter()); |
+ |
+#if defined(USE_X11) |
+ // For X11, test the functions with native_event() as well. crbug.com/107837 |
+ ScopedXI2Event event; |
+ event.InitKeyEvent(ET_KEY_PRESSED, VKEY_RETURN, EF_CONTROL_DOWN); |
+ KeyEvent keyev3(event); |
+ EXPECT_EQ(10, keyev3.GetCharacter()); |
+ |
+ event.InitKeyEvent(ET_KEY_PRESSED, VKEY_RETURN, EF_NONE); |
+ KeyEvent keyev4(event); |
+ EXPECT_EQ(13, keyev4.GetCharacter()); |
+#endif |
} |
TEST(EventTest, ClickCount) { |
const gfx::Point origin(0, 0); |
- MouseEvent mouseev(ET_MOUSE_PRESSED, origin, origin, 0, 0); |
+ MouseEvent mouseev(ET_MOUSE_PRESSED, origin, origin, EventTimeForNow(), 0, 0); |
for (int i = 1; i <=3 ; ++i) { |
mouseev.SetClickCount(i); |
EXPECT_EQ(i, mouseev.GetClickCount()); |
@@ -37,8 +68,10 @@ TEST(EventTest, ClickCount) { |
TEST(EventTest, RepeatedClick) { |
const gfx::Point origin(0, 0); |
- MouseEvent mouse_ev1(ET_MOUSE_PRESSED, origin, origin, 0, 0); |
- MouseEvent mouse_ev2(ET_MOUSE_PRESSED, origin, origin, 0, 0); |
+ MouseEvent mouse_ev1(ET_MOUSE_PRESSED, origin, origin, EventTimeForNow(), 0, |
+ 0); |
+ MouseEvent mouse_ev2(ET_MOUSE_PRESSED, origin, origin, EventTimeForNow(), 0, |
+ 0); |
LocatedEventTestApi test_ev1(&mouse_ev1); |
LocatedEventTestApi test_ev2(&mouse_ev2); |
@@ -46,6 +79,15 @@ TEST(EventTest, RepeatedClick) { |
base::TimeDelta soon = start + base::TimeDelta::FromMilliseconds(1); |
base::TimeDelta later = start + base::TimeDelta::FromMilliseconds(1000); |
+ // Same event. |
+ test_ev1.set_location(gfx::Point(0, 0)); |
+ test_ev2.set_location(gfx::Point(1, 0)); |
+ test_ev1.set_time_stamp(start); |
+ test_ev2.set_time_stamp(start); |
+ EXPECT_FALSE(MouseEvent::IsRepeatedClickEvent(mouse_ev1, mouse_ev2)); |
+ MouseEvent mouse_ev3(mouse_ev1); |
+ EXPECT_FALSE(MouseEvent::IsRepeatedClickEvent(mouse_ev1, mouse_ev3)); |
+ |
// Close point. |
test_ev1.set_location(gfx::Point(0, 0)); |
test_ev2.set_location(gfx::Point(1, 0)); |
@@ -68,6 +110,73 @@ TEST(EventTest, RepeatedClick) { |
EXPECT_FALSE(MouseEvent::IsRepeatedClickEvent(mouse_ev1, mouse_ev2)); |
} |
+// Tests that an event only increases the click count and gets marked as a |
+// double click if a release event was seen for the previous click. This |
+// prevents the same PRESSED event from being processed twice: |
+// http://crbug.com/389162 |
+TEST(EventTest, DoubleClickRequiresRelease) { |
+ const gfx::Point origin1(0, 0); |
+ const gfx::Point origin2(100, 0); |
+ scoped_ptr<MouseEvent> ev; |
+ base::TimeDelta start = base::TimeDelta::FromMilliseconds(0); |
+ base::TimeDelta soon = start + base::TimeDelta::FromMilliseconds(1); |
+ |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin1, origin1, EventTimeForNow(), |
+ 0, 0)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin1, origin1, EventTimeForNow(), |
+ 0, 0)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin2, origin2, EventTimeForNow(), |
+ 0, 0)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_RELEASED, origin2, origin2, |
+ EventTimeForNow(), 0, 0)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin2, origin2, EventTimeForNow(), |
+ 0, 0)); |
+ ev->set_time_stamp(soon); |
+ EXPECT_EQ(2, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_RELEASED, origin2, origin2, |
+ EventTimeForNow(), 0, 0)); |
+ ev->set_time_stamp(soon); |
+ EXPECT_EQ(2, MouseEvent::GetRepeatCount(*ev)); |
+ MouseEvent::ResetLastClickForTest(); |
+} |
+ |
+// Tests that clicking right and then left clicking does not generate a double |
+// click. |
+TEST(EventTest, SingleClickRightLeft) { |
+ const gfx::Point origin(0, 0); |
+ scoped_ptr<MouseEvent> ev; |
+ base::TimeDelta start = base::TimeDelta::FromMilliseconds(0); |
+ base::TimeDelta soon = start + base::TimeDelta::FromMilliseconds(1); |
+ |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin, origin, EventTimeForNow(), |
+ ui::EF_RIGHT_MOUSE_BUTTON, |
+ ui::EF_RIGHT_MOUSE_BUTTON)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin, origin, EventTimeForNow(), |
+ ui::EF_LEFT_MOUSE_BUTTON, ui::EF_LEFT_MOUSE_BUTTON)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_RELEASED, origin, origin, EventTimeForNow(), |
+ ui::EF_LEFT_MOUSE_BUTTON, ui::EF_LEFT_MOUSE_BUTTON)); |
+ ev->set_time_stamp(start); |
+ EXPECT_EQ(1, MouseEvent::GetRepeatCount(*ev)); |
+ ev.reset(new MouseEvent(ET_MOUSE_PRESSED, origin, origin, EventTimeForNow(), |
+ ui::EF_LEFT_MOUSE_BUTTON, ui::EF_LEFT_MOUSE_BUTTON)); |
+ ev->set_time_stamp(soon); |
+ EXPECT_EQ(2, MouseEvent::GetRepeatCount(*ev)); |
+ MouseEvent::ResetLastClickForTest(); |
+} |
+ |
TEST(EventTest, KeyEvent) { |
static const struct { |
KeyboardCode key_code; |
@@ -160,6 +269,41 @@ TEST(EventTest, KeyEventDirectUnicode) { |
} |
TEST(EventTest, NormalizeKeyEventFlags) { |
+#if defined(USE_X11) |
+ // Normalize flags when KeyEvent is created from XEvent. |
+ ScopedXI2Event event; |
+ { |
+ event.InitKeyEvent(ET_KEY_PRESSED, VKEY_SHIFT, EF_SHIFT_DOWN); |
+ KeyEvent keyev(event); |
+ EXPECT_EQ(EF_SHIFT_DOWN, keyev.flags()); |
+ } |
+ { |
+ event.InitKeyEvent(ET_KEY_RELEASED, VKEY_SHIFT, EF_SHIFT_DOWN); |
+ KeyEvent keyev(event); |
+ EXPECT_EQ(EF_NONE, keyev.flags()); |
+ } |
+ { |
+ event.InitKeyEvent(ET_KEY_PRESSED, VKEY_CONTROL, EF_CONTROL_DOWN); |
+ KeyEvent keyev(event); |
+ EXPECT_EQ(EF_CONTROL_DOWN, keyev.flags()); |
+ } |
+ { |
+ event.InitKeyEvent(ET_KEY_RELEASED, VKEY_CONTROL, EF_CONTROL_DOWN); |
+ KeyEvent keyev(event); |
+ EXPECT_EQ(EF_NONE, keyev.flags()); |
+ } |
+ { |
+ event.InitKeyEvent(ET_KEY_PRESSED, VKEY_MENU, EF_ALT_DOWN); |
+ KeyEvent keyev(event); |
+ EXPECT_EQ(EF_ALT_DOWN, keyev.flags()); |
+ } |
+ { |
+ event.InitKeyEvent(ET_KEY_RELEASED, VKEY_MENU, EF_ALT_DOWN); |
+ KeyEvent keyev(event); |
+ EXPECT_EQ(EF_NONE, keyev.flags()); |
+ } |
+#endif |
+ |
// Do not normalize flags for synthesized events without |
// KeyEvent::NormalizeFlags called explicitly. |
{ |
@@ -202,27 +346,263 @@ TEST(EventTest, KeyEventCopy) { |
} |
TEST(EventTest, KeyEventCode) { |
+ const DomCode kDomCodeForSpace = DomCode::SPACE; |
const char kCodeForSpace[] = "Space"; |
+ ASSERT_EQ(kDomCodeForSpace, |
+ ui::KeycodeConverter::CodeStringToDomCode(kCodeForSpace)); |
const uint16 kNativeCodeSpace = |
- ui::KeycodeConverter::CodeToNativeKeycode(kCodeForSpace); |
+ ui::KeycodeConverter::DomCodeToNativeKeycode(kDomCodeForSpace); |
ASSERT_NE(ui::KeycodeConverter::InvalidNativeKeycode(), kNativeCodeSpace); |
+ ASSERT_EQ(kNativeCodeSpace, |
+ ui::KeycodeConverter::DomCodeToNativeKeycode(kDomCodeForSpace)); |
{ |
- KeyEvent key(ET_KEY_PRESSED, VKEY_SPACE, kCodeForSpace, EF_NONE); |
- EXPECT_EQ(kCodeForSpace, key.code()); |
+ KeyEvent key(ET_KEY_PRESSED, VKEY_SPACE, kDomCodeForSpace, EF_NONE); |
+ EXPECT_EQ(kCodeForSpace, key.GetCodeString()); |
} |
{ |
// Regardless the KeyEvent.key_code (VKEY_RETURN), code should be |
// the specified value. |
- KeyEvent key(ET_KEY_PRESSED, VKEY_RETURN, kCodeForSpace, EF_NONE); |
- EXPECT_EQ(kCodeForSpace, key.code()); |
+ KeyEvent key(ET_KEY_PRESSED, VKEY_RETURN, kDomCodeForSpace, EF_NONE); |
+ EXPECT_EQ(kCodeForSpace, key.GetCodeString()); |
} |
{ |
- // If the synthetic event is initialized without code, it returns |
- // an empty string. |
- // TODO(komatsu): Fill a fallback value assuming the US keyboard layout. |
+ // If the synthetic event is initialized without code, the code is |
+ // determined from the KeyboardCode assuming a US keyboard layout. |
KeyEvent key(ET_KEY_PRESSED, VKEY_SPACE, EF_NONE); |
- EXPECT_TRUE(key.code().empty()); |
+ EXPECT_EQ(kCodeForSpace, key.GetCodeString()); |
+ } |
+#if defined(USE_X11) |
+ { |
+ // KeyEvent converts from the native keycode (XKB) to the code. |
+ ScopedXI2Event xevent; |
+ xevent.InitKeyEvent(ET_KEY_PRESSED, VKEY_SPACE, kNativeCodeSpace); |
+ KeyEvent key(xevent); |
+ EXPECT_EQ(kCodeForSpace, key.GetCodeString()); |
+ } |
+#endif // USE_X11 |
+#if defined(OS_WIN) |
+ { |
+ // Test a non extended key. |
+ ASSERT_EQ((kNativeCodeSpace & 0xFF), kNativeCodeSpace); |
+ |
+ const LPARAM lParam = GetLParamFromScanCode(kNativeCodeSpace); |
+ MSG native_event = { NULL, WM_KEYUP, VKEY_SPACE, lParam }; |
+ KeyEvent key(native_event); |
+ |
+ // KeyEvent converts from the native keycode (scan code) to the code. |
+ EXPECT_EQ(kCodeForSpace, key.GetCodeString()); |
+ } |
+ { |
+ const char kCodeForHome[] = "Home"; |
+ const uint16 kNativeCodeHome = 0xe047; |
+ |
+ // 'Home' is an extended key with 0xe000 bits. |
+ ASSERT_NE((kNativeCodeHome & 0xFF), kNativeCodeHome); |
+ const LPARAM lParam = GetLParamFromScanCode(kNativeCodeHome); |
+ |
+ MSG native_event = { NULL, WM_KEYUP, VKEY_HOME, lParam }; |
+ KeyEvent key(native_event); |
+ |
+ // KeyEvent converts from the native keycode (scan code) to the code. |
+ EXPECT_EQ(kCodeForHome, key.GetCodeString()); |
+ } |
+#endif // OS_WIN |
+} |
+ |
+namespace { |
+#if defined(USE_X11) |
+void SetKeyEventTimestamp(XEvent* event, long time) { |
+ event->xkey.time = time; |
+} |
+ |
+void AdvanceKeyEventTimestamp(XEvent* event) { |
+ event->xkey.time++; |
+} |
+ |
+#elif defined(OS_WIN) |
+void SetKeyEventTimestamp(MSG& msg, long time) { |
+ msg.time = time; |
+} |
+ |
+void AdvanceKeyEventTimestamp(MSG& msg) { |
+ msg.time++; |
+} |
+#endif |
+} // namespace |
+ |
+#if defined(USE_X11) || defined(OS_WIN) |
+TEST(EventTest, AutoRepeat) { |
+ const uint16 kNativeCodeA = |
+ ui::KeycodeConverter::DomCodeToNativeKeycode(DomCode::KEY_A); |
+ const uint16 kNativeCodeB = |
+ ui::KeycodeConverter::DomCodeToNativeKeycode(DomCode::KEY_B); |
+#if defined(USE_X11) |
+ ScopedXI2Event native_event_a_pressed; |
+ native_event_a_pressed.InitKeyEvent(ET_KEY_PRESSED, VKEY_A, kNativeCodeA); |
+ ScopedXI2Event native_event_a_pressed_1500; |
+ native_event_a_pressed_1500.InitKeyEvent( |
+ ET_KEY_PRESSED, VKEY_A, kNativeCodeA); |
+ ScopedXI2Event native_event_a_pressed_3000; |
+ native_event_a_pressed_3000.InitKeyEvent( |
+ ET_KEY_PRESSED, VKEY_A, kNativeCodeA); |
+ |
+ ScopedXI2Event native_event_a_released; |
+ native_event_a_released.InitKeyEvent(ET_KEY_RELEASED, VKEY_A, kNativeCodeA); |
+ ScopedXI2Event native_event_b_pressed; |
+ native_event_b_pressed.InitKeyEvent(ET_KEY_PRESSED, VKEY_B, kNativeCodeB); |
+ ScopedXI2Event native_event_a_pressed_nonstandard_state; |
+ native_event_a_pressed_nonstandard_state.InitKeyEvent( |
+ ET_KEY_PRESSED, VKEY_A, kNativeCodeA); |
+ // IBUS-GTK uses the mask (1 << 25) to detect reposted event. |
+ static_cast<XEvent*>(native_event_a_pressed_nonstandard_state)->xkey.state |= |
+ 1 << 25; |
+#elif defined(OS_WIN) |
+ const LPARAM lParam_a = GetLParamFromScanCode(kNativeCodeA); |
+ const LPARAM lParam_b = GetLParamFromScanCode(kNativeCodeB); |
+ MSG native_event_a_pressed = { NULL, WM_KEYDOWN, VKEY_A, lParam_a }; |
+ MSG native_event_a_pressed_1500 = { NULL, WM_KEYDOWN, VKEY_A, lParam_a }; |
+ MSG native_event_a_pressed_3000 = { NULL, WM_KEYDOWN, VKEY_A, lParam_a }; |
+ MSG native_event_a_released = { NULL, WM_KEYUP, VKEY_A, lParam_a }; |
+ MSG native_event_b_pressed = { NULL, WM_KEYUP, VKEY_B, lParam_b }; |
+#endif |
+ SetKeyEventTimestamp(native_event_a_pressed_1500, 1500); |
+ SetKeyEventTimestamp(native_event_a_pressed_3000, 3000); |
+ |
+ { |
+ KeyEvent key_a1(native_event_a_pressed); |
+ EXPECT_FALSE(key_a1.IsRepeat()); |
+ |
+ KeyEvent key_a1_with_same_event(native_event_a_pressed); |
+ EXPECT_FALSE(key_a1_with_same_event.IsRepeat()); |
+ |
+ KeyEvent key_a1_released(native_event_a_released); |
+ EXPECT_FALSE(key_a1_released.IsRepeat()); |
+ |
+ KeyEvent key_a2(native_event_a_pressed); |
+ EXPECT_FALSE(key_a2.IsRepeat()); |
+ |
+ AdvanceKeyEventTimestamp(native_event_a_pressed); |
+ KeyEvent key_a2_repeated(native_event_a_pressed); |
+ EXPECT_TRUE(key_a2_repeated.IsRepeat()); |
+ |
+ KeyEvent key_a2_released(native_event_a_released); |
+ EXPECT_FALSE(key_a2_released.IsRepeat()); |
+ } |
+ |
+ // Interleaved with different key press. |
+ { |
+ KeyEvent key_a3(native_event_a_pressed); |
+ EXPECT_FALSE(key_a3.IsRepeat()); |
+ |
+ KeyEvent key_b(native_event_b_pressed); |
+ EXPECT_FALSE(key_b.IsRepeat()); |
+ |
+ AdvanceKeyEventTimestamp(native_event_a_pressed); |
+ KeyEvent key_a3_again(native_event_a_pressed); |
+ EXPECT_FALSE(key_a3_again.IsRepeat()); |
+ |
+ AdvanceKeyEventTimestamp(native_event_a_pressed); |
+ KeyEvent key_a3_repeated(native_event_a_pressed); |
+ EXPECT_TRUE(key_a3_repeated.IsRepeat()); |
+ |
+ AdvanceKeyEventTimestamp(native_event_a_pressed); |
+ KeyEvent key_a3_repeated2(native_event_a_pressed); |
+ EXPECT_TRUE(key_a3_repeated2.IsRepeat()); |
+ |
+ KeyEvent key_a3_released(native_event_a_released); |
+ EXPECT_FALSE(key_a3_released.IsRepeat()); |
+ } |
+ |
+ // Hold the key longer than max auto repeat timeout. |
+ { |
+ KeyEvent key_a4_0(native_event_a_pressed); |
+ EXPECT_FALSE(key_a4_0.IsRepeat()); |
+ |
+ KeyEvent key_a4_1500(native_event_a_pressed_1500); |
+ EXPECT_TRUE(key_a4_1500.IsRepeat()); |
+ |
+ KeyEvent key_a4_3000(native_event_a_pressed_3000); |
+ EXPECT_TRUE(key_a4_3000.IsRepeat()); |
+ |
+ KeyEvent key_a4_released(native_event_a_released); |
+ EXPECT_FALSE(key_a4_released.IsRepeat()); |
+ } |
+ |
+#if defined(USE_X11) |
+ { |
+ KeyEvent key_a4_pressed(native_event_a_pressed); |
+ EXPECT_FALSE(key_a4_pressed.IsRepeat()); |
+ |
+ KeyEvent key_a4_pressed_nonstandard_state( |
+ native_event_a_pressed_nonstandard_state); |
+ EXPECT_FALSE(key_a4_pressed_nonstandard_state.IsRepeat()); |
+ } |
+#endif |
+} |
+#endif // USE_X11 || OS_WIN |
+ |
+TEST(EventTest, TouchEventRadiusDefaultsToOtherAxis) { |
+ const base::TimeDelta time = base::TimeDelta::FromMilliseconds(0); |
+ const float non_zero_length1 = 30; |
+ const float non_zero_length2 = 46; |
+ |
+ TouchEvent event1(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ non_zero_length1, 0, 0, 0); |
+ EXPECT_EQ(non_zero_length1, event1.radius_x()); |
+ EXPECT_EQ(non_zero_length1, event1.radius_y()); |
+ |
+ TouchEvent event2(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ 0, non_zero_length2, 0, 0); |
+ EXPECT_EQ(non_zero_length2, event2.radius_x()); |
+ EXPECT_EQ(non_zero_length2, event2.radius_y()); |
+} |
+ |
+TEST(EventTest, TouchEventRotationAngleFixing) { |
+ const base::TimeDelta time = base::TimeDelta::FromMilliseconds(0); |
+ const float radius_x = 20; |
+ const float radius_y = 10; |
+ |
+ { |
+ const float angle_in_range = 0; |
+ TouchEvent event(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ radius_x, radius_y, angle_in_range, 0); |
+ EXPECT_FLOAT_EQ(angle_in_range, event.rotation_angle()); |
+ } |
+ |
+ { |
+ const float angle_in_range = 179.9f; |
+ TouchEvent event(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ radius_x, radius_y, angle_in_range, 0); |
+ EXPECT_FLOAT_EQ(angle_in_range, event.rotation_angle()); |
+ } |
+ |
+ { |
+ const float angle_negative = -0.1f; |
+ TouchEvent event(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ radius_x, radius_y, angle_negative, 0); |
+ EXPECT_FLOAT_EQ(180 - 0.1f, event.rotation_angle()); |
+ } |
+ |
+ { |
+ const float angle_negative = -200; |
+ TouchEvent event(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ radius_x, radius_y, angle_negative, 0); |
+ EXPECT_FLOAT_EQ(360 - 200, event.rotation_angle()); |
+ } |
+ |
+ { |
+ const float angle_too_big = 180; |
+ TouchEvent event(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ radius_x, radius_y, angle_too_big, 0); |
+ EXPECT_FLOAT_EQ(0, event.rotation_angle()); |
+ } |
+ |
+ { |
+ const float angle_too_big = 400; |
+ TouchEvent event(ui::ET_TOUCH_PRESSED, gfx::Point(0, 0), 0, 0, time, |
+ radius_x, radius_y, angle_too_big, 0); |
+ EXPECT_FLOAT_EQ(400 - 360, event.rotation_angle()); |
} |
} |