2 * Copyright © 2013 Intel Corporation
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
23 #include <gtest/gtest.h>
28 #include "glxclient.h"
29 #include "glx_error.h"
32 extern bool GetGLXScreenConfigs_called
;
33 extern struct glx_screen
*psc
;
35 struct attribute_test_vector
{
40 #define E(x) { # x, x }
44 static bool got_sigsegv
;
48 sigsegv_handler(int sig
)
55 static bool query_renderer_string_called
= false;
56 static bool query_renderer_integer_called
= false;
59 fake_query_renderer_integer(struct glx_screen
*psc
, int attribute
, int *value
)
65 query_renderer_integer_called
= true;
71 fake_query_renderer_string(struct glx_screen
*psc
, int attribute
,
78 query_renderer_string_called
= true;
83 struct glx_screen_vtable fake_vtable
= {
86 fake_query_renderer_integer
,
87 fake_query_renderer_string
90 class query_renderer_string_test
: public ::testing::Test
{
93 virtual void TearDown();
95 struct glx_screen scr
;
97 struct sigaction old_sa
;
101 class query_renderer_integer_test
: public query_renderer_string_test
{
104 void query_renderer_string_test::SetUp()
106 memset(&scr
, 0, sizeof(scr
));
107 scr
.vtable
= &fake_vtable
;
112 sa
.sa_handler
= sigsegv_handler
;
113 sigemptyset(&sa
.sa_mask
);
115 sigaction(SIGSEGV
, &sa
, &old_sa
);
118 void query_renderer_string_test::TearDown()
120 sigaction(SIGSEGV
, &old_sa
, NULL
);
124 * glXQueryRendererStringMESA will return \c NULL if the query_render_string
125 * vtable entry is \c NULL. It will also not segfault.
127 TEST_F(query_renderer_string_test
, null_query_render_string
)
129 struct glx_screen_vtable vtable
= {
136 scr
.vtable
= &vtable
;
138 if (setjmp(jmp
) == 0) {
140 glXQueryRendererStringMESA(&dpy
, 0, 0, GLX_RENDERER_VENDOR_ID_MESA
);
141 EXPECT_EQ((char *)0, str
);
143 EXPECT_FALSE(got_sigsegv
);
148 * glXQueryRendererStringMESA will not call the screen query_render_string
149 * function with an invalid GLX enum value, and it will return NULL.
151 TEST_F(query_renderer_string_test
, invalid_attribute
)
153 static const attribute_test_vector invalid_attributes
[] = {
154 /* These values are just plain invalid for use with this extension.
160 E(GLX_RENDERER_VENDOR_ID_MESA
+ 0x10000),
161 E(GLX_RENDERER_DEVICE_ID_MESA
+ 0x10000),
163 /* These enums are part of the extension, but they are not allowed for
166 E(GLX_RENDERER_VERSION_MESA
),
167 E(GLX_RENDERER_ACCELERATED_MESA
),
168 E(GLX_RENDERER_VIDEO_MEMORY_MESA
),
169 E(GLX_RENDERER_UNIFIED_MEMORY_ARCHITECTURE_MESA
),
170 E(GLX_RENDERER_PREFERRED_PROFILE_MESA
),
171 E(GLX_RENDERER_OPENGL_CORE_PROFILE_VERSION_MESA
),
172 E(GLX_RENDERER_OPENGL_COMPATIBILITY_PROFILE_VERSION_MESA
),
173 E(GLX_RENDERER_OPENGL_ES_PROFILE_VERSION_MESA
),
174 E(GLX_RENDERER_OPENGL_ES2_PROFILE_VERSION_MESA
),
175 E(GLX_RENDERER_ID_MESA
),
178 for (unsigned i
= 0; i
< ARRAY_SIZE(invalid_attributes
); i
++) {
179 query_renderer_integer_called
= false;
180 query_renderer_string_called
= false;
183 glXQueryRendererStringMESA(&dpy
, 0, 0, invalid_attributes
[i
].value
);
184 EXPECT_EQ((char *)0, str
) << invalid_attributes
[i
].string
;
185 EXPECT_FALSE(query_renderer_integer_called
)
186 << invalid_attributes
[i
].string
;
187 EXPECT_FALSE(query_renderer_string_called
)
188 << invalid_attributes
[i
].string
;
193 * glXQueryRendererStringMESA will not call GetGLXScreenConfigs if the display
194 * pointer is \c NULL. It will also not segfault.
196 TEST_F(query_renderer_string_test
, null_display_pointer
)
198 if (setjmp(jmp
) == 0) {
199 GetGLXScreenConfigs_called
= false;
202 glXQueryRendererStringMESA(NULL
, 0, 0, GLX_RENDERER_VENDOR_ID_MESA
);
203 EXPECT_EQ((char *)0, str
);
204 EXPECT_FALSE(GetGLXScreenConfigs_called
);
206 EXPECT_FALSE(got_sigsegv
);
211 * glXQueryRendererStringMESA will return error if GetGLXScreenConfigs returns
212 * NULL. It will also not segfault.
214 TEST_F(query_renderer_string_test
, null_screen_pointer
)
218 if (setjmp(jmp
) == 0) {
219 GetGLXScreenConfigs_called
= false;
222 glXQueryRendererStringMESA(&dpy
, 0, 0, GLX_RENDERER_VENDOR_ID_MESA
);
223 EXPECT_EQ((char *)0, str
);
224 EXPECT_TRUE(GetGLXScreenConfigs_called
);
226 EXPECT_FALSE(got_sigsegv
);
231 * glXQueryRendererStringMESA will not call the screen query_render_string
232 * function if the renderer is invalid, and it will return NULL.
234 TEST_F(query_renderer_string_test
, invalid_renderer_index
)
236 static const int invalid_renderer_indices
[] = {
242 if (setjmp(jmp
) == 0) {
243 for (unsigned i
= 0; i
< ARRAY_SIZE(invalid_renderer_indices
); i
++) {
245 glXQueryRendererStringMESA(&dpy
, 0,
246 invalid_renderer_indices
[i
],
247 GLX_RENDERER_VENDOR_ID_MESA
);
248 EXPECT_EQ((char *)0, str
) << invalid_renderer_indices
[i
];
249 EXPECT_FALSE(query_renderer_integer_called
)
250 << invalid_renderer_indices
[i
];
251 EXPECT_FALSE(query_renderer_string_called
)
252 << invalid_renderer_indices
[i
];
255 EXPECT_FALSE(got_sigsegv
);
260 * glXQueryCurrentRendererStringMESA will return error if there is no context
261 * current. It will also not segfault.
263 TEST_F(query_renderer_string_test
, no_current_context
)
265 if (setjmp(jmp
) == 0) {
267 glXQueryCurrentRendererStringMESA(GLX_RENDERER_VENDOR_ID_MESA
);
268 EXPECT_EQ((char *)0, str
);
270 EXPECT_FALSE(got_sigsegv
);
275 * glXQueryCurrentRendererIntegerMESA will return \c NULL if the
276 * query_render_string vtable entry is \c NULL. It will also not segfault.
278 TEST_F(query_renderer_integer_test
, null_query_render_string
)
280 struct glx_screen_vtable vtable
= {
287 scr
.vtable
= &vtable
;
289 if (setjmp(jmp
) == 0) {
290 unsigned value
= 0xDEADBEEF;
291 Bool success
= glXQueryRendererIntegerMESA(&dpy
, 0, 0,
292 GLX_RENDERER_VENDOR_ID_MESA
,
294 EXPECT_FALSE(success
);
295 EXPECT_EQ(0xDEADBEEF, value
);
297 EXPECT_FALSE(got_sigsegv
);
302 * glXQueryCurrentRendererIntegerMESA will not call the screen
303 * query_render_string function with an invalid GLX enum value, and it will
306 TEST_F(query_renderer_integer_test
, invalid_attribute
)
308 static const attribute_test_vector invalid_attributes
[] = {
309 /* These values are just plain invalid for use with this extension.
315 E(GLX_RENDERER_VENDOR_ID_MESA
+ 0x10000),
316 E(GLX_RENDERER_DEVICE_ID_MESA
+ 0x10000),
317 E(GLX_RENDERER_VERSION_MESA
+ 0x10000),
318 E(GLX_RENDERER_ACCELERATED_MESA
+ 0x10000),
319 E(GLX_RENDERER_VIDEO_MEMORY_MESA
+ 0x10000),
320 E(GLX_RENDERER_UNIFIED_MEMORY_ARCHITECTURE_MESA
+ 0x10000),
321 E(GLX_RENDERER_PREFERRED_PROFILE_MESA
+ 0x10000),
322 E(GLX_RENDERER_OPENGL_CORE_PROFILE_VERSION_MESA
+ 0x10000),
323 E(GLX_RENDERER_OPENGL_COMPATIBILITY_PROFILE_VERSION_MESA
+ 0x10000),
324 E(GLX_RENDERER_OPENGL_ES_PROFILE_VERSION_MESA
+ 0x10000),
325 E(GLX_RENDERER_OPENGL_ES2_PROFILE_VERSION_MESA
+ 0x10000),
326 E(GLX_RENDERER_ID_MESA
+ 0x10000),
329 for (unsigned i
= 0; i
< ARRAY_SIZE(invalid_attributes
); i
++) {
330 query_renderer_integer_called
= false;
331 query_renderer_string_called
= false;
333 unsigned value
= 0xDEADBEEF;
335 glXQueryRendererIntegerMESA(&dpy
, 0, 0,
336 invalid_attributes
[i
].value
,
338 EXPECT_FALSE(success
) << invalid_attributes
[i
].string
;
339 EXPECT_EQ(0xDEADBEEF, value
) << invalid_attributes
[i
].string
;
340 EXPECT_FALSE(query_renderer_integer_called
)
341 << invalid_attributes
[i
].string
;
342 EXPECT_FALSE(query_renderer_string_called
)
343 << invalid_attributes
[i
].string
;
348 * glXQueryCurrentRendererIntegerMESA will not call GetGLXScreenConfigs if the
349 * display pointer is \c NULL. It will also not segfault.
351 TEST_F(query_renderer_integer_test
, null_display_pointer
)
353 if (setjmp(jmp
) == 0) {
354 GetGLXScreenConfigs_called
= false;
356 unsigned value
= 0xDEADBEEF;
358 glXQueryRendererIntegerMESA(NULL
, 0, 0, GLX_RENDERER_VENDOR_ID_MESA
,
360 EXPECT_FALSE(success
);
361 EXPECT_EQ(0xDEADBEEF, value
);
362 EXPECT_FALSE(GetGLXScreenConfigs_called
);
364 EXPECT_FALSE(got_sigsegv
);
369 * glXQueryCurrentRendererIntegerMESA will return error if GetGLXScreenConfigs
370 * returns NULL. It will also not segfault.
372 TEST_F(query_renderer_integer_test
, null_screen_pointer
)
376 if (setjmp(jmp
) == 0) {
377 GetGLXScreenConfigs_called
= false;
379 unsigned value
= 0xDEADBEEF;
381 glXQueryRendererIntegerMESA(&dpy
, 0, 0, GLX_RENDERER_VENDOR_ID_MESA
,
383 EXPECT_FALSE(success
);
384 EXPECT_EQ(0xDEADBEEF, value
);
385 EXPECT_TRUE(GetGLXScreenConfigs_called
);
387 EXPECT_FALSE(got_sigsegv
);
392 * glXQueryRendererIntegerMESA will not call the screen query_render_integer
393 * function if the renderer is invalid, and it will return NULL.
395 TEST_F(query_renderer_integer_test
, invalid_renderer_index
)
397 static const int invalid_renderer_indices
[] = {
403 if (setjmp(jmp
) == 0) {
404 for (unsigned i
= 0; i
< ARRAY_SIZE(invalid_renderer_indices
); i
++) {
405 unsigned value
= 0xDEADBEEF;
407 glXQueryRendererIntegerMESA(&dpy
, 0,
408 invalid_renderer_indices
[i
],
409 GLX_RENDERER_VENDOR_ID_MESA
,
411 EXPECT_FALSE(success
) << invalid_renderer_indices
[i
];
412 EXPECT_EQ(0xDEADBEEF, value
) << invalid_renderer_indices
[i
];
413 EXPECT_FALSE(query_renderer_integer_called
)
414 << invalid_renderer_indices
[i
];
415 EXPECT_FALSE(query_renderer_string_called
)
416 << invalid_renderer_indices
[i
];
419 EXPECT_FALSE(got_sigsegv
);
424 * glXQueryCurrentRendererIntegerMESA will return error if there is no context
425 * current. It will also not segfault.
427 TEST_F(query_renderer_integer_test
, no_current_context
)
429 if (setjmp(jmp
) == 0) {
430 unsigned value
= 0xDEADBEEF;
432 glXQueryCurrentRendererIntegerMESA(GLX_RENDERER_VENDOR_ID_MESA
,
434 EXPECT_FALSE(success
);
435 EXPECT_EQ(0xDEADBEEF, value
);
437 EXPECT_FALSE(got_sigsegv
);