Add testsuite 'scmirroring_sink_test_SBS' and 'README'. 76/139676/6
authorHyunsoo <hance.park@samsung.com>
Thu, 20 Jul 2017 05:51:50 +0000 (14:51 +0900)
committerHyunsoo <hance.park@samsung.com>
Thu, 20 Jul 2017 08:17:16 +0000 (17:17 +0900)
*Testsuite 'scmirroring_sink_test_SBS' is added.
*It allows to run CAPI command individually.
*Also i addes README.txt for description

Change-Id: I0b10bca37cfb0d2a9b69428b70e64a1069ba6fb6
Signed-off-by: Hyunsoo <hance.park@samsung.com>
packaging/capi-media-screen-mirroring.spec
test_sink/README.txt [new file with mode: 0644]
test_sink/scmirroring_sink_test_SBS.c [new file with mode: 0644]

index beffe65f1345ec7ce01be27c36b9cb08b8e4dc65..5d0665cd0b7c1d4b38d8f0b18f5fb7e5902654c6 100644 (file)
@@ -1,6 +1,6 @@
 Name:       capi-media-screen-mirroring
 Summary:    A screen mirroring library in Tizen C API
-Version:    0.1.84
+Version:    0.1.85
 Release:    0
 Group:      Multimedia/API
 License:    Apache-2.0
