1 /* 2 * Copyright (C) 2011 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #include <array> 18 #include <math.h> 19 20 #include <binder/Parcel.h> 21 #include <gtest/gtest.h> 22 #include <input/Input.h> 23 24 namespace android { 25 26 // Default display id. 27 static constexpr int32_t DISPLAY_ID = ADISPLAY_ID_DEFAULT; 28 29 class BaseTest : public testing::Test { }; 30 31 // --- PointerCoordsTest --- 32 33 class PointerCoordsTest : public BaseTest { 34 }; 35 36 TEST_F(PointerCoordsTest, ClearSetsBitsToZero) { 37 PointerCoords coords; 38 coords.clear(); 39 40 ASSERT_EQ(0ULL, coords.bits); 41 } 42 43 TEST_F(PointerCoordsTest, AxisValues) { 44 float* valuePtr; 45 PointerCoords coords; 46 coords.clear(); 47 48 // Check invariants when no axes are present. 49 ASSERT_EQ(0, coords.getAxisValue(0)) 50 << "getAxisValue should return zero because axis is not present"; 51 ASSERT_EQ(0, coords.getAxisValue(1)) 52 << "getAxisValue should return zero because axis is not present"; 53 54 // Set first axis. 55 ASSERT_EQ(OK, coords.setAxisValue(1, 5)); 56 ASSERT_EQ(5, coords.values[0]); 57 ASSERT_EQ(0x4000000000000000ULL, coords.bits); 58 59 ASSERT_EQ(0, coords.getAxisValue(0)) 60 << "getAxisValue should return zero because axis is not present"; 61 ASSERT_EQ(5, coords.getAxisValue(1)) 62 << "getAxisValue should return value of axis"; 63 64 // Set an axis with a higher id than all others. (appending value at the end) 65 ASSERT_EQ(OK, coords.setAxisValue(3, 2)); 66 ASSERT_EQ(0x5000000000000000ULL, coords.bits); 67 ASSERT_EQ(5, coords.values[0]); 68 ASSERT_EQ(2, coords.values[1]); 69 70 ASSERT_EQ(0, coords.getAxisValue(0)) 71 << "getAxisValue should return zero because axis is not present"; 72 ASSERT_EQ(5, coords.getAxisValue(1)) 73 << "getAxisValue should return value of axis"; 74 ASSERT_EQ(0, coords.getAxisValue(2)) 75 << "getAxisValue should return zero because axis is not present"; 76 ASSERT_EQ(2, coords.getAxisValue(3)) 77 << "getAxisValue should return value of axis"; 78 79 // Set an axis with an id lower than all others. (prepending value at beginning) 80 ASSERT_EQ(OK, coords.setAxisValue(0, 4)); 81 ASSERT_EQ(0xd000000000000000ULL, coords.bits); 82 ASSERT_EQ(4, coords.values[0]); 83 ASSERT_EQ(5, coords.values[1]); 84 ASSERT_EQ(2, coords.values[2]); 85 86 ASSERT_EQ(4, coords.getAxisValue(0)) 87 << "getAxisValue should return value of axis"; 88 ASSERT_EQ(5, coords.getAxisValue(1)) 89 << "getAxisValue should return value of axis"; 90 ASSERT_EQ(0, coords.getAxisValue(2)) 91 << "getAxisValue should return zero because axis is not present"; 92 ASSERT_EQ(2, coords.getAxisValue(3)) 93 << "getAxisValue should return value of axis"; 94 95 // Set an axis with an id between the others. (inserting value in the middle) 96 ASSERT_EQ(OK, coords.setAxisValue(2, 1)); 97 ASSERT_EQ(0xf000000000000000ULL, coords.bits); 98 ASSERT_EQ(4, coords.values[0]); 99 ASSERT_EQ(5, coords.values[1]); 100 ASSERT_EQ(1, coords.values[2]); 101 ASSERT_EQ(2, coords.values[3]); 102 103 ASSERT_EQ(4, coords.getAxisValue(0)) 104 << "getAxisValue should return value of axis"; 105 ASSERT_EQ(5, coords.getAxisValue(1)) 106 << "getAxisValue should return value of axis"; 107 ASSERT_EQ(1, coords.getAxisValue(2)) 108 << "getAxisValue should return value of axis"; 109 ASSERT_EQ(2, coords.getAxisValue(3)) 110 << "getAxisValue should return value of axis"; 111 112 // Set an existing axis value in place. 113 ASSERT_EQ(OK, coords.setAxisValue(1, 6)); 114 ASSERT_EQ(0xf000000000000000ULL, coords.bits); 115 ASSERT_EQ(4, coords.values[0]); 116 ASSERT_EQ(6, coords.values[1]); 117 ASSERT_EQ(1, coords.values[2]); 118 ASSERT_EQ(2, coords.values[3]); 119 120 ASSERT_EQ(4, coords.getAxisValue(0)) 121 << "getAxisValue should return value of axis"; 122 ASSERT_EQ(6, coords.getAxisValue(1)) 123 << "getAxisValue should return value of axis"; 124 ASSERT_EQ(1, coords.getAxisValue(2)) 125 << "getAxisValue should return value of axis"; 126 ASSERT_EQ(2, coords.getAxisValue(3)) 127 << "getAxisValue should return value of axis"; 128 129 // Set maximum number of axes. 130 for (size_t axis = 4; axis < PointerCoords::MAX_AXES; axis++) { 131 ASSERT_EQ(OK, coords.setAxisValue(axis, axis)); 132 } 133 ASSERT_EQ(PointerCoords::MAX_AXES, __builtin_popcountll(coords.bits)); 134 135 // Try to set one more axis beyond maximum number. 136 // Ensure bits are unchanged. 137 ASSERT_EQ(NO_MEMORY, coords.setAxisValue(PointerCoords::MAX_AXES, 100)); 138 ASSERT_EQ(PointerCoords::MAX_AXES, __builtin_popcountll(coords.bits)); 139 } 140 141 TEST_F(PointerCoordsTest, Parcel) { 142 Parcel parcel; 143 144 PointerCoords inCoords; 145 inCoords.clear(); 146 PointerCoords outCoords; 147 148 // Round trip with empty coords. 149 inCoords.writeToParcel(&parcel); 150 parcel.setDataPosition(0); 151 outCoords.readFromParcel(&parcel); 152 153 ASSERT_EQ(0ULL, outCoords.bits); 154 155 // Round trip with some values. 156 parcel.freeData(); 157 inCoords.setAxisValue(2, 5); 158 inCoords.setAxisValue(5, 8); 159 160 inCoords.writeToParcel(&parcel); 161 parcel.setDataPosition(0); 162 outCoords.readFromParcel(&parcel); 163 164 ASSERT_EQ(outCoords.bits, inCoords.bits); 165 ASSERT_EQ(outCoords.values[0], inCoords.values[0]); 166 ASSERT_EQ(outCoords.values[1], inCoords.values[1]); 167 } 168 169 170 // --- KeyEventTest --- 171 172 class KeyEventTest : public BaseTest { 173 }; 174 175 TEST_F(KeyEventTest, Properties) { 176 KeyEvent event; 177 178 // Initialize and get properties. 179 const nsecs_t ARBITRARY_DOWN_TIME = 1; 180 const nsecs_t ARBITRARY_EVENT_TIME = 2; 181 event.initialize(2, AINPUT_SOURCE_GAMEPAD, DISPLAY_ID, AKEY_EVENT_ACTION_DOWN, 182 AKEY_EVENT_FLAG_FROM_SYSTEM, AKEYCODE_BUTTON_X, 121, 183 AMETA_ALT_ON, 1, ARBITRARY_DOWN_TIME, ARBITRARY_EVENT_TIME); 184 185 ASSERT_EQ(AINPUT_EVENT_TYPE_KEY, event.getType()); 186 ASSERT_EQ(2, event.getDeviceId()); 187 ASSERT_EQ(static_cast<int>(AINPUT_SOURCE_GAMEPAD), event.getSource()); 188 ASSERT_EQ(DISPLAY_ID, event.getDisplayId()); 189 ASSERT_EQ(AKEY_EVENT_ACTION_DOWN, event.getAction()); 190 ASSERT_EQ(AKEY_EVENT_FLAG_FROM_SYSTEM, event.getFlags()); 191 ASSERT_EQ(AKEYCODE_BUTTON_X, event.getKeyCode()); 192 ASSERT_EQ(121, event.getScanCode()); 193 ASSERT_EQ(AMETA_ALT_ON, event.getMetaState()); 194 ASSERT_EQ(1, event.getRepeatCount()); 195 ASSERT_EQ(ARBITRARY_DOWN_TIME, event.getDownTime()); 196 ASSERT_EQ(ARBITRARY_EVENT_TIME, event.getEventTime()); 197 198 // Set source. 199 event.setSource(AINPUT_SOURCE_JOYSTICK); 200 ASSERT_EQ(static_cast<int>(AINPUT_SOURCE_JOYSTICK), event.getSource()); 201 202 // Set display id. 203 constexpr int32_t newDisplayId = 2; 204 event.setDisplayId(newDisplayId); 205 ASSERT_EQ(newDisplayId, event.getDisplayId()); 206 } 207 208 209 // --- MotionEventTest --- 210 211 class MotionEventTest : public BaseTest { 212 protected: 213 static const nsecs_t ARBITRARY_DOWN_TIME; 214 static const nsecs_t ARBITRARY_EVENT_TIME; 215 static const float X_OFFSET; 216 static const float Y_OFFSET; 217 218 void initializeEventWithHistory(MotionEvent* event); 219 void assertEqualsEventWithHistory(const MotionEvent* event); 220 }; 221 222 const nsecs_t MotionEventTest::ARBITRARY_DOWN_TIME = 1; 223 const nsecs_t MotionEventTest::ARBITRARY_EVENT_TIME = 2; 224 const float MotionEventTest::X_OFFSET = 1.0f; 225 const float MotionEventTest::Y_OFFSET = 1.1f; 226 227 void MotionEventTest::initializeEventWithHistory(MotionEvent* event) { 228 PointerProperties pointerProperties[2]; 229 pointerProperties[0].clear(); 230 pointerProperties[0].id = 1; 231 pointerProperties[0].toolType = AMOTION_EVENT_TOOL_TYPE_FINGER; 232 pointerProperties[1].clear(); 233 pointerProperties[1].id = 2; 234 pointerProperties[1].toolType = AMOTION_EVENT_TOOL_TYPE_STYLUS; 235 236 PointerCoords pointerCoords[2]; 237 pointerCoords[0].clear(); 238 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_X, 10); 239 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_Y, 11); 240 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_PRESSURE, 12); 241 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_SIZE, 13); 242 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, 14); 243 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, 15); 244 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, 16); 245 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, 17); 246 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, 18); 247 pointerCoords[1].clear(); 248 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_X, 20); 249 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_Y, 21); 250 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_PRESSURE, 22); 251 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_SIZE, 23); 252 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, 24); 253 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, 25); 254 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, 26); 255 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, 27); 256 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, 28); 257 event->initialize(2, AINPUT_SOURCE_TOUCHSCREEN, DISPLAY_ID, AMOTION_EVENT_ACTION_MOVE, 0, 258 AMOTION_EVENT_FLAG_WINDOW_IS_OBSCURED, 259 AMOTION_EVENT_EDGE_FLAG_TOP, AMETA_ALT_ON, AMOTION_EVENT_BUTTON_PRIMARY, 260 MotionClassification::NONE, X_OFFSET, Y_OFFSET, 2.0f, 2.1f, 261 ARBITRARY_DOWN_TIME, ARBITRARY_EVENT_TIME, 262 2, pointerProperties, pointerCoords); 263 264 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_X, 110); 265 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_Y, 111); 266 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_PRESSURE, 112); 267 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_SIZE, 113); 268 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, 114); 269 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, 115); 270 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, 116); 271 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, 117); 272 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, 118); 273 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_X, 120); 274 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_Y, 121); 275 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_PRESSURE, 122); 276 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_SIZE, 123); 277 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, 124); 278 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, 125); 279 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, 126); 280 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, 127); 281 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, 128); 282 event->addSample(ARBITRARY_EVENT_TIME + 1, pointerCoords); 283 284 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_X, 210); 285 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_Y, 211); 286 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_PRESSURE, 212); 287 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_SIZE, 213); 288 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, 214); 289 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, 215); 290 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, 216); 291 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, 217); 292 pointerCoords[0].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, 218); 293 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_X, 220); 294 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_Y, 221); 295 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_PRESSURE, 222); 296 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_SIZE, 223); 297 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MAJOR, 224); 298 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOUCH_MINOR, 225); 299 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MAJOR, 226); 300 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_TOOL_MINOR, 227); 301 pointerCoords[1].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, 228); 302 event->addSample(ARBITRARY_EVENT_TIME + 2, pointerCoords); 303 } 304 305 void MotionEventTest::assertEqualsEventWithHistory(const MotionEvent* event) { 306 // Check properties. 307 ASSERT_EQ(AINPUT_EVENT_TYPE_MOTION, event->getType()); 308 ASSERT_EQ(2, event->getDeviceId()); 309 ASSERT_EQ(static_cast<int>(AINPUT_SOURCE_TOUCHSCREEN), event->getSource()); 310 ASSERT_EQ(DISPLAY_ID, event->getDisplayId()); 311 ASSERT_EQ(AMOTION_EVENT_ACTION_MOVE, event->getAction()); 312 ASSERT_EQ(AMOTION_EVENT_FLAG_WINDOW_IS_OBSCURED, event->getFlags()); 313 ASSERT_EQ(AMOTION_EVENT_EDGE_FLAG_TOP, event->getEdgeFlags()); 314 ASSERT_EQ(AMETA_ALT_ON, event->getMetaState()); 315 ASSERT_EQ(AMOTION_EVENT_BUTTON_PRIMARY, event->getButtonState()); 316 ASSERT_EQ(MotionClassification::NONE, event->getClassification()); 317 ASSERT_EQ(X_OFFSET, event->getXOffset()); 318 ASSERT_EQ(Y_OFFSET, event->getYOffset()); 319 ASSERT_EQ(2.0f, event->getXPrecision()); 320 ASSERT_EQ(2.1f, event->getYPrecision()); 321 ASSERT_EQ(ARBITRARY_DOWN_TIME, event->getDownTime()); 322 323 ASSERT_EQ(2U, event->getPointerCount()); 324 ASSERT_EQ(1, event->getPointerId(0)); 325 ASSERT_EQ(AMOTION_EVENT_TOOL_TYPE_FINGER, event->getToolType(0)); 326 ASSERT_EQ(2, event->getPointerId(1)); 327 ASSERT_EQ(AMOTION_EVENT_TOOL_TYPE_STYLUS, event->getToolType(1)); 328 329 ASSERT_EQ(2U, event->getHistorySize()); 330 331 // Check data. 332 ASSERT_EQ(ARBITRARY_EVENT_TIME, event->getHistoricalEventTime(0)); 333 ASSERT_EQ(ARBITRARY_EVENT_TIME + 1, event->getHistoricalEventTime(1)); 334 ASSERT_EQ(ARBITRARY_EVENT_TIME + 2, event->getEventTime()); 335 336 ASSERT_EQ(11, event->getHistoricalRawPointerCoords(0, 0)-> 337 getAxisValue(AMOTION_EVENT_AXIS_Y)); 338 ASSERT_EQ(21, event->getHistoricalRawPointerCoords(1, 0)-> 339 getAxisValue(AMOTION_EVENT_AXIS_Y)); 340 ASSERT_EQ(111, event->getHistoricalRawPointerCoords(0, 1)-> 341 getAxisValue(AMOTION_EVENT_AXIS_Y)); 342 ASSERT_EQ(121, event->getHistoricalRawPointerCoords(1, 1)-> 343 getAxisValue(AMOTION_EVENT_AXIS_Y)); 344 ASSERT_EQ(211, event->getRawPointerCoords(0)-> 345 getAxisValue(AMOTION_EVENT_AXIS_Y)); 346 ASSERT_EQ(221, event->getRawPointerCoords(1)-> 347 getAxisValue(AMOTION_EVENT_AXIS_Y)); 348 349 ASSERT_EQ(11, event->getHistoricalRawAxisValue(AMOTION_EVENT_AXIS_Y, 0, 0)); 350 ASSERT_EQ(21, event->getHistoricalRawAxisValue(AMOTION_EVENT_AXIS_Y, 1, 0)); 351 ASSERT_EQ(111, event->getHistoricalRawAxisValue(AMOTION_EVENT_AXIS_Y, 0, 1)); 352 ASSERT_EQ(121, event->getHistoricalRawAxisValue(AMOTION_EVENT_AXIS_Y, 1, 1)); 353 ASSERT_EQ(211, event->getRawAxisValue(AMOTION_EVENT_AXIS_Y, 0)); 354 ASSERT_EQ(221, event->getRawAxisValue(AMOTION_EVENT_AXIS_Y, 1)); 355 356 ASSERT_EQ(10, event->getHistoricalRawX(0, 0)); 357 ASSERT_EQ(20, event->getHistoricalRawX(1, 0)); 358 ASSERT_EQ(110, event->getHistoricalRawX(0, 1)); 359 ASSERT_EQ(120, event->getHistoricalRawX(1, 1)); 360 ASSERT_EQ(210, event->getRawX(0)); 361 ASSERT_EQ(220, event->getRawX(1)); 362 363 ASSERT_EQ(11, event->getHistoricalRawY(0, 0)); 364 ASSERT_EQ(21, event->getHistoricalRawY(1, 0)); 365 ASSERT_EQ(111, event->getHistoricalRawY(0, 1)); 366 ASSERT_EQ(121, event->getHistoricalRawY(1, 1)); 367 ASSERT_EQ(211, event->getRawY(0)); 368 ASSERT_EQ(221, event->getRawY(1)); 369 370 ASSERT_EQ(X_OFFSET + 10, event->getHistoricalX(0, 0)); 371 ASSERT_EQ(X_OFFSET + 20, event->getHistoricalX(1, 0)); 372 ASSERT_EQ(X_OFFSET + 110, event->getHistoricalX(0, 1)); 373 ASSERT_EQ(X_OFFSET + 120, event->getHistoricalX(1, 1)); 374 ASSERT_EQ(X_OFFSET + 210, event->getX(0)); 375 ASSERT_EQ(X_OFFSET + 220, event->getX(1)); 376 377 ASSERT_EQ(Y_OFFSET + 11, event->getHistoricalY(0, 0)); 378 ASSERT_EQ(Y_OFFSET + 21, event->getHistoricalY(1, 0)); 379 ASSERT_EQ(Y_OFFSET + 111, event->getHistoricalY(0, 1)); 380 ASSERT_EQ(Y_OFFSET + 121, event->getHistoricalY(1, 1)); 381 ASSERT_EQ(Y_OFFSET + 211, event->getY(0)); 382 ASSERT_EQ(Y_OFFSET + 221, event->getY(1)); 383 384 ASSERT_EQ(12, event->getHistoricalPressure(0, 0)); 385 ASSERT_EQ(22, event->getHistoricalPressure(1, 0)); 386 ASSERT_EQ(112, event->getHistoricalPressure(0, 1)); 387 ASSERT_EQ(122, event->getHistoricalPressure(1, 1)); 388 ASSERT_EQ(212, event->getPressure(0)); 389 ASSERT_EQ(222, event->getPressure(1)); 390 391 ASSERT_EQ(13, event->getHistoricalSize(0, 0)); 392 ASSERT_EQ(23, event->getHistoricalSize(1, 0)); 393 ASSERT_EQ(113, event->getHistoricalSize(0, 1)); 394 ASSERT_EQ(123, event->getHistoricalSize(1, 1)); 395 ASSERT_EQ(213, event->getSize(0)); 396 ASSERT_EQ(223, event->getSize(1)); 397 398 ASSERT_EQ(14, event->getHistoricalTouchMajor(0, 0)); 399 ASSERT_EQ(24, event->getHistoricalTouchMajor(1, 0)); 400 ASSERT_EQ(114, event->getHistoricalTouchMajor(0, 1)); 401 ASSERT_EQ(124, event->getHistoricalTouchMajor(1, 1)); 402 ASSERT_EQ(214, event->getTouchMajor(0)); 403 ASSERT_EQ(224, event->getTouchMajor(1)); 404 405 ASSERT_EQ(15, event->getHistoricalTouchMinor(0, 0)); 406 ASSERT_EQ(25, event->getHistoricalTouchMinor(1, 0)); 407 ASSERT_EQ(115, event->getHistoricalTouchMinor(0, 1)); 408 ASSERT_EQ(125, event->getHistoricalTouchMinor(1, 1)); 409 ASSERT_EQ(215, event->getTouchMinor(0)); 410 ASSERT_EQ(225, event->getTouchMinor(1)); 411 412 ASSERT_EQ(16, event->getHistoricalToolMajor(0, 0)); 413 ASSERT_EQ(26, event->getHistoricalToolMajor(1, 0)); 414 ASSERT_EQ(116, event->getHistoricalToolMajor(0, 1)); 415 ASSERT_EQ(126, event->getHistoricalToolMajor(1, 1)); 416 ASSERT_EQ(216, event->getToolMajor(0)); 417 ASSERT_EQ(226, event->getToolMajor(1)); 418 419 ASSERT_EQ(17, event->getHistoricalToolMinor(0, 0)); 420 ASSERT_EQ(27, event->getHistoricalToolMinor(1, 0)); 421 ASSERT_EQ(117, event->getHistoricalToolMinor(0, 1)); 422 ASSERT_EQ(127, event->getHistoricalToolMinor(1, 1)); 423 ASSERT_EQ(217, event->getToolMinor(0)); 424 ASSERT_EQ(227, event->getToolMinor(1)); 425 426 ASSERT_EQ(18, event->getHistoricalOrientation(0, 0)); 427 ASSERT_EQ(28, event->getHistoricalOrientation(1, 0)); 428 ASSERT_EQ(118, event->getHistoricalOrientation(0, 1)); 429 ASSERT_EQ(128, event->getHistoricalOrientation(1, 1)); 430 ASSERT_EQ(218, event->getOrientation(0)); 431 ASSERT_EQ(228, event->getOrientation(1)); 432 } 433 434 TEST_F(MotionEventTest, Properties) { 435 MotionEvent event; 436 437 // Initialize, add samples and check properties. 438 initializeEventWithHistory(&event); 439 ASSERT_NO_FATAL_FAILURE(assertEqualsEventWithHistory(&event)); 440 441 // Set source. 442 event.setSource(AINPUT_SOURCE_JOYSTICK); 443 ASSERT_EQ(static_cast<int>(AINPUT_SOURCE_JOYSTICK), event.getSource()); 444 445 // Set displayId. 446 constexpr int32_t newDisplayId = 2; 447 event.setDisplayId(newDisplayId); 448 ASSERT_EQ(newDisplayId, event.getDisplayId()); 449 450 // Set action. 451 event.setAction(AMOTION_EVENT_ACTION_CANCEL); 452 ASSERT_EQ(AMOTION_EVENT_ACTION_CANCEL, event.getAction()); 453 454 // Set meta state. 455 event.setMetaState(AMETA_CTRL_ON); 456 ASSERT_EQ(AMETA_CTRL_ON, event.getMetaState()); 457 } 458 459 TEST_F(MotionEventTest, CopyFrom_KeepHistory) { 460 MotionEvent event; 461 initializeEventWithHistory(&event); 462 463 MotionEvent copy; 464 copy.copyFrom(&event, true /*keepHistory*/); 465 466 ASSERT_NO_FATAL_FAILURE(assertEqualsEventWithHistory(&event)); 467 } 468 469 TEST_F(MotionEventTest, CopyFrom_DoNotKeepHistory) { 470 MotionEvent event; 471 initializeEventWithHistory(&event); 472 473 MotionEvent copy; 474 copy.copyFrom(&event, false /*keepHistory*/); 475 476 ASSERT_EQ(event.getPointerCount(), copy.getPointerCount()); 477 ASSERT_EQ(0U, copy.getHistorySize()); 478 479 ASSERT_EQ(event.getPointerId(0), copy.getPointerId(0)); 480 ASSERT_EQ(event.getPointerId(1), copy.getPointerId(1)); 481 482 ASSERT_EQ(event.getEventTime(), copy.getEventTime()); 483 484 ASSERT_EQ(event.getX(0), copy.getX(0)); 485 } 486 487 TEST_F(MotionEventTest, OffsetLocation) { 488 MotionEvent event; 489 initializeEventWithHistory(&event); 490 491 event.offsetLocation(5.0f, -2.0f); 492 493 ASSERT_EQ(X_OFFSET + 5.0f, event.getXOffset()); 494 ASSERT_EQ(Y_OFFSET - 2.0f, event.getYOffset()); 495 } 496 497 TEST_F(MotionEventTest, Scale) { 498 MotionEvent event; 499 initializeEventWithHistory(&event); 500 501 event.scale(2.0f); 502 503 ASSERT_EQ(X_OFFSET * 2, event.getXOffset()); 504 ASSERT_EQ(Y_OFFSET * 2, event.getYOffset()); 505 506 ASSERT_EQ(210 * 2, event.getRawX(0)); 507 ASSERT_EQ(211 * 2, event.getRawY(0)); 508 ASSERT_EQ((X_OFFSET + 210) * 2, event.getX(0)); 509 ASSERT_EQ((Y_OFFSET + 211) * 2, event.getY(0)); 510 ASSERT_EQ(212, event.getPressure(0)); 511 ASSERT_EQ(213, event.getSize(0)); 512 ASSERT_EQ(214 * 2, event.getTouchMajor(0)); 513 ASSERT_EQ(215 * 2, event.getTouchMinor(0)); 514 ASSERT_EQ(216 * 2, event.getToolMajor(0)); 515 ASSERT_EQ(217 * 2, event.getToolMinor(0)); 516 ASSERT_EQ(218, event.getOrientation(0)); 517 } 518 519 TEST_F(MotionEventTest, Parcel) { 520 Parcel parcel; 521 522 MotionEvent inEvent; 523 initializeEventWithHistory(&inEvent); 524 MotionEvent outEvent; 525 526 // Round trip. 527 inEvent.writeToParcel(&parcel); 528 parcel.setDataPosition(0); 529 outEvent.readFromParcel(&parcel); 530 531 ASSERT_NO_FATAL_FAILURE(assertEqualsEventWithHistory(&outEvent)); 532 } 533 534 static void setRotationMatrix(float matrix[9], float angle) { 535 float sin = sinf(angle); 536 float cos = cosf(angle); 537 matrix[0] = cos; 538 matrix[1] = -sin; 539 matrix[2] = 0; 540 matrix[3] = sin; 541 matrix[4] = cos; 542 matrix[5] = 0; 543 matrix[6] = 0; 544 matrix[7] = 0; 545 matrix[8] = 1.0f; 546 } 547 548 TEST_F(MotionEventTest, Transform) { 549 // Generate some points on a circle. 550 // Each point 'i' is a point on a circle of radius ROTATION centered at (3,2) at an angle 551 // of ARC * i degrees clockwise relative to the Y axis. 552 // The geometrical representation is irrelevant to the test, it's just easy to generate 553 // and check rotation. We set the orientation to the same angle. 554 // Coordinate system: down is increasing Y, right is increasing X. 555 const float PI_180 = float(M_PI / 180); 556 const float RADIUS = 10; 557 const float ARC = 36; 558 const float ROTATION = ARC * 2; 559 560 const size_t pointerCount = 11; 561 PointerProperties pointerProperties[pointerCount]; 562 PointerCoords pointerCoords[pointerCount]; 563 for (size_t i = 0; i < pointerCount; i++) { 564 float angle = float(i * ARC * PI_180); 565 pointerProperties[i].clear(); 566 pointerProperties[i].id = i; 567 pointerCoords[i].clear(); 568 pointerCoords[i].setAxisValue(AMOTION_EVENT_AXIS_X, sinf(angle) * RADIUS + 3); 569 pointerCoords[i].setAxisValue(AMOTION_EVENT_AXIS_Y, -cosf(angle) * RADIUS + 2); 570 pointerCoords[i].setAxisValue(AMOTION_EVENT_AXIS_ORIENTATION, angle); 571 } 572 MotionEvent event; 573 event.initialize(0 /*deviceId*/, AINPUT_SOURCE_UNKNOWN, DISPLAY_ID, AMOTION_EVENT_ACTION_MOVE, 574 0 /*actionButton*/, 0 /*flags*/, AMOTION_EVENT_EDGE_FLAG_NONE, 575 AMETA_NONE, 0 /*buttonState*/, MotionClassification::NONE, 576 0 /*xOffset*/, 0 /*yOffset*/, 0 /*xPrecision*/, 0 /*yPrecision*/, 577 0 /*downTime*/, 0 /*eventTime*/, pointerCount, pointerProperties, pointerCoords); 578 float originalRawX = 0 + 3; 579 float originalRawY = -RADIUS + 2; 580 581 // Check original raw X and Y assumption. 582 ASSERT_NEAR(originalRawX, event.getRawX(0), 0.001); 583 ASSERT_NEAR(originalRawY, event.getRawY(0), 0.001); 584 585 // Now translate the motion event so the circle's origin is at (0,0). 586 event.offsetLocation(-3, -2); 587 588 // Offsetting the location should preserve the raw X and Y of the first point. 589 ASSERT_NEAR(originalRawX, event.getRawX(0), 0.001); 590 ASSERT_NEAR(originalRawY, event.getRawY(0), 0.001); 591 592 // Apply a rotation about the origin by ROTATION degrees clockwise. 593 float matrix[9]; 594 setRotationMatrix(matrix, ROTATION * PI_180); 595 event.transform(matrix); 596 597 // Check the points. 598 for (size_t i = 0; i < pointerCount; i++) { 599 float angle = float((i * ARC + ROTATION) * PI_180); 600 ASSERT_NEAR(sinf(angle) * RADIUS, event.getX(i), 0.001); 601 ASSERT_NEAR(-cosf(angle) * RADIUS, event.getY(i), 0.001); 602 ASSERT_NEAR(tanf(angle), tanf(event.getOrientation(i)), 0.1); 603 } 604 605 // Applying the transformation should preserve the raw X and Y of the first point. 606 ASSERT_NEAR(originalRawX, event.getRawX(0), 0.001); 607 ASSERT_NEAR(originalRawY, event.getRawY(0), 0.001); 608 } 609 610 TEST_F(MotionEventTest, Initialize_SetsClassification) { 611 std::array<MotionClassification, 3> classifications = { 612 MotionClassification::NONE, 613 MotionClassification::AMBIGUOUS_GESTURE, 614 MotionClassification::DEEP_PRESS, 615 }; 616 617 MotionEvent event; 618 constexpr size_t pointerCount = 1; 619 PointerProperties pointerProperties[pointerCount]; 620 PointerCoords pointerCoords[pointerCount]; 621 for (size_t i = 0; i < pointerCount; i++) { 622 pointerProperties[i].clear(); 623 pointerProperties[i].id = i; 624 pointerCoords[i].clear(); 625 } 626 627 for (MotionClassification classification : classifications) { 628 event.initialize(0 /*deviceId*/, AINPUT_SOURCE_TOUCHSCREEN, DISPLAY_ID, 629 AMOTION_EVENT_ACTION_DOWN, 0, 0, AMOTION_EVENT_EDGE_FLAG_NONE, AMETA_NONE, 0, 630 classification, 0, 0, 0, 0, 0 /*downTime*/, 0 /*eventTime*/, 631 pointerCount, pointerProperties, pointerCoords); 632 ASSERT_EQ(classification, event.getClassification()); 633 } 634 } 635 636 } // namespace android 637