1 /**************************************************************************
3 * Copyright 2017 Samsung Electronics co., Ltd. All Rights Reserved.
5 * Contact: Konstantin Drabeniuk <k.drabeniuk@samsung.com>
6 * Contact: Andrii Sokolenko <a.sokolenko@samsung.com>
7 * Contact: Roman Marchenko <r.marchenko@samsung.com>
8 * Contact: Sergey Sizonov <s.sizonov@samsung.com>
10 * Permission is hereby granted, free of charge, to any person obtaining a
11 * copy of this software and associated documentation files (the
12 * "Software"), to deal in the Software without restriction, including
13 * without limitation the rights to use, copy, modify, merge, publish,
14 * distribute, sub license, and/or sell copies of the Software, and to
15 * permit persons to whom the Software is furnished to do so, subject to
16 * the following conditions:
18 * The above copyright notice and this permission notice (including the
19 * next paragraph) shall be included in all copies or substantial portions
22 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
23 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
25 * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
26 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
27 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
28 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 **************************************************************************/
34 #include <sys/signalfd.h>
36 #include <sys/prctl.h>
39 #include "tdm_client.h"
45 TDM_UT_PIPE_MSG_REPLY,
46 TDM_UT_PIPE_MSG_SERVER_READY,
47 TDM_UT_PIPE_MSG_SERVER_FAILED,
48 TDM_UT_PIPE_MSG_DPMS_ON,
49 TDM_UT_PIPE_MSG_DPMS_OFF,
50 TDM_UT_PIPE_MSG_TERMINATE_SERVER,
53 #define TDM_UT_WAIT(fmt, ...) \
57 printf(fmt" [n]):next ", ##__VA_ARGS__); \
58 ch = tc_tdm_getchar(); \
62 static int _tc_tdm_pipe_read_msg(int fd);
63 static bool _tc_tdm_pipe_write_msg(int fd, int reply_fd, int msg);
64 static pid_t _tc_tdm_client_server_fork(int *pipe_to_parent, int *pipe_to_child);
66 class TDMClient : public TDMEnv
69 static pid_t server_pid;
71 /* 0: read, 1: write */
72 static int pipe_parent[2];
73 static int pipe_child[2];
76 tdm_client_output *output;
77 tdm_client_vblank *vblank;
78 tdm_client_voutput *voutput;
80 double vrefresh_interval, start, end;
86 bool PrepareClient(void);
87 bool PrepareOutput(void);
88 bool PrepareVblank(void);
90 static void TearDownTestCase(void);
91 static void ServerFork(void);
92 static void ServerKill(void);
95 pid_t TDMClient::server_pid = -1;
96 int TDMClient::pipe_parent[2] = {-1, -1};
97 int TDMClient::pipe_child[2] = {-1, -1};
99 void TDMClient::TearDownTestCase(void)
104 void TDMClient::ServerFork(void)
109 server_pid = _tc_tdm_client_server_fork(pipe_parent, pipe_child);
110 ASSERT_GT(server_pid, 0);
113 void TDMClient::ServerKill(void)
115 if (pipe_child[0] >= 0)
116 close(pipe_child[0]);
117 if (pipe_child[1] >= 0) {
118 if (server_pid > 0) {
119 bool ret = _tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_TERMINATE_SERVER);
121 if (waitpid(server_pid, NULL, 0) == server_pid)
122 TDM_INFO("*** server terminated ***");
124 TDM_ERR("*** failed to terminate server ***");
126 if (kill(server_pid, 9) < 0)
127 TDM_ERR("*** failed to kill server ***");
130 close(pipe_child[1]);
133 if (pipe_parent[0] >= 0)
134 close(pipe_parent[0]);
135 if (pipe_parent[1] >= 0)
136 close(pipe_parent[1]);
139 pipe_parent[0] = pipe_parent[1] = -1;
140 pipe_child[0] = pipe_child[1] = -1;
143 TDMClient::TDMClient()
148 vrefresh_interval = start = end = 0.0;
151 void TDMClient::SetUp(void)
155 if (server_pid == -1)
159 void TDMClient::TearDown(void)
162 tdm_client_vblank_destroy(vblank);
164 tdm_client_destroy(client);
169 bool TDMClient::PrepareClient(void)
172 client = tdm_client_create(&ret);
173 TDM_UT_RETURN_FALSE_IF_FAIL(ret == TDM_ERROR_NONE);
174 TDM_UT_RETURN_FALSE_IF_FAIL(client != NULL);
179 bool TDMClient::PrepareOutput(void)
183 TDM_UT_RETURN_FALSE_IF_FAIL(client != NULL);
185 output = tdm_client_get_output(client, NULL, &ret);
186 TDM_UT_RETURN_FALSE_IF_FAIL(ret == TDM_ERROR_NONE);
187 TDM_UT_RETURN_FALSE_IF_FAIL(output != NULL);
192 bool TDMClient::PrepareVblank(void)
195 unsigned int refresh;
197 TDM_UT_RETURN_FALSE_IF_FAIL(output != NULL);
199 vblank = tdm_client_output_create_vblank(output, &ret);
200 TDM_UT_RETURN_FALSE_IF_FAIL(ret == TDM_ERROR_NONE);
201 TDM_UT_RETURN_FALSE_IF_FAIL(vblank != NULL);
203 TDM_UT_RETURN_FALSE_IF_FAIL(tdm_client_output_get_refresh_rate(output, &refresh) == TDM_ERROR_NONE);
204 TDM_UT_RETURN_FALSE_IF_FAIL(refresh > 0);
206 vrefresh_interval = 1.0 / (double)refresh;
207 TDM_UT_RETURN_FALSE_IF_FAIL(vrefresh_interval > 0);
218 if (ch == '\n' || ch == '\r')
223 while (c != '\n' && c != EOF)
230 _tc_tdm_pipe_read_msg(int fd)
236 len = read(fd, &msg, sizeof msg);
237 } while (len < 0 && errno == EINTR);
240 msg = TDM_UT_PIPE_MSG_NONE;
246 _tc_tdm_pipe_write_msg(int fd, int reply_fd, int msg)
248 ssize_t len = write(fd, &msg, sizeof msg);
249 TDM_UT_RETURN_FALSE_IF_FAIL(len == sizeof msg);
252 int reply = _tc_tdm_pipe_read_msg(reply_fd);
253 TDM_UT_RETURN_FALSE_IF_FAIL(reply == TDM_UT_PIPE_MSG_REPLY);
260 _tc_tdm_server_set_output_dpms(tdm_display *dpy, int msg)
264 tdm_output_dpms dpms;
266 output = tdm_display_find_output(dpy, "primary", &ret);
267 TDM_UT_RETURN_FALSE_IF_FAIL(ret == TDM_ERROR_NONE);
268 TDM_UT_RETURN_FALSE_IF_FAIL(output != NULL);
270 TDM_UT_RETURN_FALSE_IF_FAIL(tdm_output_get_dpms(output, &dpms) == TDM_ERROR_NONE);
273 case TDM_UT_PIPE_MSG_DPMS_ON:
274 if (dpms != TDM_OUTPUT_DPMS_ON)
275 TDM_UT_RETURN_FALSE_IF_FAIL(tdm_output_set_dpms(output, TDM_OUTPUT_DPMS_ON) == TDM_ERROR_NONE);
277 case TDM_UT_PIPE_MSG_DPMS_OFF:
278 if (dpms != TDM_OUTPUT_DPMS_OFF)
279 TDM_UT_RETURN_FALSE_IF_FAIL(tdm_output_set_dpms(output, TDM_OUTPUT_DPMS_OFF) == TDM_ERROR_NONE);
289 _tc_tdm_server_run(int *pipe_parent, int *pipe_child)
291 tdm_display *dpy = NULL;
293 struct pollfd fds[2];
295 int output_count = 0;
297 dpy = tdm_display_init(&ret);
298 TDM_UT_GOTO_IF_FAIL(ret == TDM_ERROR_NONE, failed);
299 TDM_UT_GOTO_IF_FAIL(dpy != NULL, failed);
301 TDM_UT_GOTO_IF_FAIL(tdm_display_get_output_count(dpy, &output_count) == TDM_ERROR_NONE, failed);
303 for (int o = 0; o < output_count; o++) {
304 tdm_output *output = tdm_display_get_output(dpy, o, &ret);
305 TDM_UT_GOTO_IF_FAIL(ret == TDM_ERROR_NONE, failed);
306 TDM_UT_GOTO_IF_FAIL(output != NULL, failed);
308 if (!tc_tdm_output_is_connected(output))
311 TDM_UT_GOTO_IF_FAIL(tc_tdm_output_prepare(dpy, output, true) == true, failed);
314 TDM_UT_GOTO_IF_FAIL(_tc_tdm_pipe_write_msg(pipe_parent[1], -1, TDM_UT_PIPE_MSG_SERVER_READY) == true, done);
316 TDM_INFO("*** server ready ***");
318 ret = tdm_display_get_fd(dpy, &tdm_fd);
319 TDM_UT_GOTO_IF_FAIL(ret == TDM_ERROR_NONE, done);
321 fds[0].events = POLLIN;
325 fds[1].events = POLLIN;
326 fds[1].fd = pipe_child[0];
330 /* make sure all events are flushed to clients before falling in sleep */
331 tdm_display_flush(dpy);
333 err = poll(fds, 2, -1);
335 if (errno == EINTR || errno == EAGAIN) {
338 TDM_ERR("server-process: poll failed: %m\n");
343 if (fds[0].revents & POLLIN)
344 ret = tc_tdm_display_handle_events(dpy);
346 if (fds[1].revents & POLLIN) {
347 int msg = _tc_tdm_pipe_read_msg(pipe_child[0]);
348 _tc_tdm_pipe_write_msg(pipe_parent[1], -1, TDM_UT_PIPE_MSG_REPLY);
351 case TDM_UT_PIPE_MSG_DPMS_ON:
352 case TDM_UT_PIPE_MSG_DPMS_OFF:
353 _tc_tdm_server_set_output_dpms(dpy, msg);
355 case TDM_UT_PIPE_MSG_TERMINATE_SERVER:
365 tdm_display_deinit(dpy);
369 TDM_UT_GOTO_IF_FAIL(_tc_tdm_pipe_write_msg(pipe_parent[1], -1, TDM_UT_PIPE_MSG_SERVER_FAILED) == true, done);
370 TDM_INFO("*** server failed ***");
373 tdm_display_deinit(dpy);
378 static void _tc_tdm_client_sig_handler(int sig)
380 TDM_UT_ERR("got signal: %d", sig);
381 kill(TDMClient::server_pid, 9);
386 _tc_tdm_client_server_fork(int *pipe_parent, int *pipe_child)
391 TDM_UT_GOTO_IF_FAIL(pipe(pipe_parent) == 0, failed);
392 TDM_UT_GOTO_IF_FAIL(pipe(pipe_child) == 0, failed);
394 signal(SIGCHLD, SIG_IGN);
395 signal(SIGSEGV, _tc_tdm_client_sig_handler);
397 prctl(PR_SET_PDEATHSIG, SIGHUP);
400 TDM_UT_GOTO_IF_FAIL(pid >= 0, failed);
403 _tc_tdm_server_run(pipe_parent, pipe_child);
404 close(pipe_child[0]);
405 close(pipe_child[1]);
406 close(pipe_parent[0]);
407 close(pipe_parent[1]);
409 #ifdef TIZEN_TEST_GCOV
416 msg = _tc_tdm_pipe_read_msg(pipe_parent[0]);
417 TDM_UT_GOTO_IF_FAIL(msg == TDM_UT_PIPE_MSG_SERVER_READY, failed);
419 TDM_INFO("*** server fork done ***");
427 TEST_P(TDMClient, ClientCreate)
431 client = tdm_client_create(&ret);
432 ASSERT_EQ(ret, TDM_ERROR_NONE);
433 ASSERT_NE(client, NULL);
436 TEST_P(TDMClient, ClientCreateNullOther)
438 client = tdm_client_create(NULL);
439 ASSERT_NE(client, NULL);
442 TEST_P(TDMClient, ClientDestroy)
446 client = tdm_client_create(&ret);
447 ASSERT_EQ(ret, TDM_ERROR_NONE);
448 ASSERT_NE(client, NULL);
450 tdm_client_destroy(client);
454 TEST_P(TDMClient, ClientNullObject)
456 tdm_client_destroy(NULL);
459 /* tdm_client_get_fd */
460 TEST_P(TDMClient, ClientGetFd)
462 int fd = TDM_UT_INVALID_VALUE;
464 ASSERT_EQ(PrepareClient(), true);
466 ASSERT_EQ(tdm_client_get_fd(client, &fd), TDM_ERROR_NONE);
470 TEST_P(TDMClient, ClientGetFdNullObject)
472 int fd = TDM_UT_INVALID_VALUE;
473 ASSERT_EQ(tdm_client_get_fd(NULL, &fd), TDM_ERROR_INVALID_PARAMETER);
474 ASSERT_EQ(fd, TDM_UT_INVALID_VALUE);
477 TEST_P(TDMClient, ClientGetFdNullOther)
479 ASSERT_EQ(PrepareClient(), true);
481 ASSERT_EQ(tdm_client_get_fd(client, NULL), TDM_ERROR_INVALID_PARAMETER);
485 _tc_tdm_client_vblank_cb(unsigned int sequence, unsigned int tv_sec, unsigned int tv_usec, void *user_data)
487 bool *done = (bool *)user_data;
492 /* tdm_client_handle_events_timeout */
493 TEST_P(TDMClient, ClientHandleEvent)
497 ASSERT_EQ(PrepareClient(), true);
499 ASSERT_EQ(tdm_client_wait_vblank(client, NULL, 1, 1, 0, _tc_tdm_client_vblank_cb, &done), TDM_ERROR_NONE);
500 ASSERT_EQ(done, false);
503 ASSERT_EQ(tdm_client_handle_events(client), TDM_ERROR_NONE);
506 TEST_P(TDMClient, ClientHandleEventNullObject)
508 ASSERT_EQ(tdm_client_handle_events(NULL), TDM_ERROR_INVALID_PARAMETER);
511 /* tdm_client_wait_vblank, deprecated */
512 TEST_P(TDMClient, ClientWaitVblank)
516 ASSERT_EQ(PrepareClient(), true);
518 ASSERT_EQ(tdm_client_wait_vblank(client, NULL, 1, 1, 0, _tc_tdm_client_vblank_cb, &done), TDM_ERROR_NONE);
519 ASSERT_EQ(done, false);
522 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
525 /* tdm_client_get_output */
526 TEST_P(TDMClient, ClientGetOutput)
530 ASSERT_EQ(PrepareClient(), true);
532 output = tdm_client_get_output(client, NULL, &ret);
533 ASSERT_EQ(ret, TDM_ERROR_NONE);
534 ASSERT_NE(output, NULL);
537 TEST_P(TDMClient, ClientGetOutputPrimary)
541 ASSERT_EQ(PrepareClient(), true);
543 output = tdm_client_get_output(client, (char*)"primary", &ret);
544 ASSERT_EQ(ret, TDM_ERROR_NONE);
545 ASSERT_NE(output, NULL);
548 TEST_P(TDMClient, ClientGetOutputDefault)
552 ASSERT_EQ(PrepareClient(), true);
554 output = tdm_client_get_output(client, (char*)"default", &ret);
555 ASSERT_EQ(ret, TDM_ERROR_NONE);
556 ASSERT_NE(output, NULL);
559 TEST_P(TDMClient, ClientGetOutputInvalidName)
563 ASSERT_EQ(PrepareClient(), true);
565 output = tdm_client_get_output(client, (char*)"invalid", &ret);
566 ASSERT_EQ(ret, TDM_ERROR_INVALID_PARAMETER);
567 ASSERT_EQ(output, NULL);
570 TEST_P(TDMClient, ClientGetOutputNullObject)
574 output = tdm_client_get_output(NULL, NULL, &ret);
575 ASSERT_EQ(ret, TDM_ERROR_INVALID_PARAMETER);
576 ASSERT_EQ(output, NULL);
579 TEST_P(TDMClient, ClientGetOutputNullOther)
581 ASSERT_EQ(PrepareClient(), true);
583 output = tdm_client_get_output(client, NULL, NULL);
584 ASSERT_NE(output, NULL);
588 _tc_tdm_client_output_change_dpms_cb(tdm_client_output *output,
589 tdm_output_change_type type,
593 bool *done = (bool *)user_data;
596 case TDM_OUTPUT_CHANGE_DPMS:
605 /* tdm_client_output_add_change_handler */
606 TEST_P(TDMClient, ClientOutputAddChangeHandler)
609 tdm_output_dpms dpms;
611 ASSERT_EQ(PrepareClient(), true);
612 ASSERT_EQ(PrepareOutput(), true);
614 ASSERT_EQ(tdm_client_output_add_change_handler(output, _tc_tdm_client_output_change_dpms_cb, &done), TDM_ERROR_NONE);
615 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_OFF), true);
618 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
620 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
621 ASSERT_EQ(dpms, TDM_OUTPUT_DPMS_OFF);
623 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_ON), true);
624 while (dpms != TDM_OUTPUT_DPMS_ON) {
625 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
626 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
630 TEST_P(TDMClient, ClientOutputAddChangeHandlerTwice)
632 ASSERT_EQ(PrepareClient(), true);
633 ASSERT_EQ(PrepareOutput(), true);
635 ASSERT_EQ(tdm_client_output_add_change_handler(output, _tc_tdm_client_output_change_dpms_cb, NULL), TDM_ERROR_NONE);
636 ASSERT_EQ(tdm_client_output_add_change_handler(output, _tc_tdm_client_output_change_dpms_cb, NULL), TDM_ERROR_BAD_REQUEST);
639 TEST_P(TDMClient, ClientOutputAddChangeHandlerNullObject)
641 ASSERT_EQ(tdm_client_output_add_change_handler(NULL, _tc_tdm_client_output_change_dpms_cb, NULL), TDM_ERROR_INVALID_PARAMETER);
644 TEST_P(TDMClient, ClientOutputAddChangeHandlerNullOther)
646 ASSERT_EQ(PrepareClient(), true);
647 ASSERT_EQ(PrepareOutput(), true);
649 ASSERT_EQ(tdm_client_output_add_change_handler(output, NULL, NULL), TDM_ERROR_INVALID_PARAMETER);
652 /* tdm_client_output_remove_change_handler */
653 TEST_P(TDMClient, ClientOutputRemoveChangeHandler)
655 ASSERT_EQ(PrepareClient(), true);
656 ASSERT_EQ(PrepareOutput(), true);
658 ASSERT_EQ(tdm_client_output_add_change_handler(output, _tc_tdm_client_output_change_dpms_cb, NULL), TDM_ERROR_NONE);
659 tdm_client_output_remove_change_handler(output, _tc_tdm_client_output_change_dpms_cb, NULL);
662 TEST_P(TDMClient, ClientOutputRemoveChangeHandlerDifferentData)
664 bool done = (bool)TDM_UT_INVALID_VALUE;
666 ASSERT_EQ(PrepareClient(), true);
667 ASSERT_EQ(PrepareOutput(), true);
669 ASSERT_EQ(tdm_client_output_add_change_handler(output, _tc_tdm_client_output_change_dpms_cb, &done), TDM_ERROR_NONE);
670 tdm_client_output_remove_change_handler(output, _tc_tdm_client_output_change_dpms_cb, NULL);
674 _tc_tdm_client_output_change_dpms_cb2(tdm_client_output *output,
675 tdm_output_change_type type,
680 case TDM_OUTPUT_CHANGE_DPMS:
681 tdm_client_output_remove_change_handler(output, _tc_tdm_client_output_change_dpms_cb2, user_data);
688 TEST_P(TDMClient, ClientOutputRemoveChangeHandlerInHandler)
690 tdm_output_dpms dpms = TDM_OUTPUT_DPMS_ON;
692 ASSERT_EQ(PrepareClient(), true);
693 ASSERT_EQ(PrepareOutput(), true);
695 ASSERT_EQ(tdm_client_output_add_change_handler(output, _tc_tdm_client_output_change_dpms_cb2, NULL), TDM_ERROR_NONE);
696 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_OFF), true);
697 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
698 while (dpms != TDM_OUTPUT_DPMS_OFF) {
699 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
700 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
703 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_ON), true);
704 while (dpms != TDM_OUTPUT_DPMS_ON)
705 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
708 TEST_P(TDMClient, ClientOutputRemoveChangeHandlerNullObject)
710 tdm_client_output_remove_change_handler(NULL, _tc_tdm_client_output_change_dpms_cb, NULL);
713 TEST_P(TDMClient, ClientOutputRemoveChangeHandlerNullOther)
715 ASSERT_EQ(PrepareClient(), true);
716 ASSERT_EQ(PrepareOutput(), true);
718 tdm_client_output_remove_change_handler(output, NULL, NULL);
721 /* tdm_client_output_get_refresh_rate */
722 TEST_P(TDMClient, ClientOutputGetRefreshRate)
724 unsigned int refresh = 0;
726 ASSERT_EQ(PrepareClient(), true);
727 ASSERT_EQ(PrepareOutput(), true);
729 ASSERT_EQ(tdm_client_output_get_refresh_rate(output, &refresh), TDM_ERROR_NONE);
730 ASSERT_GT(refresh, 0);
733 TEST_P(TDMClient, ClientOutputGetRefreshRateNullObject)
735 unsigned int refresh = (unsigned int)TDM_UT_INVALID_VALUE;
737 ASSERT_EQ(tdm_client_output_get_refresh_rate(NULL, &refresh), TDM_ERROR_INVALID_PARAMETER);
738 ASSERT_EQ(refresh, (unsigned int)TDM_UT_INVALID_VALUE);
741 TEST_P(TDMClient, ClientOutputGetRefreshRateNullOther)
743 ASSERT_EQ(PrepareClient(), true);
744 ASSERT_EQ(PrepareOutput(), true);
746 ASSERT_EQ(tdm_client_output_get_refresh_rate(output, NULL), TDM_ERROR_INVALID_PARAMETER);
749 /* tdm_client_output_get_refresh_rate */
750 TEST_P(TDMClient, ClientOutputGetConnStatus)
752 tdm_output_conn_status status = (tdm_output_conn_status)TDM_UT_INVALID_VALUE;
754 ASSERT_EQ(PrepareClient(), true);
755 ASSERT_EQ(PrepareOutput(), true);
757 ASSERT_EQ(tdm_client_output_get_conn_status(output, &status), TDM_ERROR_NONE);
758 ASSERT_NE(status, (tdm_output_conn_status)TDM_UT_INVALID_VALUE);
761 TEST_P(TDMClient, ClientOutputGetConnStatusNullObject)
763 tdm_output_conn_status status = (tdm_output_conn_status)TDM_UT_INVALID_VALUE;
765 ASSERT_EQ(tdm_client_output_get_conn_status(NULL, &status), TDM_ERROR_INVALID_PARAMETER);
766 ASSERT_EQ(status, (tdm_output_conn_status)TDM_UT_INVALID_VALUE);
769 TEST_P(TDMClient, ClientOutputGetConnStatusNullOther)
771 ASSERT_EQ(PrepareClient(), true);
772 ASSERT_EQ(PrepareOutput(), true);
774 ASSERT_EQ(tdm_client_output_get_conn_status(output, NULL), TDM_ERROR_INVALID_PARAMETER);
777 /* tdm_client_output_get_dpms */
778 TEST_P(TDMClient, ClientOutputGetDpms)
780 tdm_output_dpms dpms = (tdm_output_dpms)TDM_UT_INVALID_VALUE;
782 ASSERT_EQ(PrepareClient(), true);
783 ASSERT_EQ(PrepareOutput(), true);
785 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
786 ASSERT_NE(dpms, (tdm_output_dpms)TDM_UT_INVALID_VALUE);
789 TEST_P(TDMClient, ClientOutputGetDpmsNullObject)
791 tdm_output_dpms dpms = (tdm_output_dpms)TDM_UT_INVALID_VALUE;
793 ASSERT_EQ(tdm_client_output_get_dpms(NULL, &dpms), TDM_ERROR_INVALID_PARAMETER);
794 ASSERT_EQ(dpms, (tdm_output_dpms)TDM_UT_INVALID_VALUE);
797 TEST_P(TDMClient, ClientOutputGetDpmsNullOther)
799 ASSERT_EQ(PrepareClient(), true);
800 ASSERT_EQ(PrepareOutput(), true);
802 ASSERT_EQ(tdm_client_output_get_dpms(output, NULL), TDM_ERROR_INVALID_PARAMETER);
805 TEST_P(TDMClient, ClientOutputGetAvailableModes)
807 tdm_client_output_mode *modes;
810 ASSERT_EQ(PrepareClient(), true);
811 ASSERT_EQ(PrepareOutput(), true);
813 ASSERT_EQ(tdm_client_output_get_available_modes(output, &modes, &count), TDM_ERROR_NONE);
816 for (i = 0; i < count; i++) {
817 tdm_client_output_mode *mode = (tdm_client_output_mode *)&modes[i];
818 ASSERT_GT(mode->hdisplay, 0);
819 ASSERT_GT(mode->vdisplay, 0);
820 ASSERT_GT(mode->vrefresh, 0);
824 TEST_P(TDMClient, ClientOutputGetAvailableModesNullObject)
826 tdm_client_output_mode *modes;
827 int count = TDM_UT_INVALID_VALUE;
829 ASSERT_EQ(PrepareClient(), true);
830 ASSERT_EQ(PrepareOutput(), true);
832 ASSERT_EQ(tdm_client_output_get_available_modes(NULL, &modes, &count), TDM_ERROR_INVALID_PARAMETER);
833 ASSERT_EQ(count, TDM_UT_INVALID_VALUE);
836 TEST_P(TDMClient, ClientOutputGetAvailableModesNullOther)
838 ASSERT_EQ(PrepareClient(), true);
839 ASSERT_EQ(PrepareOutput(), true);
841 ASSERT_EQ(tdm_client_output_get_available_modes(output, NULL, NULL), TDM_ERROR_INVALID_PARAMETER);
844 /* tdm_client_output_create_vblank */
845 TEST_P(TDMClient, ClientOutputCreateVblank)
849 ASSERT_EQ(PrepareClient(), true);
850 ASSERT_EQ(PrepareOutput(), true);
852 vblank = tdm_client_output_create_vblank(output, &ret);
853 ASSERT_EQ(ret, TDM_ERROR_NONE);
854 ASSERT_NE(vblank, NULL);
857 TEST_P(TDMClient, ClientOutputCreateVblankNullObject)
861 vblank = tdm_client_output_create_vblank(NULL, &ret);
862 ASSERT_EQ(ret, TDM_ERROR_INVALID_PARAMETER);
863 ASSERT_EQ(vblank, NULL);
866 TEST_P(TDMClient, ClientOutputCreateVblankNullOther)
868 ASSERT_EQ(PrepareClient(), true);
869 ASSERT_EQ(PrepareOutput(), true);
871 vblank = tdm_client_output_create_vblank(output, NULL);
872 ASSERT_NE(vblank, NULL);
875 /* tdm_client_vblank_destroy */
876 TEST_P(TDMClient, ClientVblankDestroy)
880 ASSERT_EQ(PrepareClient(), true);
881 ASSERT_EQ(PrepareOutput(), true);
883 vblank = tdm_client_output_create_vblank(output, &ret);
884 ASSERT_EQ(ret, TDM_ERROR_NONE);
885 ASSERT_NE(vblank, NULL);
887 tdm_client_vblank_destroy(vblank);
891 TEST_P(TDMClient, ClientVblankDestroyNullObject)
893 tdm_client_vblank_destroy(NULL);
896 /* tdm_client_vblank_set_name */
897 TEST_P(TDMClient, ClientVblankSetName)
899 ASSERT_EQ(PrepareClient(), true);
900 ASSERT_EQ(PrepareOutput(), true);
901 ASSERT_EQ(PrepareVblank(), true);
903 ASSERT_EQ(tdm_client_vblank_set_name(vblank, TDM_UT_VBLANK_NAME), TDM_ERROR_NONE);
906 TEST_P(TDMClient, ClientVblankSetNameTwice)
908 ASSERT_EQ(PrepareClient(), true);
909 ASSERT_EQ(PrepareOutput(), true);
910 ASSERT_EQ(PrepareVblank(), true);
912 ASSERT_EQ(tdm_client_vblank_set_name(vblank, TDM_UT_VBLANK_NAME), TDM_ERROR_NONE);
913 ASSERT_EQ(tdm_client_vblank_set_name(vblank, TDM_UT_VBLANK_NAME), TDM_ERROR_NONE);
916 TEST_P(TDMClient, ClientVblankSetNameNullObject)
918 ASSERT_EQ(tdm_client_vblank_set_name(NULL, TDM_UT_VBLANK_NAME), TDM_ERROR_INVALID_PARAMETER);
921 /* tdm_client_vblank_set_sync */
922 TEST_P(TDMClient, ClientVblankSetSync)
924 ASSERT_EQ(PrepareClient(), true);
925 ASSERT_EQ(PrepareOutput(), true);
926 ASSERT_EQ(PrepareVblank(), true);
928 ASSERT_EQ(tdm_client_vblank_set_sync(vblank, 1), TDM_ERROR_NONE);
931 TEST_P(TDMClient, ClientVblankSetSyncTwice)
933 ASSERT_EQ(PrepareClient(), true);
934 ASSERT_EQ(PrepareOutput(), true);
935 ASSERT_EQ(PrepareVblank(), true);
937 ASSERT_EQ(tdm_client_vblank_set_sync(vblank, 1), TDM_ERROR_NONE);
938 ASSERT_EQ(tdm_client_vblank_set_sync(vblank, 1), TDM_ERROR_NONE);
941 TEST_P(TDMClient, ClientVblankSetSyncNullObject)
943 ASSERT_EQ(tdm_client_vblank_set_sync(NULL, 1), TDM_ERROR_INVALID_PARAMETER);
946 /* tdm_client_vblank_set_fps */
947 TEST_P(TDMClient, ClientVblankSetFps)
949 ASSERT_EQ(PrepareClient(), true);
950 ASSERT_EQ(PrepareOutput(), true);
951 ASSERT_EQ(PrepareVblank(), true);
953 ASSERT_EQ(tdm_client_vblank_set_fps(vblank, 30), TDM_ERROR_NONE);
956 TEST_P(TDMClient, ClientVblankSetFpsTwice)
958 ASSERT_EQ(PrepareClient(), true);
959 ASSERT_EQ(PrepareOutput(), true);
960 ASSERT_EQ(PrepareVblank(), true);
962 ASSERT_EQ(tdm_client_vblank_set_fps(vblank, 30), TDM_ERROR_NONE);
963 ASSERT_EQ(tdm_client_vblank_set_fps(vblank, 30), TDM_ERROR_NONE);
966 TEST_P(TDMClient, ClientVblankSetFpsNullObject)
968 ASSERT_EQ(tdm_client_vblank_set_fps(NULL, 30), TDM_ERROR_INVALID_PARAMETER);
971 /* tdm_client_vblank_set_offset */
972 TEST_P(TDMClient, ClientVblankSetOffset)
974 ASSERT_EQ(PrepareClient(), true);
975 ASSERT_EQ(PrepareOutput(), true);
976 ASSERT_EQ(PrepareVblank(), true);
978 ASSERT_EQ(tdm_client_vblank_set_offset(vblank, 10), TDM_ERROR_NONE);
981 TEST_P(TDMClient, ClientVblankSetOffsetTwice)
983 ASSERT_EQ(PrepareClient(), true);
984 ASSERT_EQ(PrepareOutput(), true);
985 ASSERT_EQ(PrepareVblank(), true);
987 ASSERT_EQ(tdm_client_vblank_set_offset(vblank, 10), TDM_ERROR_NONE);
988 ASSERT_EQ(tdm_client_vblank_set_offset(vblank, 10), TDM_ERROR_NONE);
991 TEST_P(TDMClient, ClientVblankSetOffsetNullObject)
993 ASSERT_EQ(tdm_client_vblank_set_offset(NULL, 10), TDM_ERROR_INVALID_PARAMETER);
996 /* tdm_client_vblank_set_enable_fake */
997 TEST_P(TDMClient, ClientVblankSetEnableFake)
999 ASSERT_EQ(PrepareClient(), true);
1000 ASSERT_EQ(PrepareOutput(), true);
1001 ASSERT_EQ(PrepareVblank(), true);
1003 ASSERT_EQ(tdm_client_vblank_set_enable_fake(vblank, 1), TDM_ERROR_NONE);
1006 TEST_P(TDMClient, ClientVblankSetEnableFakeTwice)
1008 ASSERT_EQ(PrepareClient(), true);
1009 ASSERT_EQ(PrepareOutput(), true);
1010 ASSERT_EQ(PrepareVblank(), true);
1012 ASSERT_EQ(tdm_client_vblank_set_enable_fake(vblank, 1), TDM_ERROR_NONE);
1013 ASSERT_EQ(tdm_client_vblank_set_enable_fake(vblank, 1), TDM_ERROR_NONE);
1016 TEST_P(TDMClient, ClientVblankSetEnableFakeNullObject)
1018 ASSERT_EQ(tdm_client_vblank_set_enable_fake(NULL, 1), TDM_ERROR_INVALID_PARAMETER);
1022 _tc_tdm_client_vblank_cb2(tdm_client_vblank *vblank,
1024 unsigned int sequence,
1025 unsigned int tv_sec,
1026 unsigned int tv_usec,
1029 bool *done = (bool *)user_data;
1034 /* tdm_client_vblank_wait */
1035 TEST_P(TDMClient, ClientVblankWait)
1039 ASSERT_EQ(PrepareClient(), true);
1040 ASSERT_EQ(PrepareOutput(), true);
1041 ASSERT_EQ(PrepareVblank(), true);
1044 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done), TDM_ERROR_NONE);
1046 start = tdm_helper_get_time();
1048 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1049 end = tdm_helper_get_time();
1051 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1052 ASSERT_LT((end - start), (vrefresh_interval + vrefresh_interval));
1055 TEST_P(TDMClient, ClientVblankWaitFewTime)
1057 bool done1, done2, done3;
1059 ASSERT_EQ(PrepareClient(), true);
1060 ASSERT_EQ(PrepareOutput(), true);
1061 ASSERT_EQ(PrepareVblank(), true);
1063 done1 = done2 = done3 = false;
1064 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done1), TDM_ERROR_NONE);
1065 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done2), TDM_ERROR_NONE);
1066 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done3), TDM_ERROR_NONE);
1068 start = tdm_helper_get_time();
1069 while (!done1 || !done2 || !done3)
1070 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1071 end = tdm_helper_get_time();
1073 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1074 ASSERT_LT((end - start), (vrefresh_interval + vrefresh_interval));
1078 TEST_P(TDMClient, ClientVblankWaitInterval0)
1080 ASSERT_EQ(PrepareClient(), true);
1081 ASSERT_EQ(PrepareOutput(), true);
1082 ASSERT_EQ(PrepareVblank(), true);
1084 ASSERT_EQ(tdm_client_vblank_wait(vblank, 0, _tc_tdm_client_vblank_cb2, NULL), TDM_ERROR_INVALID_PARAMETER);
1087 TEST_P(TDMClient, ClientVblankWaitInterval)
1091 ASSERT_EQ(PrepareClient(), true);
1092 ASSERT_EQ(PrepareOutput(), true);
1093 ASSERT_EQ(PrepareVblank(), true);
1096 for (int t = 1; t < 10; t++) {
1098 ASSERT_EQ(tdm_client_vblank_wait(vblank, t, _tc_tdm_client_vblank_cb2, &done), TDM_ERROR_NONE);
1100 start = tdm_helper_get_time();
1102 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1103 end = tdm_helper_get_time();
1105 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1106 ASSERT_GT((end - start), (vrefresh_interval * (t - 1)));
1107 ASSERT_LT((end - start), (vrefresh_interval * t + vrefresh_interval));
1112 _tc_tdm_client_vblank_cb3(tdm_client_vblank *vblank,
1114 unsigned int sequence,
1115 unsigned int tv_sec,
1116 unsigned int tv_usec,
1119 unsigned int *cur_seq = (unsigned int *)user_data;
1121 *cur_seq = sequence;
1124 TEST_P(TDMClient, ClientVblankWaitSeq)
1126 ASSERT_EQ(PrepareClient(), true);
1127 ASSERT_EQ(PrepareOutput(), true);
1128 ASSERT_EQ(PrepareVblank(), true);
1130 for (int t = 0; t < 10; t++) {
1131 unsigned int cur_seq = 0, temp = 0;
1133 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb3, &cur_seq), TDM_ERROR_NONE);
1134 while (cur_seq == 0)
1135 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1137 start = tdm_helper_get_time();
1138 ASSERT_EQ(tdm_client_vblank_wait_seq(vblank, cur_seq + 1, _tc_tdm_client_vblank_cb3, &temp), TDM_ERROR_NONE);
1140 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1141 end = tdm_helper_get_time();
1143 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1144 ASSERT_LT((end - start), (vrefresh_interval + vrefresh_interval));
1148 TEST_P(TDMClient, ClientVblankWaitSeqInterval)
1150 ASSERT_EQ(PrepareClient(), true);
1151 ASSERT_EQ(PrepareOutput(), true);
1152 ASSERT_EQ(PrepareVblank(), true);
1155 for (int t = 1; t < 10; t++) {
1156 unsigned int cur_seq = 0, temp = 0;
1158 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb3, &cur_seq), TDM_ERROR_NONE);
1159 while (cur_seq == 0)
1160 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1162 start = tdm_helper_get_time();
1163 ASSERT_EQ(tdm_client_vblank_wait_seq(vblank, cur_seq + t, _tc_tdm_client_vblank_cb3, &temp), TDM_ERROR_NONE);
1165 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1166 end = tdm_helper_get_time();
1168 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1169 ASSERT_GT((end - start), (vrefresh_interval * (t - 1)));
1170 ASSERT_LT((end - start), (vrefresh_interval * t + vrefresh_interval));
1174 TEST_P(TDMClient, ClientVblankWaitSetOffset)
1178 ASSERT_EQ(PrepareClient(), true);
1179 ASSERT_EQ(PrepareOutput(), true);
1180 ASSERT_EQ(PrepareVblank(), true);
1182 ASSERT_EQ(tdm_client_vblank_set_offset(vblank, 100), TDM_ERROR_NONE);
1185 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done), TDM_ERROR_NONE);
1187 start = tdm_helper_get_time();
1189 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1190 end = tdm_helper_get_time();
1192 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1193 ASSERT_GT((end - start), (0.1));
1194 ASSERT_LT((end - start), (vrefresh_interval + vrefresh_interval + 0.1));
1197 TEST_P(TDMClient, ClientVblankWaitSetFps)
1201 unsigned int fps = 10;
1203 ASSERT_EQ(PrepareClient(), true);
1204 ASSERT_EQ(PrepareOutput(), true);
1205 ASSERT_EQ(PrepareVblank(), true);
1207 ASSERT_EQ(tdm_client_vblank_set_fps(vblank, fps), TDM_ERROR_NONE);
1208 interval = 1.0 / (double)fps;
1211 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done), TDM_ERROR_NONE);
1213 start = tdm_helper_get_time();
1215 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1216 end = tdm_helper_get_time();
1218 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1219 ASSERT_GT((end - start), (interval - vrefresh_interval));
1220 ASSERT_LT((end - start), (interval + vrefresh_interval));
1225 TEST_P(TDMVblank, VblankWaitEnableDisableGlobalFps)
1227 TDM_UT_SKIP_FLAG(has_outputs);
1229 unsigned int fps = (unsigned int)TDM_UT_INVALID_VALUE;
1230 double vrefresh_interval;
1231 unsigned int cur_seq[3];
1232 unsigned int global_fps = 5;
1233 double start, end, interval;
1235 ASSERT_EQ(TestPrepareOutput(), true);
1236 ASSERT_EQ(TestCreateVblanks3(), true);
1237 ASSERT_EQ(vblank_count, 3);
1239 ASSERT_EQ(tdm_vblank_get_fps(vblanks[0], &fps), TDM_ERROR_NONE);
1240 ASSERT_TRUE(fps >= 30 && fps != (unsigned int)TDM_UT_INVALID_VALUE);
1241 vrefresh_interval = 1.0 / (double)fps;
1243 for (int v = 0; v < 3; v++)
1244 ASSERT_EQ(tdm_vblank_set_fixed_fps(vblanks[v], 10 * (v + 1)), TDM_ERROR_NONE);
1247 tdm_vblank_enable_global_fps(1, global_fps);
1248 interval = 1.0 / (double)global_fps;
1250 for (int v = 0; v < 3; v++) {
1252 ASSERT_EQ(tdm_vblank_wait(vblanks[v], 0, 0, 1, _tc_tdm_vblank_cb, &cur_seq[v]), TDM_ERROR_NONE);
1255 start = tdm_helper_get_time();
1256 while (cur_seq[0] == 0)
1257 ASSERT_EQ(tc_tdm_display_handle_events(dpy), TDM_ERROR_NONE);
1258 end = tdm_helper_get_time();
1260 ASSERT_NE(cur_seq[1], 0);
1261 ASSERT_NE(cur_seq[2], 0);
1263 /* "+- vrefresh_interval" consider the delay of socket communication between kernel and platform */
1264 ASSERT_GT((end - start), (interval - vrefresh_interval));
1265 ASSERT_LT((end - start), (interval + vrefresh_interval));
1268 tdm_vblank_enable_global_fps(0, 0);
1270 for (int v = 0; v < 3; v++) {
1272 ASSERT_EQ(tdm_vblank_wait(vblanks[v], 0, 0, 1, _tc_tdm_vblank_cb, &cur_seq[v]), TDM_ERROR_NONE);
1275 while (cur_seq[0] == 0)
1276 ASSERT_EQ(tc_tdm_display_handle_events(dpy), TDM_ERROR_NONE);
1277 ASSERT_EQ(cur_seq[1], 0);
1278 ASSERT_EQ(cur_seq[2], 0);
1280 while (cur_seq[1] == 0)
1281 ASSERT_EQ(tc_tdm_display_handle_events(dpy), TDM_ERROR_NONE);
1282 ASSERT_EQ(cur_seq[2], 0);
1285 TEST_P(TDMVblank, VblankWaitIgnoreGlobalFps)
1287 TDM_UT_SKIP_FLAG(has_outputs);
1289 unsigned int fps = (unsigned int)TDM_UT_INVALID_VALUE;
1290 unsigned int cur_seq[3];
1291 unsigned int global_fps = 5;
1292 double start, end, interval;
1294 ASSERT_EQ(TestPrepareOutput(), true);
1295 ASSERT_EQ(TestCreateVblanks3(), true);
1296 ASSERT_EQ(vblank_count, 3);
1298 ASSERT_EQ(tdm_vblank_get_fps(vblanks[0], &fps), TDM_ERROR_NONE);
1299 ASSERT_TRUE(fps >= 30 && fps != (unsigned int)TDM_UT_INVALID_VALUE);
1300 interval = 1.0 / (double)fps;
1302 /* 2nd vblank will ignore the global fps. */
1303 ASSERT_EQ(tdm_vblank_ignore_global_fps(vblanks[1], 1), TDM_ERROR_NONE);
1305 tdm_vblank_enable_global_fps(1, global_fps);
1307 for (int v = 0; v < 3; v++) {
1309 ASSERT_EQ(tdm_vblank_wait(vblanks[v], 0, 0, 1, _tc_tdm_vblank_cb, &cur_seq[v]), TDM_ERROR_NONE);
1312 start = tdm_helper_get_time();
1313 while (cur_seq[1] == 0)
1314 ASSERT_EQ(tc_tdm_display_handle_events(dpy), TDM_ERROR_NONE);
1315 end = tdm_helper_get_time();
1317 ASSERT_EQ(cur_seq[0], 0);
1318 ASSERT_EQ(cur_seq[2], 0);
1320 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1321 ASSERT_LT((end - start), (interval + interval));
1323 while (cur_seq[0] == 0)
1324 ASSERT_EQ(tc_tdm_display_handle_events(dpy), TDM_ERROR_NONE);
1325 ASSERT_NE(cur_seq[2], 0);
1330 TEST_P(TDMClient, ClientVblankWaitNullObject)
1332 unsigned int cur_seq = 0;
1334 ASSERT_EQ(tdm_client_vblank_wait(NULL, 1, _tc_tdm_client_vblank_cb3, &cur_seq), TDM_ERROR_INVALID_PARAMETER);
1337 TEST_P(TDMClient, ClientVblankWaitNullOther)
1339 ASSERT_EQ(PrepareClient(), true);
1340 ASSERT_EQ(PrepareOutput(), true);
1341 ASSERT_EQ(PrepareVblank(), true);
1343 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, NULL, NULL), TDM_ERROR_INVALID_PARAMETER);
1346 TEST_P(TDMClient, ClientVblankWaitDpmsOff)
1348 tdm_output_dpms dpms = (tdm_output_dpms)TDM_UT_INVALID_VALUE;
1350 ASSERT_EQ(PrepareClient(), true);
1351 ASSERT_EQ(PrepareOutput(), true);
1352 ASSERT_EQ(PrepareVblank(), true);
1354 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_OFF), true);
1355 while (dpms != TDM_OUTPUT_DPMS_OFF)
1356 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
1357 ASSERT_EQ(dpms, TDM_OUTPUT_DPMS_OFF);
1359 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, NULL), TDM_ERROR_DPMS_OFF);
1361 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_ON), true);
1362 while (dpms != TDM_OUTPUT_DPMS_ON)
1363 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
1366 TEST_P(TDMClient, ClientVblankWaitSetEnableFakeDpmsOff)
1368 tdm_output_dpms dpms = (tdm_output_dpms)TDM_UT_INVALID_VALUE;
1371 ASSERT_EQ(PrepareClient(), true);
1372 ASSERT_EQ(PrepareOutput(), true);
1373 ASSERT_EQ(PrepareVblank(), true);
1375 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_OFF), true);
1376 while (dpms != TDM_OUTPUT_DPMS_OFF)
1377 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
1379 ASSERT_EQ(tdm_client_vblank_set_enable_fake(vblank, 1), TDM_ERROR_NONE);
1382 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done), TDM_ERROR_NONE);
1385 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1387 ASSERT_EQ(_tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_DPMS_ON), true);
1388 while (dpms != TDM_OUTPUT_DPMS_ON)
1389 ASSERT_EQ(tdm_client_output_get_dpms(output, &dpms), TDM_ERROR_NONE);
1392 /* tdm_client_vblank_wait */
1393 TEST_P(TDMClient, ClientVblankIsWaiting)
1396 unsigned int waiting;
1398 ASSERT_EQ(PrepareClient(), true);
1399 ASSERT_EQ(PrepareOutput(), true);
1400 ASSERT_EQ(PrepareVblank(), true);
1403 ASSERT_EQ(tdm_client_vblank_wait(vblank, 1, _tc_tdm_client_vblank_cb2, &done), TDM_ERROR_NONE);
1405 waiting = tdm_client_vblank_is_waiting(vblank);
1406 ASSERT_EQ(waiting, 1);
1408 start = tdm_helper_get_time();
1410 ASSERT_EQ(tdm_client_handle_events_timeout(client, 3000), TDM_ERROR_NONE);
1411 end = tdm_helper_get_time();
1413 /* "+ vrefresh_interval" consider the delay of socket communication between kernel and platform */
1414 ASSERT_LT((end - start), (vrefresh_interval + vrefresh_interval));
1416 waiting = tdm_client_vblank_is_waiting(vblank);
1417 ASSERT_EQ(waiting, 0);
1420 /* tdm_client_vblank_wait */
1421 TEST_P(TDMClient, ClientVblankIsWaitingNullObject)
1423 unsigned int waiting = tdm_client_vblank_is_waiting(NULL);
1424 ASSERT_EQ(waiting, 0);
1427 TEST_P(TDMClient, ClientCreateVOutput)
1430 const char name[TDM_NAME_LEN] = "Virtual Output";
1432 ASSERT_EQ(PrepareClient(), true);
1434 voutput = tdm_client_create_voutput(client, name, &ret);
1435 ASSERT_EQ(ret, TDM_ERROR_NONE);
1436 ASSERT_NE(voutput, NULL);
1438 tdm_client_voutput_destroy(voutput);
1441 class TDMVirtualOutput : public ::testing::Test
1444 TDMVirtualOutput() {};
1445 ~TDMVirtualOutput() {};
1447 static void SetUpTestCase();
1448 static void TearDownTestCase();
1449 static bool PrepareVOutput(void);
1452 static tdm_client *client;
1453 static tdm_client_voutput *voutput;
1454 const int MODE_COUNT = 2;
1457 static pid_t server_pid;
1459 /* 0: read, 1: write */
1460 static int pipe_parent[2];
1461 static int pipe_child[2];
1463 static void ServerFork(void);
1464 static void ServerKill(void);
1467 pid_t TDMVirtualOutput::server_pid = -1;
1468 int TDMVirtualOutput::pipe_parent[2] = {-1, -1};
1469 int TDMVirtualOutput::pipe_child[2] = {-1, -1};
1470 tdm_client* TDMVirtualOutput::client = nullptr;
1471 tdm_client_voutput* TDMVirtualOutput::voutput = nullptr;
1473 void TDMVirtualOutput::ServerKill(void)
1475 if (pipe_child[0] >= 0)
1476 close(pipe_child[0]);
1477 if (pipe_child[1] >= 0) {
1478 if (server_pid > 0) {
1479 bool ret = _tc_tdm_pipe_write_msg(pipe_child[1], pipe_parent[0], TDM_UT_PIPE_MSG_TERMINATE_SERVER);
1481 if (waitpid(server_pid, NULL, 0) == server_pid)
1482 TDM_INFO("*** server terminated ***");
1484 TDM_ERR("*** failed to terminate server ***");
1486 if (kill(server_pid, 9) < 0)
1487 TDM_ERR("*** failed to kill server ***");
1490 close(pipe_child[1]);
1493 if (pipe_parent[0] >= 0)
1494 close(pipe_parent[0]);
1495 if (pipe_parent[1] >= 0)
1496 close(pipe_parent[1]);
1499 pipe_parent[0] = pipe_parent[1] = -1;
1500 pipe_child[0] = pipe_child[1] = -1;
1503 void TDMVirtualOutput::ServerFork(void)
1508 server_pid = _tc_tdm_client_server_fork(pipe_parent, pipe_child);
1509 ASSERT_GT(server_pid, 0);
1512 void TDMVirtualOutput::SetUpTestCase(void)
1514 setenv("XDG_RUNTIME_DIR", "/run", 1);
1515 setenv("TBM_DISPLAY_SERVER", "1", 1);
1517 if (server_pid == -1)
1520 ASSERT_EQ(PrepareVOutput(), true);
1523 void TDMVirtualOutput::TearDownTestCase(void)
1525 // TDM_UT_WAIT("check & press");
1528 tdm_client_voutput_destroy(voutput);
1531 tdm_client_destroy(client);
1535 unsetenv("XDG_RUNTIME_DIR");
1536 unsetenv("TBM_DISPLAY_SERVER");
1539 bool TDMVirtualOutput::PrepareVOutput(void)
1542 const char name[TDM_NAME_LEN] = "Virtual Output";
1544 client = tdm_client_create(&ret);
1545 TDM_UT_RETURN_FALSE_IF_FAIL(ret == TDM_ERROR_NONE);
1546 TDM_UT_RETURN_FALSE_IF_FAIL(client != NULL);
1549 voutput = tdm_client_create_voutput(client, name, &ret);
1550 TDM_UT_RETURN_FALSE_IF_FAIL(ret == TDM_ERROR_NONE);
1551 TDM_UT_RETURN_FALSE_IF_FAIL(voutput != NULL);
1553 // TDM_UT_WAIT("check & press");
1559 _tc_tdm_client_virutual_make_available_mode(tdm_client_output_mode *modes, int count)
1563 for (i = 0; i < count; i++) {
1564 modes[i].clock = 25200;
1565 modes[i].hdisplay = 640;
1566 modes[i].hsync_start = 656;
1567 modes[i].hsync_end = 752;
1568 modes[i].htotal = 800;
1570 modes[i].vdisplay = 480;
1571 modes[i].vsync_start = 490;
1572 modes[i].vsync_end = 492;
1573 modes[i].vtotal = 525;
1575 modes[i].vrefresh = 30;
1578 snprintf(modes[i].name, TDM_NAME_LEN, "%dx%d_%d", modes[i].hdisplay, modes[i].vdisplay, i);
1582 TEST_F(TDMVirtualOutput, SetAvailableModes)
1585 tdm_client_output_mode modes[this->MODE_COUNT];
1586 int count = this->MODE_COUNT;
1588 _tc_tdm_client_virutual_make_available_mode(modes, count);
1590 ret = tdm_client_voutput_set_available_modes(this->voutput, modes, count);
1591 ASSERT_EQ(ret, TDM_ERROR_NONE);
1594 TEST_F(TDMVirtualOutput, FailTestSetAvailableModes)
1597 tdm_client_output_mode modes[this->MODE_COUNT];
1598 int count = this->MODE_COUNT;
1600 ret = tdm_client_voutput_set_available_modes(NULL, modes, count);
1601 ASSERT_EQ(ret, TDM_ERROR_INVALID_PARAMETER);
1603 ret = tdm_client_voutput_set_available_modes(this->voutput, NULL, count);
1604 ASSERT_EQ(ret, TDM_ERROR_INVALID_PARAMETER);
1607 TEST_F(TDMVirtualOutput, SetPhysicalSize)
1610 unsigned int mmWidth = 1234, mmHeight = 1234;
1612 ret = tdm_client_voutput_set_physical_size(this->voutput, mmWidth, mmHeight);
1613 ASSERT_EQ(ret, TDM_ERROR_NONE);
1616 TEST_F(TDMVirtualOutput, FailTestSetPhysicalSize)
1619 unsigned int invalid_mmWidth = 0, invalid_mmHeight = 0;
1621 ret = tdm_client_voutput_set_physical_size(this->voutput, invalid_mmWidth, invalid_mmHeight);
1622 ASSERT_EQ(ret, TDM_ERROR_INVALID_PARAMETER);
1626 _tc_tdm_client_voutput_commit_handler(tdm_client_voutput *voutput, tbm_surface_h buffer, void *user_data)
1629 flag = (int *)user_data;
1633 TEST_F(TDMVirtualOutput, AddCommitHandler)
1636 int flag_callback_called = 0;
1638 ret = tdm_client_voutput_add_commit_handler(this->voutput,
1639 _tc_tdm_client_voutput_commit_handler,
1640 &flag_callback_called);
1641 ASSERT_EQ(ret, TDM_ERROR_NONE);
1642 // ASSERT_EQ(flag_callback_called, 1);
1644 tdm_client_voutput_remove_commit_handler(this->voutput,
1645 _tc_tdm_client_voutput_commit_handler,
1646 &flag_callback_called);
1649 TEST_F(TDMVirtualOutput, CommitDone)
1653 ret = tdm_client_voutput_commit_done(this->voutput);
1654 ASSERT_EQ(ret, TDM_ERROR_NONE);
1657 TEST_F(TDMVirtualOutput, GetClientOutput)
1660 tdm_client_output *output;
1662 output = tdm_client_voutput_get_client_output(this->voutput, &ret);
1663 ASSERT_EQ(ret, TDM_ERROR_NONE);
1664 ASSERT_NE(output, NULL);
1667 TEST_F(TDMVirtualOutput, Connect)
1670 tdm_client_output *output;
1671 unsigned int mmWidth = 300, mmHeight = 150;
1672 tdm_client_output_mode modes[this->MODE_COUNT];
1673 int count = this->MODE_COUNT;
1675 output = tdm_client_voutput_get_client_output(this->voutput, &ret);
1676 ASSERT_EQ(ret, TDM_ERROR_NONE);
1677 ASSERT_NE(output, NULL);
1679 ret = tdm_client_voutput_set_physical_size(this->voutput, mmWidth, mmHeight);
1680 ASSERT_EQ(ret, TDM_ERROR_NONE);
1682 _tc_tdm_client_virutual_make_available_mode(modes, count);
1683 ret = tdm_client_voutput_set_available_modes(this->voutput, modes, count);
1684 ASSERT_EQ(ret, TDM_ERROR_NONE);
1686 ret = tdm_client_output_connect(output);
1687 ASSERT_EQ(ret, TDM_ERROR_NONE);
1689 tdm_client_handle_events_timeout(this->client, 0);
1692 TEST_F(TDMVirtualOutput, Disconnect)
1695 tdm_client_output *output;
1697 // TDM_UT_WAIT("check & press");
1699 output = tdm_client_voutput_get_client_output(this->voutput, &ret);
1700 ASSERT_EQ(ret, TDM_ERROR_NONE);
1701 ASSERT_NE(output, NULL);
1703 ret = tdm_client_output_disconnect(output);
1704 ASSERT_EQ(ret, TDM_ERROR_NONE);
1706 tdm_client_handle_events_timeout(this->client, 0);
1710 TEST_F(TDMVirtualOutput, FailTestGetClientOutput)
1715 TEST_F(TDMVirtualOutput, SetBufferQueue)
1720 TEST_F(TDMVirtualOutput, FailTestSetBufferQueue)
1727 #ifdef TDM_UT_TEST_WITH_PARAMS
1728 INSTANTIATE_TEST_CASE_P(TDMClientParams,
1730 Combine(Bool(), Bool(), Values(TDM_DEFAULT_MODULE)));
1732 INSTANTIATE_TEST_CASE_P(TDMClientParams,
1734 Values(TDM_DEFAULT_MODULE));