diff --git a/test_sink/README.txt b/test_sink/README.txt
new file mode 100644 (file)
index 0000000..f879f02
--- /dev/null
@@ -0,0 +1,14 @@
+------------------------------------------
+|                                        |
+| Screen Mirroring Sink Testsuite guide  |
+|                                        |
+------------------------------------------
+
+*scmirroring_sink_test
+: This is screen mirroring 'SINK' testsuite.
+  It reaches in 'PLAYING' state at once with command 's'.
+  When command 's' is input, APIs for displaying screen mirroring are run in order(scmirroring_sink_prepare > scmirroring_sink_connect > scmirorring_sink_start).
+
+*scmirroring_sink_test_SBS
+: This is screen mirroring 'SINK' testsuite.
+  It can allows you to running APIs individually which is run automatically in 'scmirroring_sink_test' testsuite.
diff --git a/test_sink/scmirroring_sink_test_SBS.c b/test_sink/scmirroring_sink_test_SBS.c
new file mode 100644 (file)
index 0000000..321d9bf
--- /dev/null
@@ -0,0 +1,1267 @@
+/*
+* Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
+*
+* 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.
+*/
+
+#include <stdlib.h>
+#include <string.h>
+#include <glib/gprintf.h>
+#include <scmirroring_sink.h>
+#include <wifi-direct.h>
+#include <wifi-direct-internal.h>
+
+#include <Elementary.h>
+#include <appcore-efl.h>
+
+#define MAX_STRING_LEN    2048
+#define SINKTEST_EXECUTE_DELAY 5000
+#define MAIN_MENU 0
+#define SUBMENU_RESOLUTION 1
+#define SUBMENU_GETTING_STREAM_INFO 2
+#define SUBMENU_SETTING_SINK 3
+#define SUBMENU_SETTING_WINDOW_SIZE 4
+
+//#define TEST_WITH_WIFI_DIRECT
+
+#define PACKAGE "screen_mirroring_sink_test"
+static int app_create(void *data);
+static int app_terminate(void *data);
+static Evas_Object* _create_win(const char *name);
+static Evas_Object *create_evas_image_object(Evas_Object *eo_parent);
+static void _win_del(void *data, Evas_Object *obj, void *event);
+static gboolean _scmirroring_start_jobs(gpointer data);
+
+struct appcore_ops ops = {
+       .create = app_create,
+       .terminate = app_terminate,
+};
+static Evas_Object* g_evas;
+static Evas_Object* g_eo = NULL;
+
+scmirroring_sink_h g_scmirroring = NULL;
+gint g_resolution = 0;
+gint g_sinktype = SCMIRRORING_DISPLAY_TYPE_OVERLAY;
+
+gint g_menu = MAIN_MENU;
+
+#ifdef TEST_WITH_WIFI_DIRECT
+static int g_peer_cnt = 0;
+static char g_peer_ip[32];
+static char g_peer_port[32];
+static char g_src_mac_addr[18] = {0, };
+#define DEFAULT_SCREEN_MIRRORING_PORT 2022
+#endif
+
+gboolean __scmirroring_sink_start(gpointer data);
+
+#ifndef TEST_WITH_WIFI_DIRECT
+static int __scmirroring_sink_create(gpointer data);
+static int __scmirroring_sink_prepare(gpointer data);
+static int __scmirroring_sink_connect(gpointer data);
+static int __scmirroring_sink_unprepare(gpointer data);
+static int __scmirroring_sink_destroy(gpointer data);
+static int __scmirroring_sink_start_only(gpointer data);
+#endif
+#ifdef TEST_WITH_WIFI_DIRECT
+static gboolean __start_wifi_display_connection();
+static gboolean __start_p2p_connection(gpointer data);
+static gboolean __disconnect_p2p_connection(void);
+#endif
+static void __quit_program(void);
+gboolean __timeout_menu_display(void *data);
+
+/* Submenu for setting resolution */
+static void __display_resolution_submenu(void);
+gboolean __timeout_resolution_submenu_display(void *data);
+static void __interpret_resolution_submenu(char *cmd);
+
+/* Submenu for getting negotiated audio and video information */
+static void __display_stream_info_submenu(void);
+gboolean __timeout_stream_info_submenu_display(void *data);
+static void __interpret_stream_info_submenu(char *cmd);
+
+/* Submenu for setting sink type */
+gboolean __timeout_sink_submenu_display(void *data);
+static void __display_sink_submenu(void);
+static void __interpret_sink_submenu(char *cmd);
+static void create_render_rect_and_bg(Evas_Object *win);
+
+/* Submenu for setting window size */
+gboolean __timeout_window_size_submenu_display(void *data);
+static void __display_window_size_submenu(void);
+static void __interpret_window_size_submenu(char *cmd);
+
+static void create_render_rect_and_bg(Evas_Object *win);
+void create_render_rect_and_bg(Evas_Object *win)
+{
+       if (!win) {
+               g_print("no win");
+               return;
+       }
+       Evas_Object *bg, *rect;
+
+       bg = elm_bg_add(win);
+       elm_win_resize_object_add(win, bg);
+       evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_show(bg);
+
+       rect = evas_object_rectangle_add(evas_object_evas_get(win));
+       if (!rect) {
+               g_print("no rect");
+               return;
+       }
+       evas_object_color_set(rect, 0, 0, 0, 0);
+       evas_object_render_op_set(rect, EVAS_RENDER_COPY);
+
+       elm_win_resize_object_add(win, rect);
+       evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_show(rect);
+       evas_object_show(win);
+}
+
+static void _win_del(void *data, Evas_Object *obj, void *event)
+{
+       elm_exit();
+}
+
+
+static Evas_Object* _create_win(const char *name)
+{
+       Evas_Object *eo = NULL;
+       int w = 0;
+       int h = 0;
+
+       g_printf("[%s][%d] name=%s\n", __func__, __LINE__, name);
+
+       eo = elm_win_add(NULL, name, ELM_WIN_BASIC);
+       if (eo) {
+               elm_win_title_set(eo, name);
+               elm_win_borderless_set(eo, EINA_TRUE);
+               evas_object_smart_callback_add(eo, "delete,request", _win_del, NULL);
+               elm_win_autodel_set(eo, EINA_TRUE);
+               elm_win_screen_size_get(eo, NULL, NULL, &w, &h);
+               g_print("window size :%d,%d\n", w, h);
+               elm_win_alpha_set(eo, EINA_TRUE);
+       }
+       return eo;
+}
+
+static Evas_Object *create_evas_image_object(Evas_Object *eo_parent)
+{
+       if (!eo_parent)
+               return NULL;
+
+       Evas *evas = evas_object_evas_get(eo_parent);
+       Evas_Object *eo = NULL;
+
+       eo = evas_object_image_add(evas);
+
+       return eo;
+}
+
+static int app_create(void *data)
+{
+
+       gboolean result = FALSE;
+
+       g_print("app_create enter");
+
+       Evas_Object *win = NULL;
+       /* create window */
+       win = _create_win(PACKAGE);
+       if (win == NULL)
+               return -1;
+       g_evas = win;
+       create_render_rect_and_bg(g_evas);
+
+       elm_win_activate(win);
+       evas_object_show(win);
+
+       result = _scmirroring_start_jobs((void *)NULL);
+       if (result != TRUE)
+               g_print("failed _scmirroring_start_jobs ");
+
+       g_print("app_create leave");
+
+       return result;
+
+}
+static int app_terminate(void *data)
+{
+
+       if (g_evas) {
+               evas_object_del(g_evas);
+               g_evas = NULL;
+       }
+       return 0;
+}
+
+gboolean __timeout_sink_submenu_display(void *data)
+{
+       __display_sink_submenu();
+       return FALSE;
+}
+
+static void __display_sink_submenu(void)
+{
+       g_print("\n");
+       g_print("**********************************************************************\n");
+       g_print("               Setting sink \n");
+       g_print("**********************************************************************\n");
+       g_print("1 : SCMIRRORING_DISPLAY_TYPE_OVERLAY with No Surface(DEFAULT)\n");
+       g_print("2 : SCMIRRORING_DISPLAY_TYPE_OVERLAY with Surface\n");
+       g_print("3 : SCMIRRORING_DISPLAY_TYPE_EVAS\n");
+       g_print("g : Go back to main menu \n");
+       g_print("**********************************************************************\n");
+
+}
+
+static void __interpret_sink_submenu(char *cmd)
+{
+       if (strncmp(cmd, "1", 1) == 0) {
+               g_print("SCMIRRORING_DISPLAY_TYPE_OVERLAY with No Surface\n");
+               g_sinktype = -1;
+       } else if (strncmp(cmd, "2", 1) == 0) {
+               g_print("SCMIRRORING_DISPLAY_TYPE_OVERLAY with Surface\n");
+               g_sinktype = SCMIRRORING_DISPLAY_TYPE_OVERLAY;
+       } else if (strncmp(cmd, "3", 1) == 0) {
+               g_print("SCMIRRORING_DISPLAY_TYPE_EVAS\n");
+               g_sinktype = SCMIRRORING_DISPLAY_TYPE_EVAS;
+       } else if (strncmp(cmd, "g", 1) == 0) {
+               g_print("go back to main menu\n");
+               g_menu = MAIN_MENU;
+               g_timeout_add(100, __timeout_menu_display, 0);
+               return;
+       }
+
+       g_print("sink type : %d\n", g_sinktype);
+       g_timeout_add(100, __timeout_sink_submenu_display, 0);
+       return;
+}
+
+gboolean __timeout_resolution_submenu_display(void *data)
+{
+       __display_resolution_submenu();
+       return FALSE;
+}
+
+static void __display_resolution_submenu(void)
+{
+       g_print("\n");
+       g_print("**********************************************************************\n");
+       g_print("               Setting resolution \n");
+       g_print("**********************************************************************\n");
+       g_print("1 : SCMIRRORING_RESOLUTION_1920x1080_P30 [%d]\n", SCMIRRORING_RESOLUTION_1920x1080_P30);
+       g_print("2 : SCMIRRORING_RESOLUTION_1280x720_P30  [%d]\n", SCMIRRORING_RESOLUTION_1280x720_P30);
+       g_print("3 : SCMIRRORING_RESOLUTION_960x540_P30   [%d]\n", SCMIRRORING_RESOLUTION_960x540_P30);
+       g_print("4 : SCMIRRORING_RESOLUTION_864x480_P30   [%d]\n", SCMIRRORING_RESOLUTION_864x480_P30);
+       g_print("5 : SCMIRRORING_RESOLUTION_720x480_P60   [%d]\n", SCMIRRORING_RESOLUTION_720x480_P60);
+       g_print("6 : SCMIRRORING_RESOLUTION_640x480_P60   [%d]\n", SCMIRRORING_RESOLUTION_640x480_P60);
+       g_print("7 : SCMIRRORING_RESOLUTION_640x360_P30   [%d]\n", SCMIRRORING_RESOLUTION_640x360_P30);
+       g_print("r : Reset resolution \n");
+       g_print("g : Go back to main menu \n");
+       g_print("**********************************************************************\n");
+
+}
+
+static void __interpret_resolution_submenu(char *cmd)
+{
+       if (strncmp(cmd, "1", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_1920x1080_P30[%d]\n", SCMIRRORING_RESOLUTION_1920x1080_P30);
+               g_resolution |= SCMIRRORING_RESOLUTION_1920x1080_P30;
+       } else if (strncmp(cmd, "2", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_1280x720_P30[%d]\n", SCMIRRORING_RESOLUTION_1280x720_P30);
+               g_resolution |= SCMIRRORING_RESOLUTION_1280x720_P30;
+       } else if (strncmp(cmd, "3", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_960x540_P30[%d]\n", SCMIRRORING_RESOLUTION_960x540_P30);
+               g_resolution |= SCMIRRORING_RESOLUTION_960x540_P30;
+       } else if (strncmp(cmd, "4", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_864x480_P30[%d]\n", SCMIRRORING_RESOLUTION_864x480_P30);
+               g_resolution |= SCMIRRORING_RESOLUTION_864x480_P30;
+       } else if (strncmp(cmd, "5", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_720x480_P60[%d]\n", SCMIRRORING_RESOLUTION_720x480_P60);
+               g_resolution |= SCMIRRORING_RESOLUTION_720x480_P60;
+       } else if (strncmp(cmd, "6", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_640x480_P60[%d]\n", SCMIRRORING_RESOLUTION_640x480_P60);
+               g_resolution |= SCMIRRORING_RESOLUTION_640x480_P60;
+       } else if (strncmp(cmd, "7", 1) == 0) {
+               g_print("resolution |= SCMIRRORING_RESOLUTION_640x360_P30[%d]\n", SCMIRRORING_RESOLUTION_640x360_P30);
+               g_resolution |= SCMIRRORING_RESOLUTION_640x360_P30;
+       } else if (strncmp(cmd, "r", 1) == 0) {
+               g_resolution = 0;
+       } else if (strncmp(cmd, "g", 1) == 0) {
+               g_print("go back to main menu\n");
+               g_menu = MAIN_MENU;
+               g_timeout_add(100, __timeout_menu_display, 0);
+               return;
+       }
+
+       g_print("resolution : %d\n", g_resolution);
+       scmirroring_sink_set_resolution(g_scmirroring, g_resolution);
+       g_timeout_add(100, __timeout_resolution_submenu_display, 0);
+
+       return;
+}
+
+gboolean __timeout_stream_info_submenu_display(void *data)
+{
+       __display_stream_info_submenu();
+       return FALSE;
+}
+
+static void __display_stream_info_submenu(void)
+{
+       g_print("\n");
+       g_print("**********************************************************************\n");
+       g_print("               Getting negotiated audio and video information \n");
+       g_print("**********************************************************************\n");
+       g_print("1 : video codec\n");
+       g_print("2 : video resolution\n");
+       g_print("3 : video frame rate\n");
+       g_print("4 : audio codec\n");
+       g_print("5 : audio channel\n");
+       g_print("6 : audio sample rate\n");
+       g_print("7 : audio bitwidth\n");
+       g_print("g : Go back to main menu \n");
+       g_print("**********************************************************************\n");
+
+}
+
+static void __interpret_stream_info_submenu(char *cmd)
+{
+       int ret = SCMIRRORING_ERROR_NONE;
+       if (strncmp(cmd, "1", 1) == 0) {
+
+               scmirroring_video_codec_e codec;
+               ret = scmirroring_sink_get_negotiated_video_codec(&g_scmirroring, &codec);
+               if (ret != SCMIRRORING_ERROR_NONE) {
+                       g_print("Error : scmirroring_sink_get_negotiated_video_codec fail[%d]\n", ret);
+               } else {
+                       switch (codec) {
+                       case SCMIRRORING_VIDEO_CODEC_H264:
+                               g_print("video codec : H264[%d]\n", codec);
+                               break;
+                       default:
+                               g_print("video codec : NONE[%d]\n", codec);
+                               break;
+                       }
+               }
+
+       } else if (strncmp(cmd, "2", 1) == 0) {
+
+               int width, height;
+               ret = scmirroring_sink_get_negotiated_video_resolution(&g_scmirroring, &width, &height);
+               if (ret != SCMIRRORING_ERROR_NONE)
+                       g_print("Error : scmirroring_sink_get_negotiated_video_resolution fail[%d]\n", ret);
+               else
+                       g_print("video resoltuion : width[%d], height[%d]\n", width, height);
+
+       } else if (strncmp(cmd, "3", 1) == 0) {
+
+               int frame_rate;
+               ret = scmirroring_sink_get_negotiated_video_frame_rate(&g_scmirroring, &frame_rate);
+               if (ret != SCMIRRORING_ERROR_NONE)
+                       g_print("Error : scmirroring_sink_get_negotiated_video_frame_rate fail[%d]\n", ret);
+               else
+                       g_print("video frame rate[%d]\n", frame_rate);
+
+       } else if (strncmp(cmd, "4", 1) == 0) {
+               scmirroring_audio_codec_e codec;
+               ret = scmirroring_sink_get_negotiated_audio_codec(&g_scmirroring, &codec);
+               if (ret != SCMIRRORING_ERROR_NONE) {
+                       g_print("Error : scmirroring_sink_get_negotiated_audio_codec fail[%d]\n", ret);
+               } else {
+                       switch (codec) {
+                       case SCMIRRORING_AUDIO_CODEC_AAC:
+                               g_print("audio codec : AAC[%d]\n", codec);
+                               break;
+                       case SCMIRRORING_AUDIO_CODEC_AC3:
+                               g_print("audio codec : AC3[%d]\n", codec);
+                               break;
+                       case SCMIRRORING_AUDIO_CODEC_LPCM:
+                               g_print("audio codec : LPCM[%d]\n", codec);
+                               break;
+                       default:
+                               g_print("audio codec : NONE[%d]\n", codec);
+                               break;
+                       }
+               }
+
+       } else if (strncmp(cmd, "5", 1) == 0) {
+               int channel;
+               ret = scmirroring_sink_get_negotiated_audio_channel(&g_scmirroring, &channel);
+               if (ret != SCMIRRORING_ERROR_NONE)
+                       g_print("Error : scmirroring_sink_get_negotiated_audio_channel fail[%d]\n", ret);
+               else
+                       g_print("audio channel[%d]\n", channel);
+
+       } else if (strncmp(cmd, "6", 1) == 0) {
+               int sample_rate;
+               ret = scmirroring_sink_get_negotiated_audio_sample_rate(&g_scmirroring, &sample_rate);
+               if (ret != SCMIRRORING_ERROR_NONE)
+                       g_print("Error : scmirroring_sink_get_negotiated_audio_sample_rate fail[%d]\n", ret);
+               else
+                       g_print("audio sample rate[%d]\n", sample_rate);
+
+       } else if (strncmp(cmd, "7", 1) == 0) {
+               int bitwidth;
+               ret = scmirroring_sink_get_negotiated_audio_bitwidth(&g_scmirroring, &bitwidth);
+               if (ret != SCMIRRORING_ERROR_NONE)
+                       g_print("Error : scmirroring_sink_get_negotiated_audio_bitwidth fail[%d]\n", ret);
+               else
+                       g_print("audio bitwidth[%d]\n", bitwidth);
+
+       } else if (strncmp(cmd, "g", 1) == 0) {
+               g_print("go back to main menu\n");
+               g_menu = MAIN_MENU;
+               g_timeout_add(100, __timeout_menu_display, 0);
+               return;
+       }
+
+       g_timeout_add(100, __timeout_stream_info_submenu_display, 0);
+
+       return;
+}
+
+gboolean __timeout_window_size_submenu_display(void *data)
+{
+       __display_window_size_submenu();
+       return FALSE;
+
+}
+
+static void __display_window_size_submenu(void)
+{
+       g_print("\n");
+       g_print("**********************************************************************\n");
+       g_print("     Setting window size \n");
+       g_print("**********************************************************************\n");
+       g_print("1 : UHD [width:3840, height:2160] \n");
+       g_print("2 : FHD [width:1920, height:1080] \n");
+       g_print("3 : HD  [width:1280, height:720] \n");
+       g_print("g : Go back to main menu \n");
+       g_print("**********************************************************************\n");
+
+}
+
+static void __interpret_window_size_submenu(char *cmd)
+{
+       int w = 0;
+       int h = 0;
+       if (strncmp(cmd, "1", 1) == 0) {
+               w = 3840;
+               h = 2160;
+               elm_win_aux_hint_add(g_evas, "wm.policy.win.user.geometry", "1");
+               evas_object_resize(g_evas, w, h);
+               g_print("Window size is changed.[width:%d, height:%d]", w, h);
+       } else if (strncmp(cmd, "2", 1) == 0) {
+               w = 1920;
+               h = 1080;
+               elm_win_aux_hint_add(g_evas, "wm.policy.win.user.geometry", "1");
+               evas_object_resize(g_evas, w, h);
+               g_print("Window size is changed.[width:%d, height:%d]", w, h);
+       } else if (strncmp(cmd, "3", 1) == 0) {
+               w = 1280;
+               h = 720;
+               elm_win_aux_hint_add(g_evas, "wm.policy.win.user.geometry", "1");
+               evas_object_resize(g_evas, w, h);
+               g_print("Window size is changed.[width:%d, height:%d]", w, h);
+       } else if (strncmp(cmd, "g", 1) == 0) {
+               g_print("go back to main menu\n");
+               g_menu = MAIN_MENU;
+               g_timeout_add(100, __timeout_menu_display, 0);
+               return;
+       }
+
+       g_timeout_add(100, __timeout_window_size_submenu_display, 0);
+       return;
+}
+
+
+static void scmirroring_sink_state_callback(scmirroring_error_e error_code, scmirroring_sink_state_e state, void *user_data)
+{
+       g_print("Received Callback error code[%d]", error_code);
+
+       if (state == SCMIRRORING_SINK_STATE_NONE)
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_NONE\n", state);
+       else if (state == SCMIRRORING_SINK_STATE_NULL)
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_NULL\n", state);
+       else if (state == SCMIRRORING_SINK_STATE_PREPARED)
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_PREPARED\n", state);
+       else if (state == SCMIRRORING_SINK_STATE_CONNECTED) {
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_CONNECTED\n", state);
+       } else if (state == SCMIRRORING_SINK_STATE_PLAYING)
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_PLAYING\n", state);
+       else if (state == SCMIRRORING_SINK_STATE_PAUSED)
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_PAUSED\n", state);
+       else if (state == SCMIRRORING_SINK_STATE_DISCONNECTED) {
+               g_print(" state[%d] SCMIRRORING_SINK_STATE_DISCONNECTED\n", state);
+       } else
+               g_print(" state[%d] Invalid State", state);
+
+       return;
+}
+
+static void __quit_program(void)
+{
+       g_print("Quit Program\n");
+
+#ifdef TEST_WITH_WIFI_DIRECT
+       __disconnect_p2p_connection();
+#endif
+       g_scmirroring = 0;
+       elm_exit();
+}
+
+static void __displaymenu(void)
+{
+       g_print("\n");
+       g_print("=====================================================================\n");
+       g_print("                               SCMIRRORING Sink Testsuite(press q to quit) \n");
+       g_print("=====================================================================\n");
+#ifndef TEST_WITH_WIFI_DIRECT
+       g_print("a : a ip port(ex. a 192.168.49.1 2022)\n");
+       g_print("s : start\n");
+#else
+       g_print("b : Connecting and Starting sink with mac address which you wanna connect src device. (ex. b f8:d0:bd:7f:e9:7c)\n");
+#endif
+       g_print("P : Pause\n");
+       g_print("R : Resume\n");
+       g_print("D : Disconnect\n");
+       g_print("T : desTroy\n");
+       g_print("L : Setting resolution\n");
+       g_print("G : Getting negotiated audio and video information\n");
+       g_print("S : Setting Sink\n");
+       g_print("C : Setting window size\n");
+       g_print("q : quit\n");
+       g_print("-----------------------------------------------------------------------------------------\n");
+}
+
+gboolean __timeout_menu_display(void *data)
+{
+       __displaymenu();
+
+       return FALSE;
+}
+
+#ifdef TEST_WITH_WIFI_DIRECT
+bool _connected_peer_cb(wifi_direct_connected_peer_info_s *peer, void *user_data)
+{
+       int peer_port = 0;
+       if (wifi_direct_get_peer_display_port(peer->mac_address, &peer_port) != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Can not get port info\n Use default(2022)\n");
+               peer_port = DEFAULT_SCREEN_MIRRORING_PORT;
+       }
+       if (peer_port == 0) {
+               g_print("Can not get port info\n Use default(2022)\n");
+               peer_port = DEFAULT_SCREEN_MIRRORING_PORT;
+       }
+
+       g_print("[_connected_peer_cb] Connected to IP [%s]\n", peer->ip_address);
+       g_print("[_connected_peer_cb] Connected to Port [%d]\n", peer_port);
+       g_print("[_connected_peer_cb] Connected device_name [%s]\n", peer->device_name);
+       g_print("[_connected_peer_cb] Connected to mac_address [%s]\n", peer->mac_address);
+       g_print("[_connected_peer_cb] Connected to interface_address [%s]\n", peer->interface_address);
+
+       memset(g_peer_ip, 0x00, sizeof(g_peer_ip));
+       memset(g_peer_port, 0x00, sizeof(g_peer_port));
+
+       snprintf(g_peer_ip, sizeof(g_peer_port), "%s", peer->ip_address);
+       snprintf(g_peer_port, sizeof(g_peer_port), "%d", peer_port);
+
+       g_timeout_add(SINKTEST_EXECUTE_DELAY, __scmirroring_sink_start, NULL);
+
+       return TRUE;
+}
+
+void _activation_cb(int error_code, wifi_direct_device_state_e device_state, void *user_data)
+{
+       gint ret = FALSE;
+       switch (device_state) {
+       case WIFI_DIRECT_DEVICE_STATE_ACTIVATED:
+               g_print("device_state : WIFI_DIRECT_DEVICE_STATE_ACTIVATED\n");
+               ret = __start_wifi_display_connection();
+               if (ret == TRUE) {
+                       g_print("__start_wifi_display_connection success\n");
+               } else {
+                       g_print("__start_wifi_display_connection fail\n");
+                       g_print("Quit Program\n");
+                       ret = wifi_direct_deinitialize();
+                       if (ret != WIFI_DIRECT_ERROR_NONE)
+                               g_print("wifi_direct_deinitialize is failed\n");
+
+                       g_scmirroring = 0;
+                       elm_exit();
+               }
+               break;
+       case WIFI_DIRECT_DEVICE_STATE_DEACTIVATED:
+               g_print("device_state : WIFI_DIRECT_DEVICE_STATE_DEACTIVATED\n");
+               break;
+       default:
+               g_print("device_state : ERROR\n");
+               break;
+       }
+
+       return;
+}
+
+bool _discovered_peer_cb(wifi_direct_discovered_peer_info_s *peer, void *user_data)
+{
+       g_print("[%d] discovered device peer : %s, %s, %d\n", g_peer_cnt, peer->device_name, peer->mac_address, peer->is_connected);
+
+       g_peer_cnt++;
+
+       return TRUE;
+}
+
+void _discover_cb(int error_code, wifi_direct_discovery_state_e discovery_state, void *user_data)
+{
+       int ret = WIFI_DIRECT_ERROR_NONE;
+       /*g_print("Discovered [ error : %d discovery state : %d ]\n", error_code, discovery_state); */
+
+       switch (discovery_state) {
+       case WIFI_DIRECT_ONLY_LISTEN_STARTED:
+               g_print("discovery_state : WIFI_DIRECT_ONLY_LISTEN_STARTED \n");
+               break;
+       case WIFI_DIRECT_DISCOVERY_STARTED:
+               g_print("discovery_state : WIFI_DIRECT_DISCOVERY_STARTED \n");
+               break;
+       case WIFI_DIRECT_DISCOVERY_FOUND:
+               g_print("discovery_state : WIFI_DIRECT_DISCOVERY_FOUND \n");
+               ret = wifi_direct_foreach_discovered_peers(_discovered_peer_cb, (void *)NULL);
+               if (ret != WIFI_DIRECT_ERROR_NONE)
+                       g_print("Error : wifi_direct_foreach_discovered_peers failed : %d\n", ret);
+               break;
+       case WIFI_DIRECT_DISCOVERY_FINISHED:
+               g_print("discovery_state : WIFI_DIRECT_DISCOVERY_FINISHED \n");
+               break;
+       default:
+               g_print("discovery_state : ERROR\n");
+               break;
+       }
+
+       return;
+}
+
+void _ip_assigned_cb(const char *mac_address, const char *ip_address, const char *interface_address, void *user_data)
+{
+       g_print("[_ip_assigned_cb] IP assigned [ ip addr : %s if addr : %s mac_addr:%s ]\n", ip_address, interface_address, mac_address);
+
+       int peer_port = 0;
+       wifi_direct_discovered_peer_info_s *peer_info = NULL;
+
+       if (wifi_direct_get_peer_display_port((char *)mac_address, &peer_port) != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Can not get port info\n Use default(2022)\n");
+               peer_port = DEFAULT_SCREEN_MIRRORING_PORT;
+       }
+       if (peer_port == 0) {
+               g_print("Can not get port info\n Use default(2022)\n");
+               peer_port = DEFAULT_SCREEN_MIRRORING_PORT;
+       }
+       if (wifi_direct_get_peer_info((char *)mac_address, &peer_info) != WIFI_DIRECT_ERROR_NONE)
+               g_print("Can not get peer info and device name\n");
+
+       if (peer_info != NULL && peer_info->device_name != NULL)
+               g_print("[_ip_assigned_cb] Connected to device_name [%s]\n", peer_info->device_name);
+
+       g_print("[_ip_assigned_cb] Connected to IP [%s]\n", ip_address);
+       g_print("[_ip_assigned_cb] Connected to Port [%d]\n", peer_port);
+       g_print("[_ip_assigned_cb] Connected to mac_address [%s]\n", mac_address);
+       g_print("[_ip_assigned_cb] Connected to interface_address [%s]\n", interface_address);
+
+       memset(g_peer_ip, 0x00, sizeof(g_peer_ip));
+       memset(g_peer_port, 0x00, sizeof(g_peer_port));
+
+       snprintf(g_peer_ip, sizeof(g_peer_port), "%s", ip_address);
+       snprintf(g_peer_port, sizeof(g_peer_port), "%d", peer_port);
+
+       g_timeout_add(SINKTEST_EXECUTE_DELAY, __scmirroring_sink_start, NULL);
+}
+
+void _connection_cb(int error_code, wifi_direct_connection_state_e connection_state, const char *mac_address, void *user_data)
+{
+       int ret = WIFI_DIRECT_ERROR_NONE;
+
+       g_print("Connected [ error : %d connection state : %d mac_addr:%s ]\n", error_code, connection_state, mac_address);
+
+       switch (connection_state) {
+       case WIFI_DIRECT_CONNECTION_REQ:
+               g_print("WIFI_DIRECT_CONNECTION_REQ : Connection is requested\n");
+               ret = wifi_direct_accept_connection((char *)mac_address);
+               if (ret != WIFI_DIRECT_ERROR_NONE)
+                       g_print("Error : wifi_direct_accept_connection failed : %d\n", ret);
+               break;
+       case WIFI_DIRECT_CONNECTION_WPS_REQ:
+               g_print("WIFI_DIRECT_CONNECTION_WPS_REQ : WPS is requested\n");
+               break;
+       case WIFI_DIRECT_CONNECTION_IN_PROGRESS:
+               g_print("WIFI_DIRECT_CONNECTION_IN_PROGRESS : Connection in progress\n");
+               break;
+       case WIFI_DIRECT_CONNECTION_RSP:
+       {
+               bool is_go = FALSE;
+               g_print("WIFI_DIRECT_CONNECTION_RSP : Connected\n");
+               ret = wifi_direct_is_group_owner(&is_go);
+               if (ret != WIFI_DIRECT_ERROR_NONE)
+                       g_print("Error : wifi_direct_is_group_owner failed : %d\n", ret);
+
+               if (is_go) {
+                       g_print("Connected as Group Owner\n");
+               } else {
+                       ret = wifi_direct_foreach_connected_peers(_connected_peer_cb, (void *)NULL);
+                       if (ret != WIFI_DIRECT_ERROR_NONE) {
+                               g_print("Error : wifi_direct_foreach_connected_peers failed : %d\n", ret);
+                               return;
+                       }
+                       g_print("Connected as Group Client\n");
+               }
+               break;
+       }
+       case WIFI_DIRECT_DISASSOCIATION_IND:
+               g_print("WIFI_DIRECT_DISASSOCIATION_IND : Disconnected by remote Group Client\n");
+               break;
+       case WIFI_DIRECT_DISCONNECTION_RSP:
+               g_print("WIFI_DIRECT_DISCONNECTION_RSP : Disconnected by local device\n");
+               break;
+       case WIFI_DIRECT_DISCONNECTION_IND:
+               g_print("WIFI_DIRECT_DISCONNECTION_IND : Disconnected by remote Group Owner\n");
+               break;
+       case WIFI_DIRECT_GROUP_CREATED:
+               g_print("WIFI_DIRECT_GROUP_CREATED : Group is created\n");
+               break;
+       case WIFI_DIRECT_GROUP_DESTROYED:
+               g_print("WIFI_DIRECT_GROUP_DESTROYED : Group is destroyed\n");
+               break;
+       default:
+               break;
+       }
+       return;
+}
+
+
+static int __wifi_direct_device_connect()
+{
+       if (strlen(g_src_mac_addr) > 17 || strlen(g_src_mac_addr) <= 0) {
+               g_print("\nWrong Mac_address");
+               return SCMIRRORING_ERROR_INVALID_OPERATION;
+       }
+
+       int err =  wifi_direct_connect(g_src_mac_addr);
+       if (err != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Failed to connect  [%d]\n", err);
+               return SCMIRRORING_ERROR_INVALID_OPERATION;
+       }
+       return SCMIRRORING_ERROR_NONE;
+}
+
+#endif
+
+static void __interpret(char *cmd)
+{
+       int ret = SCMIRRORING_ERROR_NONE;
+
+       if (strncmp(cmd, "D", 1) == 0) {
+               g_print("Disconnect\n");
+               ret = scmirroring_sink_disconnect(g_scmirroring);
+       } else if (strncmp(cmd, "P", 1) == 0) {
+               g_print("Pause\n");
+               ret = scmirroring_sink_pause(g_scmirroring);
+       } else if (strncmp(cmd, "R", 1) == 0) {
+               g_print("Resume\n");
+               ret = scmirroring_sink_resume(g_scmirroring);
+       } else if (strncmp(cmd, "T", 1) == 0) {
+               g_print("Destroy\n");
+               ret = __scmirroring_sink_destroy(g_scmirroring);
+       } else if (strncmp(cmd, "q", 1) == 0) {
+               __quit_program();
+       } else if (strncmp(cmd, "S", 1) == 0) {
+               g_menu = SUBMENU_SETTING_SINK;
+               g_timeout_add(100, __timeout_sink_submenu_display, 0);
+               return;
+       } else if (strncmp(cmd, "L", 1) == 0) {
+               g_menu = SUBMENU_RESOLUTION;
+               g_timeout_add(100, __timeout_resolution_submenu_display, 0);
+               return;
+       } else if (strncmp(cmd, "G", 1) == 0) {
+               g_menu = SUBMENU_GETTING_STREAM_INFO;
+               g_timeout_add(100, __timeout_stream_info_submenu_display, 0);
+               return;
+       } else if (strncmp(cmd, "C", 1) == 0) {
+               g_menu = SUBMENU_SETTING_WINDOW_SIZE;
+               g_timeout_add(100, __timeout_window_size_submenu_display, 0);
+               return;
+       }
+#ifndef TEST_WITH_WIFI_DIRECT
+       else if (strncmp(cmd, "1", 1) == 0) {
+               ret = __scmirroring_sink_create(NULL);
+               if (ret == SCMIRRORING_ERROR_NONE) {
+                       ret = scmirroring_sink_set_ip_and_port(g_scmirroring, "192.168.49.1", "2022");
+                       g_print("Input server IP and port number IP[%s] Port[%s]\n",  "192.168.49.1", "2022");
+               }
+       } else if (strncmp(cmd, "51", 2) == 0) {
+               ret = __scmirroring_sink_create(NULL);
+               if (ret == SCMIRRORING_ERROR_NONE) {
+                       ret = scmirroring_sink_set_ip_and_port(g_scmirroring,  "192.168.49.51", "2022");
+                       g_print("Input server IP and port number IP[%s] Port[%s]\n",  "192.168.49.51", "2022");
+               }
+       } else if (strncmp(cmd, "s", 1) == 0) {
+               g_print("Start\n");
+               ret = __scmirroring_sink_start_only(NULL);
+       } else if (strncmp(cmd, "p", 1) == 0) {
+               g_print("Prepare\n");
+               ret = __scmirroring_sink_prepare(NULL);
+       } else if (strncmp(cmd, "c", 1) == 0) {
+               g_print("Connect\n");
+               ret = __scmirroring_sink_connect(NULL);
+       } else if (strncmp(cmd, "up", 1) == 0) {
+               g_print("Unprepare\n");
+               ret = __scmirroring_sink_unprepare(NULL);
+       }
+#else
+        else if (strncmp(cmd, "b", 1) == 0) {
+               strncpy(g_src_mac_addr, value[1], sizeof(g_src_mac_addr));
+               g_src_mac_addr[17] = '\0';
+               g_print("Src mac address : %s\n", g_src_mac_addr);
+               ret = __wifi_direct_device_connect();
+       }
+#endif
+       else {
+               g_print("unknown menu \n");
+       }
+
+       if (ret != SCMIRRORING_ERROR_NONE)
+               g_print("Error Occured [%d]", ret);
+
+       g_timeout_add(100, __timeout_menu_display, 0);
+
+       return;
+}
+
+gboolean __input(GIOChannel *channel)
+{
+       char buf[MAX_STRING_LEN + 3];
+       gsize read;
+       GError *error = NULL;
+
+       g_io_channel_read_chars(channel, buf, MAX_STRING_LEN, &read, &error);
+       buf[read] = '\0';
+       g_strstrip(buf);
+
+       if (g_menu == MAIN_MENU)
+               __interpret(buf);
+       else if (g_menu == SUBMENU_RESOLUTION)
+               __interpret_resolution_submenu(buf);
+       else if (g_menu == SUBMENU_GETTING_STREAM_INFO)
+               __interpret_stream_info_submenu(buf);
+       else if (g_menu == SUBMENU_SETTING_SINK)
+               __interpret_sink_submenu(buf);
+       else if (g_menu == SUBMENU_SETTING_WINDOW_SIZE)
+               __interpret_window_size_submenu(buf);
+
+       return TRUE;
+}
+
+#ifdef TEST_WITH_WIFI_DIRECT
+static gboolean __start_wifi_display_connection()
+{
+       int go_intent = 0;
+       static int is_initialized = FALSE;
+       wifi_direct_state_e direct_state = WIFI_DIRECT_STATE_DEACTIVATED;
+       gint ret = FALSE;
+
+       if (is_initialized == TRUE)
+               return TRUE;
+       is_initialized = TRUE;
+
+       /*Enable Screen Mirroring*/
+       ret = wifi_direct_init_display();
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_display_init failed : %d\n", ret);
+               return FALSE;
+       }
+
+       /*Enable Wifi Direct - You can set this as true if you want to see it from wifi-direct list*/
+       ret = wifi_direct_set_display_availability(TRUE);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_display_init failed : %d\n", ret);
+               return FALSE;
+       }
+
+       ret = wifi_direct_set_display(WIFI_DISPLAY_TYPE_SINK, 2022, 0);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_display_set_device failed : %d\n", ret);
+               return FALSE;
+       }
+
+       ret = wifi_direct_get_group_owner_intent(&go_intent);
+       g_print("go_intent = [%d]\n", go_intent);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_get_group_owner_intent failed : %d\n", ret);
+               return FALSE;
+       }
+
+       go_intent = 1;
+       ret = wifi_direct_set_group_owner_intent(go_intent);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_get_group_owner_intent failed : %d\n", ret);
+               return FALSE;
+       }
+       g_print("wifi_direct_set_group_owner_intent() result=[%d] go_intent[%d]\n", ret, go_intent);
+
+       ret = wifi_direct_set_max_clients(1);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_set_max_clients failed : %d\n", ret);
+               return FALSE;
+       }
+
+       ret = wifi_direct_get_state(&direct_state);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_get_state failed : %d\n", ret);
+               return FALSE;
+       }
+
+       if (direct_state > WIFI_DIRECT_STATE_ACTIVATING) {
+               char *device_name = NULL;
+
+               ret = wifi_direct_start_discovery(0, 20);
+               if (ret != WIFI_DIRECT_ERROR_NONE) {
+                       g_print("Error : wifi_direct_start_discovery failed : %d\n", ret);
+                       return FALSE;
+               }
+
+               ret = wifi_direct_get_device_name(&device_name);
+               if (ret != WIFI_DIRECT_ERROR_NONE) {
+                       g_print("Error : wifi_direct_get_device_name failed : %d\n", ret);
+                       return FALSE;
+               }
+
+               g_print("Device Name : [%s]\n", device_name);
+               if (device_name)
+                       free(device_name);
+
+       } else {
+               g_print("Error : Direct not activated yet\n");
+       }
+
+       g_print("====== p2p connection established ======\n");
+
+       return TRUE;
+}
+
+
+static gboolean __start_p2p_connection(gpointer data)
+{
+       int ret = WIFI_DIRECT_ERROR_NONE;
+       wifi_direct_state_e direct_state = WIFI_DIRECT_STATE_DEACTIVATED;
+
+       g_print("====== Start p2p connection ======\n");
+
+       ret = wifi_direct_initialize();
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_initialize failed : %d\n", ret);
+               return FALSE;
+       }
+
+       struct ug_data *ugd = (struct ug_data *)data;
+
+       /* Activation / Deactivation state Callback */
+       ret = wifi_direct_set_device_state_changed_cb(_activation_cb, (void *)ugd);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_set_device_state_changed_cb failed : %d\n", ret);
+               goto error;
+       }
+
+       /* Discovery state Callback */
+       ret = wifi_direct_set_discovery_state_changed_cb(_discover_cb, (void *)ugd);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_set_discovery_state_changed_cb failed : %d\n", ret);
+               goto error;
+       }
+
+       /* Connection state Callback */
+       ret = wifi_direct_set_connection_state_changed_cb(_connection_cb, (void *)ugd);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_set_connection_state_changed_cb failed : %d\n", ret);
+               goto error;
+       }
+
+       /* IP address assigning state callback */
+       ret = wifi_direct_set_client_ip_address_assigned_cb(_ip_assigned_cb, (void *)ugd);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_set_client_ip_address_assigned_cb failed : %d\n", ret);
+               goto error;
+       }
+
+       ret = wifi_direct_get_state(&direct_state);
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_get_state failed : %d\n", ret);
+               goto error;
+       }
+
+       if (direct_state < WIFI_DIRECT_STATE_ACTIVATED) {
+               g_print("wifi direct status < WIFI_DIRECT_STATE_ACTIVATED\n");
+               g_print("\n------Starting to activate scmirroring------\n");
+               ret = wifi_direct_activate();
+               if (ret < WIFI_DIRECT_ERROR_NONE) {
+                       g_print("Error : wifi_direct_activate failed : %d\n", ret);
+                       return FALSE;
+               }
+       } else {
+               g_print("wifi direct status >= WIFI_DIRECT_STATE_ACTIVATED.. Disconnect all first\n");
+               ret = wifi_direct_disconnect_all();
+               if (!ret)
+                       g_print("wifi_direct_disconnect_all success\n");
+               else
+                       g_print("wifi_direct_disconnect_all fail\n");
+
+               ret = __start_wifi_display_connection();
+               if (ret == TRUE) {
+                       g_print("__start_wifi_display_connection success\n");
+               } else {
+                       g_print("__start_wifi_display_connection fail\n");
+                       goto error;
+               }
+       }
+
+       return TRUE;
+
+error:
+       ret = wifi_direct_deinitialize();
+
+       return FALSE;
+}
+
+static gboolean __disconnect_p2p_connection(void)
+{
+       int ret = WIFI_DIRECT_ERROR_NONE;
+
+       ret = wifi_direct_deactivate();
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_deactivate failed : %d\n", ret);
+               return FALSE;
+       }
+
+       ret = wifi_direct_deinitialize();
+       if (ret != WIFI_DIRECT_ERROR_NONE) {
+               g_print("Error : wifi_direct_deinitialize failed : %d\n", ret);
+               return FALSE;
+       }
+
+       g_print("------p2p connection disconnected------\n");
+
+       return TRUE;
+}
+#endif
+
+#ifndef TEST_WITH_WIFI_DIRECT
+static int __scmirroring_sink_create(gpointer data)
+{
+       int ret = SCMIRRORING_ERROR_NONE;
+
+       ret = scmirroring_sink_create(&g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_create fail [%d]", ret);
+               return SCMIRRORING_ERROR_INVALID_OPERATION;
+       }
+
+       if (g_sinktype != -1) {
+               if (g_sinktype == SCMIRRORING_DISPLAY_TYPE_OVERLAY) {
+                       evas_object_show(g_evas);
+                       ret = scmirroring_sink_set_display(g_scmirroring, SCMIRRORING_DISPLAY_TYPE_OVERLAY, (void *)g_evas);
+               } else if (g_sinktype == SCMIRRORING_DISPLAY_TYPE_EVAS) {
+                       g_eo = create_evas_image_object(g_evas);
+                       evas_object_image_size_set(g_eo, 800, 1200);
+                       evas_object_image_fill_set(g_eo, 0, 0, 800, 1200);
+                       evas_object_resize(g_eo, 800, 1200);
+                       evas_object_show(g_evas);
+                       ret = scmirroring_sink_set_display(g_scmirroring, SCMIRRORING_DISPLAY_TYPE_EVAS, (void *)g_eo);
+               }
+
+               if (ret != SCMIRRORING_ERROR_NONE) {
+                       g_print("scmirroring_sink_set_display fail [%d]", ret);
+                       return FALSE;
+               }
+       }
+       return ret;
+}
+
+
+static int __scmirroring_sink_prepare(gpointer data)
+{
+
+       int ret = SCMIRRORING_ERROR_NONE;
+       ret = scmirroring_sink_prepare(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_prepare fail [%d]", ret);
+               return SCMIRRORING_ERROR_INVALID_OPERATION;
+       }
+       return ret;
+
+}
+static int __scmirroring_sink_connect(gpointer data)
+{
+       int ret =  SCMIRRORING_ERROR_NONE;
+       ret = scmirroring_sink_set_state_changed_cb(g_scmirroring, scmirroring_sink_state_callback, NULL);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_set_state_changed_cb fail [%d]", ret);
+               return FALSE;
+       }
+
+       ret = scmirroring_sink_connect(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_connect fail [%d]", ret);
+               return FALSE;
+       }
+       return ret;
+}
+
+static int __scmirroring_sink_unprepare(gpointer data)
+{
+       int ret =  SCMIRRORING_ERROR_NONE;
+       ret = scmirroring_sink_unprepare(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_unprepare fail [%d]", ret);
+               return FALSE;
+       }
+       return ret;
+}
+static int __scmirroring_sink_destroy(gpointer data)
+{
+       int ret =  SCMIRRORING_ERROR_NONE;
+       ret = scmirroring_sink_destroy(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_destroy fail [%d]", ret);
+               return FALSE;
+       }
+       return ret;
+}
+
+
+/*
+ * '__scmirroring_sink_start_only' has only 'scmirroring_sink_start' api for individual execution.
+ */
+gboolean __scmirroring_sink_start_only(gpointer data)
+{
+       int ret = SCMIRRORING_ERROR_NONE;
+       ret = scmirroring_sink_start(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_start fail [%d]", ret);
+               return FALSE;
+       }
+       return FALSE;
+}
+
+#endif
+
+
+/*
+ * '__scmirroring_sink_start_in_order' execute all APIs in order which is necessary for executing screen mirroring.
+ */
+gboolean __scmirroring_sink_start(gpointer data)
+{
+       int ret = SCMIRRORING_ERROR_NONE;
+       g_print("__scmirroring_sink_start <enter>\n");
+
+#ifdef TEST_WITH_WIFI_DIRECT
+       ret = scmirroring_sink_create(&g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_create fail [%d]", ret);
+               return FALSE;
+       }
+
+       if (g_resolution != 0) {
+               ret = scmirroring_sink_set_resolution(g_scmirroring, g_resolution);
+               if (ret != SCMIRRORING_ERROR_NONE)
+                       g_print("Failed to set resolution, error[%d]\n", ret);
+       }
+
+       if (g_sinktype != -1) {
+
+               if (g_sinktype == SCMIRRORING_DISPLAY_TYPE_OVERLAY) {
+                       evas_object_show(g_evas);
+                       ret = scmirroring_sink_set_display(g_scmirroring, SCMIRRORING_DISPLAY_TYPE_OVERLAY, (void *)g_evas);
+               } else if (g_sinktype == SCMIRRORING_DISPLAY_TYPE_EVAS) {
+                       g_eo = create_evas_image_object(g_evas);
+                       evas_object_image_size_set(g_eo, 800, 1200);
+                       evas_object_image_fill_set(g_eo, 0, 0, 800, 1200);
+                       evas_object_resize(g_eo, 800, 1200);
+                       evas_object_show(g_evas);
+                       ret = scmirroring_sink_set_display(g_scmirroring, SCMIRRORING_DISPLAY_TYPE_EVAS, (void *)g_eo);
+               }
+
+               if (ret != SCMIRRORING_ERROR_NONE) {
+                       g_print("scmirroring_sink_set_display fail [%d]", ret);
+                       return FALSE;
+               }
+       }
+
+       ret = scmirroring_sink_prepare(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_prepare fail [%d]", ret);
+               return FALSE;
+       }
+
+       ret = scmirroring_sink_set_ip_and_port(g_scmirroring, g_peer_ip, g_peer_port);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_set_ip_and_port fail [%d]", ret);
+               return FALSE;
+       }
+
+       g_print("Input server IP and port number IP[%s] Port[%s]\n", g_peer_ip, g_peer_port);
+#endif
+
+       ret = scmirroring_sink_set_state_changed_cb(g_scmirroring, scmirroring_sink_state_callback, NULL);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_set_state_changed_cb fail [%d]", ret);
+               return FALSE;
+       }
+
+       ret = scmirroring_sink_connect(g_scmirroring);
+       if (ret != SCMIRRORING_ERROR_NONE) {
+               g_print("scmirroring_sink_connect fail [%d]", ret);
+               return FALSE;
+       }
+
+       g_print("__scmirroring_sink_start <leave>\n");
+       return FALSE;
+}
+
+gboolean _scmirroring_start_jobs(gpointer data)
+{
+#ifdef TEST_WITH_WIFI_DIRECT
+       int ret = WIFI_DIRECT_ERROR_NONE;
+
+       ret = __start_p2p_connection(data);
+       if (ret == FALSE)
+               return FALSE;
+#endif
+
+       return TRUE;
+}
+
+int main(int argc, char *argv[])
+{
+       GIOChannel *stdin_channel;
+
+       stdin_channel = g_io_channel_unix_new(0);
+       g_io_channel_set_flags(stdin_channel, G_IO_FLAG_NONBLOCK, NULL);
+       g_io_add_watch(stdin_channel, G_IO_IN, (GIOFunc)__input, NULL);
+
+       __displaymenu();
+
+       ops.data = NULL;
+       appcore_efl_main(PACKAGE, &argc, &argv, &ops);
+
+       return 0;
+}