Merge branch 'devel/master' into sandbox/dkdk/tizen
[platform/core/uifw/dali-adaptor.git] / automated-tests / src / dali-adaptor / utc-Dali-Key.cpp
index aed7054..9064e60 100644 (file)
@@ -1,30 +1,31 @@
-//
-// Copyright (c) 2014 Samsung Electronics Co., Ltd.
-//
-// Licensed under the Flora License, Version 1.0 (the License);
-// you may not use this file except in compliance with the License.
-// You may obtain a copy of the License at
-//
-//     http://floralicense.org/license/
-//
-// Unless required by applicable law or agreed to in writing, software
-// distributed under the License is distributed on an AS IS BASIS,
-// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-// See the License for the specific language governing permissions and
-// limitations under the License.
-//
+/*
+ * Copyright (c) 2020 Samsung Electronics Co., Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
 
 // EXTERNAL INCLUDES
-#include <utilX.h>
-#include <map>
 #include <string.h>
 #include <iostream>
+#include <map>
 
 // CLASS HEADER
+#include <dali-test-suite-utils.h>
+#include <dali.h>
+#include <dali/devel-api/events/key-event-devel.h>
 #include <stdlib.h>
 #include <iostream>
-#include <dali.h>
-#include <dali-test-suite-utils.h>
 
 using namespace Dali;
 
@@ -38,65 +39,65 @@ void utc_dali_adaptor_key_cleanup(void)
   test_return_value = TET_PASS;
 }
 
-// Copied from key-impl.cpp
+// Copied from key-impl.h
 struct KeyLookup
 {
-  const char* keyName;      ///< X string representation
-  const int   daliKeyCode;  ///< Dali Enum Representation
-  const bool  deviceButton; ///< Whether the key is from a button on the device
+  const char*     keyName;      ///< XF86 key name
+  const Dali::KEY daliKeyCode;  ///< Dali key code
+  const bool      deviceButton; ///< Whether the key is from a button on the device
 };
 
-// Taken from key-impl.cpp
-KeyLookup KeyLookupTable[]=
-{
-  // KeyName                DALi Equivalent           true if device key
-  { "Escape",               DALI_KEY_ESCAPE,          false },
-  { "Menu",                 DALI_KEY_MENU,            false },
-  { KEY_CAMERA,             DALI_KEY_CAMERA,          false },
-  { KEY_CONFIG,             DALI_KEY_CONFIG,          false },
-  { KEY_POWER,              DALI_KEY_POWER,           true  },
-  { KEY_PAUSE,              DALI_KEY_PAUSE,           false },
-  { KEY_CANCEL,             DALI_KEY_CANCEL,          false },
-  { KEY_PLAYCD,             DALI_KEY_PLAY_CD,         false },
-  { KEY_STOPCD,             DALI_KEY_STOP_CD,         false },
-  { KEY_PAUSECD,            DALI_KEY_PAUSE_CD,        false },
-  { KEY_NEXTSONG,           DALI_KEY_NEXT_SONG,       false },
-  { KEY_PREVIOUSSONG,       DALI_KEY_PREVIOUS_SONG,   false },
-  { KEY_REWIND,             DALI_KEY_REWIND,          false },
-  { KEY_FASTFORWARD,        DALI_KEY_FASTFORWARD,     false },
-  { KEY_MEDIA,              DALI_KEY_MEDIA,           false },
-  { KEY_PLAYPAUSE,          DALI_KEY_PLAY_PAUSE,      false },
-  { KEY_MUTE,               DALI_KEY_MUTE,            false },
-  { KEY_SEND,               DALI_KEY_SEND,            true  },
-  { KEY_SELECT,             DALI_KEY_SELECT,          true  },
-  { KEY_END,                DALI_KEY_END,             true  },
-  { KEY_MENU,               DALI_KEY_MENU,            true  },
-  { KEY_HOME,               DALI_KEY_HOME,            true  },
-  { KEY_BACK,               DALI_KEY_BACK,            true  },
-  { KEY_HOMEPAGE,           DALI_KEY_HOMEPAGE,        false },
-  { KEY_WEBPAGE,            DALI_KEY_WEBPAGE,         false },
-  { KEY_MAIL,               DALI_KEY_MAIL,            false },
-  { KEY_SCREENSAVER,        DALI_KEY_SCREENSAVER,     false },
-  { KEY_BRIGHTNESSUP,       DALI_KEY_BRIGHTNESS_UP,   false },
-  { KEY_BRIGHTNESSDOWN,     DALI_KEY_BRIGHTNESS_DOWN, false },
-  { KEY_SOFTKBD,            DALI_KEY_SOFT_KBD,        false },
-  { KEY_QUICKPANEL,         DALI_KEY_QUICK_PANEL,     false },
-  { KEY_TASKSWITCH,         DALI_KEY_TASK_SWITCH,     false },
-  { KEY_APPS,               DALI_KEY_APPS,            false },
-  { KEY_SEARCH,             DALI_KEY_SEARCH,          false },
-  { KEY_VOICE,              DALI_KEY_VOICE,           false },
-  { KEY_LANGUAGE,           DALI_KEY_LANGUAGE,        false },
-  { KEY_VOLUMEUP,           DALI_KEY_VOLUME_UP,       true  },
-  { KEY_VOLUMEDOWN,         DALI_KEY_VOLUME_DOWN,     true  },
-};
-const std::size_t KEY_LOOKUP_COUNT = (sizeof( KeyLookupTable))/ (sizeof(KeyLookup));
+// Common keys for all platforms
+KeyLookup KeyLookupTable[] =
+  {
+    {"Escape", DALI_KEY_ESCAPE, false}, // item not defined in utilX
+    {"Menu", DALI_KEY_MENU, false},     // item not defined in utilX
 
+    // Now the key names are used as literal string not defined symbols,
+    // since these definition in utilX.h is deprecated and we're guided not to use them
+    {"XF86Camera", DALI_KEY_CAMERA, false},
+    {"XF86Camera_Full", DALI_KEY_CONFIG, false},
+    {"XF86PowerOff", DALI_KEY_POWER, true},
+    {"XF86Standby", DALI_KEY_PAUSE, false},
+    {"Cancel", DALI_KEY_CANCEL, false},
+    {"XF86AudioPlay", DALI_KEY_PLAY_CD, false},
+    {"XF86AudioStop", DALI_KEY_STOP_CD, false},
+    {"XF86AudioPause", DALI_KEY_PAUSE_CD, false},
+    {"XF86AudioNext", DALI_KEY_NEXT_SONG, false},
+    {"XF86AudioPrev", DALI_KEY_PREVIOUS_SONG, false},
+    {"XF86AudioRewind", DALI_KEY_REWIND, false},
+    {"XF86AudioForward", DALI_KEY_FASTFORWARD, false},
+    {"XF86AudioMedia", DALI_KEY_MEDIA, false},
+    {"XF86AudioPlayPause", DALI_KEY_PLAY_PAUSE, false},
+    {"XF86AudioMute", DALI_KEY_MUTE, false},
+    {"XF86Menu", DALI_KEY_MENU, true},
+    {"XF86Home", DALI_KEY_HOME, true},
+    {"XF86Back", DALI_KEY_BACK, true},
+    {"XF86Send", DALI_KEY_MENU, true},
+    {"XF86Phone", DALI_KEY_HOME, true},
+    {"XF86Stop", DALI_KEY_BACK, true},
+    {"XF86HomePage", DALI_KEY_HOMEPAGE, false},
+    {"XF86WWW", DALI_KEY_WEBPAGE, false},
+    {"XF86Mail", DALI_KEY_MAIL, false},
+    {"XF86ScreenSaver", DALI_KEY_SCREENSAVER, false},
+    {"XF86MonBrightnessUp", DALI_KEY_BRIGHTNESS_UP, false},
+    {"XF86MonBrightnessDown", DALI_KEY_BRIGHTNESS_DOWN, false},
+    {"XF86SoftKBD", DALI_KEY_SOFT_KBD, false},
+    {"XF86QuickPanel", DALI_KEY_QUICK_PANEL, false},
+    {"XF86TaskPane", DALI_KEY_TASK_SWITCH, false},
+    {"XF86Apps", DALI_KEY_APPS, false},
+    {"XF86Search", DALI_KEY_SEARCH, false},
+    {"XF86Voice", DALI_KEY_VOICE, false},
+    {"Hangul", DALI_KEY_LANGUAGE, false},
+    {"XF86AudioRaiseVolume", DALI_KEY_VOLUME_UP, true},
+    {"XF86AudioLowerVolume", DALI_KEY_VOLUME_DOWN, true},
+};
+const std::size_t KEY_LOOKUP_COUNT = (sizeof(KeyLookupTable)) / (sizeof(KeyLookup));
 
 // Generate a KeyPressEvent to send to Core
-Dali::KeyEvent GenerateKeyPress( const std::string& keyName )
+Dali::KeyEvent GenerateKeyPress(const std::string& keyName)
 {
-  KeyEvent keyPress;
-  keyPress.keyPressedName = keyName;
+  Dali::KeyEvent keyPress = DevelKeyEvent::New(keyName, "", "", -1, 0, 0lu, Dali::KeyEvent::DOWN, "", "", Device::Class::NONE, Device::Subclass::NONE); // set name to test, key string to i and modifier to shift
   return keyPress;
 }
 
@@ -104,10 +105,10 @@ int UtcDaliKeyIsKey(void)
 {
   TestApplication application;
 
-  for ( std::size_t i = 0; i < KEY_LOOKUP_COUNT; ++i )
+  for(std::size_t i = 0; i < KEY_LOOKUP_COUNT; ++i)
   {
-    tet_printf( "Checking %s", KeyLookupTable[i].keyName );
-    DALI_TEST_CHECK( IsKey( GenerateKeyPress( KeyLookupTable[i].keyName ), KeyLookupTable[i].daliKeyCode ) );
+    tet_printf("Checking %s", KeyLookupTable[i].keyName);
+    DALI_TEST_CHECK(IsKey(GenerateKeyPress(KeyLookupTable[i].keyName), KeyLookupTable[i].daliKeyCode));
   }
   END_TEST;
 }
@@ -117,13 +118,13 @@ int UtcDaliKeyIsKeyNegative(void)
   TestApplication application;
 
   // Random value
-  DALI_TEST_CHECK( IsKey( GenerateKeyPress( "invalid-key-name" ), DALI_KEY_MUTE ) == false );
+  DALI_TEST_CHECK(IsKey(GenerateKeyPress("invalid-key-name"), DALI_KEY_MUTE) == false);
 
   // Compare with another key value
-  for ( std::size_t i = 0; i < KEY_LOOKUP_COUNT; ++i )
+  for(std::size_t i = 0; i < KEY_LOOKUP_COUNT; ++i)
   {
-    tet_printf( "Checking %s", KeyLookupTable[i].keyName );
-    DALI_TEST_CHECK( IsKey( GenerateKeyPress( KeyLookupTable[i].keyName ), KeyLookupTable[ ( i + 1 ) % KEY_LOOKUP_COUNT ].daliKeyCode ) == false );
+    tet_printf("Checking %s", KeyLookupTable[i].keyName);
+    DALI_TEST_CHECK(IsKey(GenerateKeyPress(KeyLookupTable[i].keyName), KeyLookupTable[(i + 1) % KEY_LOOKUP_COUNT].daliKeyCode) == false);
   }
   END_TEST;
 }