summaryrefslogtreecommitdiffstats
path: root/tests/glx/clientinfo_unittest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/glx/clientinfo_unittest.cpp')
-rw-r--r--tests/glx/clientinfo_unittest.cpp723
1 files changed, 0 insertions, 723 deletions
diff --git a/tests/glx/clientinfo_unittest.cpp b/tests/glx/clientinfo_unittest.cpp
deleted file mode 100644
index f599c833a66..00000000000
--- a/tests/glx/clientinfo_unittest.cpp
+++ /dev/null
@@ -1,723 +0,0 @@
-/*
- * Copyright © 2011 Intel Corporation
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice (including the next
- * paragraph) shall be included in all copies or substantial portions of the
- * Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- */
-#include <gtest/gtest.h>
-#include <string.h>
-
-extern "C" {
-#include "glxclient.h"
-}
-
-#include <xcb/glx.h>
-
-#include "mock_xdisplay.h"
-#include "fake_glx_screen.h"
-
-/**
- * \name Wrappers around some X structures to make the more usable for tests
- */
-/*@{*/
-class fake_glx_screen;
-
-class fake_glx_display : public glx_display {
-public:
- fake_glx_display(mock_XDisplay *dpy, int major, int minor)
- {
- this->next = 0;
- this->dpy = dpy;
- this->majorOpcode = 0;
- this->majorVersion = major;
- this->minorVersion = minor;
- this->serverGLXvendor = 0;
- this->serverGLXversion = 0;
- this->glXDrawHash = 0;
-
- this->screens = new glx_screen *[dpy->nscreens];
- memset(this->screens, 0, sizeof(struct glx_screen *) * dpy->nscreens);
- }
-
- ~fake_glx_display()
- {
- for (int i = 0; i < this->dpy->nscreens; i++) {
- if (this->screens[i] != NULL)
- delete this->screens[i];
- }
-
- delete [] this->screens;
- }
-
- void init_screen(int i, const char *ext);
-};
-
-class glX_send_client_info_test : public ::testing::Test {
-public:
- glX_send_client_info_test();
- virtual ~glX_send_client_info_test();
- virtual void SetUp();
-
- void common_protocol_expected_false_test(unsigned major, unsigned minor,
- const char *glx_ext, bool *value);
-
- void common_protocol_expected_true_test(unsigned major, unsigned minor,
- const char *glx_ext, bool *value);
-
- void create_single_screen_display(unsigned major, unsigned minor,
- const char *glx_ext);
-
- void destroy_display();
-
-protected:
- fake_glx_display *glx_dpy;
- mock_XDisplay *display;
-};
-
-void
-fake_glx_display::init_screen(int i, const char *ext)
-{
- if (this->screens[i] != NULL)
- delete this->screens[i];
-
- this->screens[i] = new fake_glx_screen(this, i, ext);
-}
-/*@}*/
-
-static const char ext[] = "GL_XXX_dummy";
-
-static bool ClientInfo_was_sent;
-static bool SetClientInfoARB_was_sent;
-static bool SetClientInfo2ARB_was_sent;
-static xcb_connection_t *connection_used;
-static int gl_ext_length;
-static char *gl_ext_string;
-static int glx_ext_length;
-static char *glx_ext_string;
-static int num_gl_versions;
-static uint32_t *gl_versions;
-static int glx_major;
-static int glx_minor;
-
-extern "C" xcb_connection_t *
-XGetXCBConnection(Display *dpy)
-{
- return (xcb_connection_t *) 0xdeadbeef;
-}
-
-extern "C" xcb_void_cookie_t
-xcb_glx_client_info(xcb_connection_t *c,
- uint32_t major_version,
- uint32_t minor_version,
- uint32_t str_len,
- const char *string)
-{
- xcb_void_cookie_t cookie;
-
- ClientInfo_was_sent = true;
- connection_used = c;
-
- gl_ext_string = (char *) malloc(str_len);
- memcpy(gl_ext_string, string, str_len);
- gl_ext_length = str_len;
-
- glx_major = major_version;
- glx_minor = minor_version;
-
- cookie.sequence = 0;
- return cookie;
-}
-
-extern "C" xcb_void_cookie_t
-xcb_glx_set_client_info_arb(xcb_connection_t *c,
- uint32_t major_version,
- uint32_t minor_version,
- uint32_t num_versions,
- uint32_t gl_str_len,
- uint32_t glx_str_len,
- const uint32_t *versions,
- const char *gl_string,
- const char *glx_string)
-{
- xcb_void_cookie_t cookie;
-
- SetClientInfoARB_was_sent = true;
- connection_used = c;
-
- gl_ext_string = new char[gl_str_len];
- memcpy(gl_ext_string, gl_string, gl_str_len);
- gl_ext_length = gl_str_len;
-
- glx_ext_string = new char[glx_str_len];
- memcpy(glx_ext_string, glx_string, glx_str_len);
- glx_ext_length = glx_str_len;
-
- gl_versions = new uint32_t[num_versions * 2];
- memcpy(gl_versions, versions, sizeof(uint32_t) * num_versions * 2);
- num_gl_versions = num_versions;
-
- glx_major = major_version;
- glx_minor = minor_version;
-
- cookie.sequence = 0;
- return cookie;
-}
-
-extern "C" xcb_void_cookie_t
-xcb_glx_set_client_info_2arb(xcb_connection_t *c,
- uint32_t major_version,
- uint32_t minor_version,
- uint32_t num_versions,
- uint32_t gl_str_len,
- uint32_t glx_str_len,
- const uint32_t *versions,
- const char *gl_string,
- const char *glx_string)
-{
- xcb_void_cookie_t cookie;
-
- SetClientInfo2ARB_was_sent = true;
- connection_used = c;
-
- gl_ext_string = new char[gl_str_len];
- memcpy(gl_ext_string, gl_string, gl_str_len);
- gl_ext_length = gl_str_len;
-
- glx_ext_string = new char[glx_str_len];
- memcpy(glx_ext_string, glx_string, glx_str_len);
- glx_ext_length = glx_str_len;
-
- gl_versions = new uint32_t[num_versions * 3];
- memcpy(gl_versions, versions, sizeof(uint32_t) * num_versions * 3);
- num_gl_versions = num_versions;
-
- glx_major = major_version;
- glx_minor = minor_version;
-
- cookie.sequence = 0;
- return cookie;
-}
-
-extern "C" char *
-__glXGetClientGLExtensionString()
-{
- char *str = (char *) malloc(sizeof(ext));
-
- memcpy(str, ext, sizeof(ext));
- return str;
-}
-
-glX_send_client_info_test::glX_send_client_info_test()
- : glx_dpy(0), display(0)
-{
- /* empty */
-}
-
-glX_send_client_info_test::~glX_send_client_info_test()
-{
- if (glx_dpy)
- delete glx_dpy;
-
- if (display)
- delete display;
-}
-
-void
-glX_send_client_info_test::destroy_display()
-{
- if (this->glx_dpy != NULL) {
- if (this->glx_dpy->screens != NULL) {
- for (int i = 0; i < this->display->nscreens; i++) {
- delete [] this->glx_dpy->screens[i]->serverGLXexts;
- delete this->glx_dpy->screens[i];
- }
-
- delete [] this->glx_dpy->screens;
- }
-
- delete this->glx_dpy;
- delete this->display;
- }
-}
-
-void
-glX_send_client_info_test::SetUp()
-{
- ClientInfo_was_sent = false;
- SetClientInfoARB_was_sent = false;
- SetClientInfo2ARB_was_sent = false;
- connection_used = (xcb_connection_t *) ~0;
- gl_ext_length = 0;
- gl_ext_string = (char *) 0;
- glx_ext_length = 0;
- glx_ext_string = (char *) 0;
- num_gl_versions = 0;
- gl_versions = (uint32_t *) 0;
- glx_major = 0;
- glx_minor = 0;
-}
-
-void
-glX_send_client_info_test::create_single_screen_display(unsigned major,
- unsigned minor,
- const char *glx_ext)
-{
- this->display = new mock_XDisplay(1);
-
- this->glx_dpy = new fake_glx_display(this->display, major, minor);
- this->glx_dpy->init_screen(0, glx_ext);
-}
-
-void
-glX_send_client_info_test::common_protocol_expected_false_test(unsigned major,
- unsigned minor,
- const char *glx_ext,
- bool *value)
-{
- create_single_screen_display(major, minor, glx_ext);
- __glX_send_client_info(this->glx_dpy);
- EXPECT_FALSE(*value);
-}
-
-void
-glX_send_client_info_test::common_protocol_expected_true_test(unsigned major,
- unsigned minor,
- const char *glx_ext,
- bool *value)
-{
- create_single_screen_display(major, minor, glx_ext);
- __glX_send_client_info(this->glx_dpy);
- EXPECT_TRUE(*value);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_ClientInfo_for_1_0)
-{
- /* The glXClientInfo protocol was added in GLX 1.1. Verify that no
- * glXClientInfo is sent to a GLX server that only has GLX 1.0.
- */
- common_protocol_expected_false_test(1, 0, "", &ClientInfo_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfoARB_for_1_0)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that no glXSetClientInfoARB is
- * sent to a GLX server that only has GLX 1.0 regardless of the extension
- * setting.
- */
- common_protocol_expected_false_test(1, 0,
- "GLX_ARB_create_context",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfoARB_for_1_1)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that no glXSetClientInfoARB is
- * sent to a GLX server that only has GLX 1.0 regardless of the extension
- * setting.
- */
- common_protocol_expected_false_test(1, 1,
- "GLX_ARB_create_context",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfoARB_for_1_4_with_empty_extensions)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that no glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 but has an empty extension string
- * (i.e., no extensions at all).
- */
- common_protocol_expected_false_test(1, 4,
- "",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfoARB_for_1_4_without_extension)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that no glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 but doesn't have the extension.
- */
- common_protocol_expected_false_test(1, 4,
- "GLX_EXT_texture_from_pixmap",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfoARB_for_1_4_with_wrong_extension)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that no glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 but does not have the extension.
- *
- * This test differs from
- * doesnt_send_SetClientInfoARB_for_1_4_without_extension in that an
- * extension exists that looks like the correct extension but isn't.
- */
- common_protocol_expected_false_test(1, 4,
- "GLX_ARB_create_context2",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfoARB_for_1_4_with_profile_extension)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that no glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 but does not have the extension.
- *
- * This test differs from
- * doesnt_send_SetClientInfoARB_for_1_4_without_extension in that an
- * extension exists that looks like the correct extension but isn't.
- */
- common_protocol_expected_false_test(1, 4,
- "GLX_ARB_create_context_profile",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfo2ARB_for_1_0)
-{
- /* The glXSetClientInfo2ARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context_profile extension. Verify that no
- * glXSetClientInfo2ARB is sent to a GLX server that only has GLX 1.0
- * regardless of the extension setting.
- */
- common_protocol_expected_false_test(1, 0,
- "GLX_ARB_create_context_profile",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfo2ARB_for_1_1)
-{
- /* The glXSetClientInfo2ARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context_profile extension. Verify that no
- * glXSetClientInfo2ARB is sent to a GLX server that only has GLX 1.1
- * regardless of the extension setting.
- */
- common_protocol_expected_false_test(1, 1,
- "GLX_ARB_create_context_profile",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfo2ARB_for_1_4_with_empty_extensions)
-{
- /* The glXSetClientInfo2ARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context_profile extension. Verify that no
- * glXSetClientInfo2ARB is sent to a GLX server that has GLX 1.4 but has an
- * empty extension string (i.e., no extensions at all).
- */
- common_protocol_expected_false_test(1, 4,
- "",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfo2ARB_for_1_4_without_extension)
-{
- /* The glXSetClientInfo2ARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context_profile extension. Verify that no
- * glXSetClientInfo2ARB is sent to a GLX server that has GLX 1.4 but
- * doesn't have the extension.
- */
- common_protocol_expected_false_test(1, 4,
- "GLX_EXT_texture_from_pixmap",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, doesnt_send_SetClientInfo2ARB_for_1_4_with_wrong_extension)
-{
- /* The glXSetClientInfo2ARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context_profile extension. Verify that no
- * glXSetClientInfo2ARB is sent to a GLX server that has GLX 1.4 but does
- * not have the extension.
- *
- * This test differs from
- * doesnt_send_SetClientInfo2ARB_for_1_4_without_extension in that an
- * extension exists that looks like the correct extension but isn't.
- */
- common_protocol_expected_false_test(1, 4,
- "GLX_ARB_create_context_profile2",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, does_send_ClientInfo_for_1_1)
-{
- /* The glXClientInfo protocol was added in GLX 1.1. Verify that
- * glXClientInfo is sent to a GLX server that has GLX 1.1.
- */
- common_protocol_expected_true_test(1, 1,
- "",
- &ClientInfo_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, does_send_SetClientInfoARB_for_1_4_with_extension)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 and the extension.
- */
- common_protocol_expected_true_test(1, 4,
- "GLX_ARB_create_context",
- &SetClientInfoARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, does_send_SetClientInfo2ARB_for_1_4_with_just_profile_extension)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 and the extension.
- */
- common_protocol_expected_true_test(1, 4,
- "GLX_ARB_create_context_profile",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, does_send_SetClientInfo2ARB_for_1_4_with_both_extensions)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 and the extension.
- */
- common_protocol_expected_true_test(1, 4,
- "GLX_ARB_create_context "
- "GLX_ARB_create_context_profile",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, does_send_SetClientInfo2ARB_for_1_4_with_both_extensions_reversed)
-{
- /* The glXSetClientInfoARB protocol was added in GLX 1.4 with the
- * GLX_ARB_create_context extension. Verify that glXSetClientInfoARB is
- * sent to a GLX server that has GLX 1.4 and the extension.
- */
- common_protocol_expected_true_test(1, 4,
- "GLX_ARB_create_context_profile "
- "GLX_ARB_create_context",
- &SetClientInfo2ARB_was_sent);
-}
-
-TEST_F(glX_send_client_info_test, uses_correct_connection)
-{
- create_single_screen_display(1, 1, "");
- __glX_send_client_info(this->glx_dpy);
- EXPECT_EQ((xcb_connection_t *) 0xdeadbeef, connection_used);
-}
-
-TEST_F(glX_send_client_info_test, sends_correct_gl_extension_string)
-{
- create_single_screen_display(1, 1, "");
- __glX_send_client_info(this->glx_dpy);
-
- ASSERT_EQ(sizeof(ext), gl_ext_length);
- ASSERT_NE((char *) 0, gl_ext_string);
- EXPECT_EQ(0, memcmp(gl_ext_string, ext, sizeof(ext)));
-}
-
-TEST_F(glX_send_client_info_test, gl_versions_are_sane)
-{
- create_single_screen_display(1, 4, "GLX_ARB_create_context");
- __glX_send_client_info(this->glx_dpy);
-
- ASSERT_NE(0, num_gl_versions);
-
- unsigned versions_below_3_0 = 0;
- for (int i = 0; i < num_gl_versions; i++) {
- EXPECT_LT(0, gl_versions[i * 2]);
- EXPECT_GE(4, gl_versions[i * 2]);
-
- /* Verify that the minor version advertised with the major version makes
- * sense.
- */
- switch (gl_versions[i * 2]) {
- case 1:
- EXPECT_GE(5, gl_versions[i * 2 + 1]);
- versions_below_3_0++;
- break;
- case 2:
- EXPECT_GE(1, gl_versions[i * 2 + 1]);
- versions_below_3_0++;
- break;
- case 3:
- EXPECT_GE(3, gl_versions[i * 2 + 1]);
- break;
- case 4:
- EXPECT_GE(2, gl_versions[i * 2 + 1]);
- break;
- }
- }
-
- /* From the GLX_ARB_create_context spec:
- *
- * "Only the highest supported version below 3.0 should be sent, since
- * OpenGL 2.1 is backwards compatible with all earlier versions."
- */
- EXPECT_LE(versions_below_3_0, 1);
-}
-
-TEST_F(glX_send_client_info_test, gl_versions_and_profiles_are_sane)
-{
- create_single_screen_display(1, 4, "GLX_ARB_create_context_profile");
- __glX_send_client_info(this->glx_dpy);
-
- ASSERT_NE(0, num_gl_versions);
-
- const uint32_t all_valid_bits = GLX_CONTEXT_CORE_PROFILE_BIT_ARB
- | GLX_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB;
-
- unsigned versions_below_3_0 = 0;
-
- for (int i = 0; i < num_gl_versions; i++) {
- EXPECT_LT(0, gl_versions[i * 3]);
- EXPECT_GE(4, gl_versions[i * 3]);
-
- /* Verify that the minor version advertised with the major version makes
- * sense.
- */
- switch (gl_versions[i * 3]) {
- case 1:
- EXPECT_GE(5, gl_versions[i * 3 + 1]);
- EXPECT_EQ(0, gl_versions[i * 3 + 2]);
- versions_below_3_0++;
- break;
- case 2:
- EXPECT_GE(1, gl_versions[i * 3 + 1]);
- EXPECT_EQ(0, gl_versions[i * 3 + 2]);
- versions_below_3_0++;
- break;
- case 3:
- EXPECT_GE(3, gl_versions[i * 3 + 1]);
-
- /* Profiles were not introduced until OpenGL 3.2.
- */
- if (gl_versions[i * 3 + 1] < 2) {
- EXPECT_EQ(0, gl_versions[i * 3 + 2]);
- } else {
- EXPECT_EQ(0, gl_versions[i * 3 + 2] & ~all_valid_bits);
- }
- break;
- case 4:
- EXPECT_GE(2, gl_versions[i * 3 + 1]);
- EXPECT_EQ(0, gl_versions[i * 3 + 2] & ~all_valid_bits);
- break;
- }
- }
-
- /* From the GLX_ARB_create_context_profile spec:
- *
- * "Only the highest supported version below 3.0 should be sent, since
- * OpenGL 2.1 is backwards compatible with all earlier versions."
- */
- EXPECT_LE(versions_below_3_0, 1);
-}
-
-TEST_F(glX_send_client_info_test, glx_version_is_1_4_for_1_1)
-{
- create_single_screen_display(1, 1, "");
- __glX_send_client_info(this->glx_dpy);
-
- EXPECT_EQ(1, glx_major);
- EXPECT_EQ(4, glx_minor);
-}
-
-TEST_F(glX_send_client_info_test, glx_version_is_1_4_for_1_4)
-{
- create_single_screen_display(1, 4, "");
- __glX_send_client_info(this->glx_dpy);
-
- EXPECT_EQ(1, glx_major);
- EXPECT_EQ(4, glx_minor);
-}
-
-TEST_F(glX_send_client_info_test, glx_version_is_1_4_for_1_4_with_ARB_create_context)
-{
- create_single_screen_display(1, 4, "GLX_ARB_create_context");
- __glX_send_client_info(this->glx_dpy);
-
- EXPECT_EQ(1, glx_major);
- EXPECT_EQ(4, glx_minor);
-}
-
-TEST_F(glX_send_client_info_test, glx_version_is_1_4_for_1_4_with_ARB_create_context_profile)
-{
- create_single_screen_display(1, 4, "GLX_ARB_create_context_profile");
- __glX_send_client_info(this->glx_dpy);
-
- EXPECT_EQ(1, glx_major);
- EXPECT_EQ(4, glx_minor);
-}
-
-TEST_F(glX_send_client_info_test, glx_version_is_1_4_for_1_5)
-{
- create_single_screen_display(1, 5, "");
- __glX_send_client_info(this->glx_dpy);
-
- EXPECT_EQ(1, glx_major);
- EXPECT_EQ(4, glx_minor);
-}
-
-TEST_F(glX_send_client_info_test, glx_extensions_has_GLX_ARB_create_context)
-{
- create_single_screen_display(1, 4, "GLX_ARB_create_context");
- __glX_send_client_info(this->glx_dpy);
-
- ASSERT_NE(0, glx_ext_length);
- ASSERT_NE((char *) 0, glx_ext_string);
-
- bool found_GLX_ARB_create_context = false;
- const char *const needle = "GLX_ARB_create_context";
- const unsigned len = strlen(needle);
- char *haystack = glx_ext_string;
- while (haystack != NULL) {
- char *match = strstr(haystack, needle);
-
- if (match[len] == '\0' || match[len] == ' ') {
- found_GLX_ARB_create_context = true;
- break;
- }
-
- haystack = match + len;
- }
-
- EXPECT_TRUE(found_GLX_ARB_create_context);
-}
-
-TEST_F(glX_send_client_info_test, glx_extensions_has_GLX_ARB_create_context_profile)
-{
- create_single_screen_display(1, 4, "GLX_ARB_create_context_profile");
- __glX_send_client_info(this->glx_dpy);
-
- ASSERT_NE(0, glx_ext_length);
- ASSERT_NE((char *) 0, glx_ext_string);
-
- bool found_GLX_ARB_create_context_profile = false;
- const char *const needle = "GLX_ARB_create_context_profile";
- const unsigned len = strlen(needle);
- char *haystack = glx_ext_string;
- while (haystack != NULL) {
- char *match = strstr(haystack, needle);
-
- if (match[len] == '\0' || match[len] == ' ') {
- found_GLX_ARB_create_context_profile = true;
- break;
- }
-
- haystack = match + len;
- }
-
- EXPECT_TRUE(found_GLX_ARB_create_context_profile);
-}