mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-05 02:11:08 +00:00
Merge branch 'matthiasc/for-main' into 'main'
testsuite: Add some GL texture tests See merge request GNOME/gtk!5715
This commit is contained in:
commit
1ba5ea60cb
@ -14,7 +14,7 @@ test_allowed_backends (gconstpointer data)
|
||||
GdkGLAPI allowed = GPOINTER_TO_SIZE (data);
|
||||
GdkGLAPI not_allowed = (~allowed) & ALL_APIS;
|
||||
GdkGLAPI api, random_apis;
|
||||
GdkDisplay *display = gdk_display_get_default ();
|
||||
GdkDisplay *display;
|
||||
GdkGLContext *context;
|
||||
GError *error = NULL;
|
||||
|
||||
@ -28,7 +28,7 @@ test_allowed_backends (gconstpointer data)
|
||||
}
|
||||
|
||||
context = gdk_display_create_gl_context (display, &error);
|
||||
g_assert (context);
|
||||
g_assert_nonnull (context);
|
||||
g_assert_no_error (error);
|
||||
g_assert_cmpint (gdk_gl_context_get_api (context), ==, 0);
|
||||
g_assert_cmpint (gdk_gl_context_get_allowed_apis (context), ==, ALL_APIS);
|
||||
|
128
testsuite/gdk/gltexture.c
Normal file
128
testsuite/gdk/gltexture.c
Normal file
@ -0,0 +1,128 @@
|
||||
#include <gtk/gtk.h>
|
||||
#include <epoxy/gl.h>
|
||||
|
||||
static cairo_surface_t *
|
||||
make_surface (void)
|
||||
{
|
||||
cairo_surface_t *surface;
|
||||
cairo_t *cr;
|
||||
guchar *data;
|
||||
|
||||
data = g_malloc (64 * 64 * 4);
|
||||
surface = cairo_image_surface_create_for_data (data,
|
||||
CAIRO_FORMAT_ARGB32,
|
||||
64, 64, 64 * 4);
|
||||
cr = cairo_create (surface);
|
||||
cairo_set_source_rgb (cr, 1, 0, 0);
|
||||
cairo_paint (cr);
|
||||
cairo_destroy (cr);
|
||||
|
||||
return surface;
|
||||
}
|
||||
|
||||
enum {
|
||||
SAME_CONTEXT,
|
||||
NO_CONTEXT,
|
||||
SHARED_CONTEXT
|
||||
};
|
||||
|
||||
static void
|
||||
test_gltexture (int test)
|
||||
{
|
||||
GdkDisplay *display;
|
||||
GdkGLContext *context;
|
||||
GdkGLContext *context2 = NULL;
|
||||
GdkTexture *texture;
|
||||
cairo_surface_t *surface;
|
||||
GError *error = NULL;
|
||||
unsigned int id;
|
||||
guchar *data;
|
||||
|
||||
display = gdk_display_get_default ();
|
||||
if (!gdk_display_prepare_gl (display, &error))
|
||||
{
|
||||
g_test_message ("no GL support: %s", error->message);
|
||||
g_test_skip ("no GL support");
|
||||
g_clear_error (&error);
|
||||
return;
|
||||
}
|
||||
|
||||
context = gdk_display_create_gl_context (display, &error);
|
||||
g_assert_nonnull (context);
|
||||
g_assert_no_error (error);
|
||||
|
||||
gdk_gl_context_realize (context, &error);
|
||||
g_assert_no_error (error);
|
||||
|
||||
surface = make_surface ();
|
||||
|
||||
gdk_gl_context_make_current (context);
|
||||
|
||||
glGenTextures (1, &id);
|
||||
glActiveTexture (GL_TEXTURE0);
|
||||
glBindTexture (GL_TEXTURE_2D, id);
|
||||
glTexImage2D (GL_TEXTURE_2D, 0, GL_RGBA8, 64, 64, 0, GL_BGRA, GL_UNSIGNED_BYTE,
|
||||
cairo_image_surface_get_data (surface));
|
||||
|
||||
g_assert_true (glGetError () == GL_NO_ERROR);
|
||||
|
||||
if (test == NO_CONTEXT)
|
||||
gdk_gl_context_clear_current ();
|
||||
else if (test == SHARED_CONTEXT)
|
||||
{
|
||||
context2 = gdk_display_create_gl_context (display, &error);
|
||||
g_assert_nonnull (context2);
|
||||
g_assert_no_error (error);
|
||||
|
||||
gdk_gl_context_realize (context2, &error);
|
||||
g_assert_no_error (error);
|
||||
|
||||
gdk_gl_context_make_current (context2);
|
||||
}
|
||||
|
||||
texture = gdk_gl_texture_new (context, id, 64, 64, NULL, NULL);
|
||||
|
||||
data = g_malloc0 (64 * 64 * 4);
|
||||
gdk_texture_download (texture, data, 64 * 4);
|
||||
|
||||
g_assert_true (memcmp (data, cairo_image_surface_get_data (surface), 64 * 64 * 4) == 0);
|
||||
|
||||
g_free (data);
|
||||
g_object_unref (texture);
|
||||
|
||||
cairo_surface_destroy (surface);
|
||||
|
||||
g_object_unref (context);
|
||||
|
||||
g_clear_object (&context2);
|
||||
}
|
||||
|
||||
static void
|
||||
test_gltexture_same_context (void)
|
||||
{
|
||||
test_gltexture (SAME_CONTEXT);
|
||||
}
|
||||
|
||||
static void
|
||||
test_gltexture_no_context (void)
|
||||
{
|
||||
test_gltexture (NO_CONTEXT);
|
||||
}
|
||||
|
||||
static void
|
||||
test_gltexture_shared_context (void)
|
||||
{
|
||||
test_gltexture (SHARED_CONTEXT);
|
||||
}
|
||||
|
||||
int
|
||||
main (int argc, char *argv[])
|
||||
{
|
||||
gtk_test_init (&argc, &argv, NULL);
|
||||
|
||||
g_test_add_func ("/gltexture/same-context", test_gltexture_same_context);
|
||||
g_test_add_func ("/gltexture/no-context", test_gltexture_no_context);
|
||||
g_test_add_func ("/gltexture/shared-context", test_gltexture_shared_context);
|
||||
|
||||
return g_test_run ();
|
||||
}
|
@ -17,6 +17,7 @@ tests = [
|
||||
{ 'name': 'displaymanager' },
|
||||
{ 'name': 'encoding' },
|
||||
{ 'name': 'glcontext' },
|
||||
{ 'name': 'gltexture' },
|
||||
{ 'name': 'keysyms' },
|
||||
{ 'name': 'memorytexture' },
|
||||
{ 'name': 'rectangle' },
|
||||
|
Loading…
Reference in New Issue
Block a user