source: mainline/uspace/lib/ddev/test/ddev.c@ 0b63dc2

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 0b63dc2 was 0b63dc2, checked in by Jiri Svoboda <jiri@…>, 6 years ago

Switch compositor → display server

Convert KFB from visualizer to display device interface. Add ability
of display device implementor to provide client with arg2, arg3 needed
to connect to GC.

  • Property mode set to 100644
File size: 5.9 KB
Line 
1/*
2 * Copyright (c) 2019 Jiri Svoboda
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#include <async.h>
30#include <errno.h>
31#include <ddev.h>
32#include <ddev_srv.h>
33#include <fibril_synch.h>
34#include <gfx/color.h>
35#include <gfx/context.h>
36#include <gfx/render.h>
37#include <ipcgfx/server.h>
38#include <loc.h>
39#include <pcut/pcut.h>
40
41PCUT_INIT;
42
43PCUT_TEST_SUITE(ddev);
44
45static const char *test_ddev_server = "test-ddev";
46static const char *test_ddev_svc = "test/ddev";
47
48static void test_ddev_conn(ipc_call_t *, void *);
49
50static errno_t test_get_gc(void *, sysarg_t *, sysarg_t *);
51static errno_t test_gc_set_color(void *, gfx_color_t *);
52
53static ddev_ops_t test_ddev_ops = {
54 .get_gc = test_get_gc
55};
56
57static gfx_context_ops_t test_gc_ops = {
58 .set_color = test_gc_set_color
59};
60
61/** Describes to the server how to respond to our request and pass tracking
62 * data back to the client.
63 */
64typedef struct {
65 errno_t rc;
66 bool set_color_called;
67 ddev_srv_t *srv;
68} test_response_t;
69
70/** ddev_open(), ddev_close() work for valid display device service */
71PCUT_TEST(open_close)
72{
73 errno_t rc;
74 service_id_t sid;
75 ddev_t *ddev = NULL;
76 test_response_t resp;
77
78 async_set_fallback_port_handler(test_ddev_conn, &resp);
79
80 // FIXME This causes this test to be non-reentrant!
81 rc = loc_server_register(test_ddev_server);
82 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
83
84 rc = loc_service_register(test_ddev_svc, &sid);
85 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
86
87 rc = ddev_open(test_ddev_svc, &ddev);
88 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
89 PCUT_ASSERT_NOT_NULL(ddev);
90
91 ddev_close(ddev);
92 rc = loc_service_unregister(sid);
93 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
94}
95
96/** ddev_get_gc with server returning failure */
97PCUT_TEST(dev_get_gc_failure)
98{
99 errno_t rc;
100 service_id_t sid;
101 ddev_t *ddev = NULL;
102 test_response_t resp;
103 gfx_context_t *gc;
104
105 async_set_fallback_port_handler(test_ddev_conn, &resp);
106
107 // FIXME This causes this test to be non-reentrant!
108 rc = loc_server_register(test_ddev_server);
109 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
110
111 rc = loc_service_register(test_ddev_svc, &sid);
112 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
113
114 rc = ddev_open(test_ddev_svc, &ddev);
115 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
116 PCUT_ASSERT_NOT_NULL(ddev);
117
118 gc = NULL;
119 resp.rc = ENOMEM;
120 rc = ddev_get_gc(ddev, &gc);
121 /* async_connect_me_to() does not return specific error */
122 PCUT_ASSERT_ERRNO_VAL(EIO, rc);
123 PCUT_ASSERT_NULL(gc);
124
125 ddev_close(ddev);
126 rc = loc_service_unregister(sid);
127 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
128}
129
130/** ddev_get_gc with server returning success */
131PCUT_TEST(dev_get_gc_success)
132{
133 errno_t rc;
134 service_id_t sid;
135 ddev_t *ddev = NULL;
136 test_response_t resp;
137 gfx_context_t *gc;
138 gfx_color_t *color;
139
140 async_set_fallback_port_handler(test_ddev_conn, &resp);
141
142 // FIXME This causes this test to be non-reentrant!
143 rc = loc_server_register(test_ddev_server);
144 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
145
146 rc = loc_service_register(test_ddev_svc, &sid);
147 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
148
149 rc = ddev_open(test_ddev_svc, &ddev);
150 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
151 PCUT_ASSERT_NOT_NULL(ddev);
152
153 resp.rc = EOK;
154 gc = NULL;
155 rc = ddev_get_gc(ddev, &gc);
156 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
157 PCUT_ASSERT_NOT_NULL(gc);
158
159 rc = gfx_color_new_rgb_i16(0, 0, 0, &color);
160 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
161
162 resp.set_color_called = false;
163 rc = gfx_set_color(gc, color);
164 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
165 PCUT_ASSERT_TRUE(resp.set_color_called);
166
167 gfx_color_delete(color);
168
169 ddev_close(ddev);
170 rc = loc_service_unregister(sid);
171 PCUT_ASSERT_ERRNO_VAL(EOK, rc);
172}
173
174/** Test display device connection.
175 *
176 * This is very similar to connection handler in the display server.
177 * XXX This should be folded into display_srv, if possible
178 */
179static void test_ddev_conn(ipc_call_t *icall, void *arg)
180{
181 test_response_t *resp = (test_response_t *) arg;
182 ddev_srv_t srv;
183 sysarg_t svc_id;
184 gfx_context_t *gc;
185 errno_t rc;
186
187 svc_id = ipc_get_arg2(icall);
188
189 if (svc_id != 0) {
190 /* Set up protocol structure */
191 ddev_srv_initialize(&srv);
192 srv.ops = &test_ddev_ops;
193 srv.arg = arg;
194 resp->srv = &srv;
195
196 /* Handle connection */
197 ddev_conn(icall, &srv);
198
199 resp->srv = NULL;
200 } else {
201 if (resp->rc != EOK) {
202 async_answer_0(icall, resp->rc);
203 return;
204 }
205
206 rc = gfx_context_new(&test_gc_ops, arg, &gc);
207 if (rc != EOK) {
208 async_answer_0(icall, ENOMEM);
209 return;
210 }
211
212 /* GC connection */
213 gc_conn(icall, gc);
214 }
215}
216
217static errno_t test_get_gc(void *arg, sysarg_t *arg2, sysarg_t *arg3)
218{
219 *arg2 = 0;
220 *arg3 = 42;
221 return EOK;
222}
223
224static errno_t test_gc_set_color(void *arg, gfx_color_t *color)
225{
226 test_response_t *resp = (test_response_t *) arg;
227
228 resp->set_color_called = true;
229 return resp->rc;
230}
231
232PCUT_EXPORT(ddev);
Note: See TracBrowser for help on using the repository browser.