/* -*- Mode: C; c-basic-offset: 2; -*- */ /* GdkPixbuf library - test loaders * * Copyright (C) 2013 Red Hat, Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see . * * Author: Matthias Clasen */ #include "config.h" #include "gdk-pixbuf/gdk-pixbuf.h" #include "test-common.h" #include #define compare_option(p1, p2, key) \ g_strcmp0 (gdk_pixbuf_get_option (p1, key), gdk_pixbuf_get_option (p2, key)) static gboolean pixbuf_equal (GdkPixbuf *p1, GdkPixbuf *p2) { if (gdk_pixbuf_get_colorspace (p1) != gdk_pixbuf_get_colorspace (p2)) return FALSE; if (gdk_pixbuf_get_n_channels (p1) != gdk_pixbuf_get_n_channels (p2)) return FALSE; if (gdk_pixbuf_get_bits_per_sample (p1) != gdk_pixbuf_get_bits_per_sample (p2)) return FALSE; if (gdk_pixbuf_get_width (p1) != gdk_pixbuf_get_width (p2)) return FALSE; if (gdk_pixbuf_get_height (p1) != gdk_pixbuf_get_height (p2)) return FALSE; if (gdk_pixbuf_get_rowstride (p1) != gdk_pixbuf_get_rowstride (p2)) return FALSE; if (memcmp (gdk_pixbuf_get_pixels (p1), gdk_pixbuf_get_pixels (p2), gdk_pixbuf_get_byte_length (p1)) != 0) return FALSE; if (compare_option (p1, p2, "Title") != 0) return FALSE; if (compare_option (p1, p2, "Artist") != 0) return FALSE; if (compare_option (p1, p2, "x_hot") != 0) return FALSE; if (compare_option (p1, p2, "y_hot") != 0) return FALSE; if (compare_option (p1, p2, "orientation") != 0) return FALSE; if (compare_option (p1, p2, "icc-profile") != 0) return FALSE; return TRUE; } static void test_stream (gconstpointer data) { const gchar *filename = data; const gchar *path; GError *error = NULL; GdkPixbuf *pixbuf, *ref; GFile *file; GInputStream *stream; if (!format_supported (filename)) { g_test_skip ("format not supported"); return; } path = g_test_get_filename (G_TEST_DIST, filename, NULL); ref = gdk_pixbuf_new_from_file (path, &error); g_assert_no_error (error); file = g_file_new_for_path (path); stream = (GInputStream *)g_file_read (file, NULL, &error); g_assert_no_error (error); pixbuf = gdk_pixbuf_new_from_stream (stream, NULL, &error); g_assert_no_error (error); g_assert (pixbuf_equal (pixbuf, ref)); g_object_unref (pixbuf); g_object_unref (stream); g_object_unref (file); g_object_unref (ref); } static void async_done_cb (GObject *source, GAsyncResult *res, gpointer data) { GdkPixbuf *ref = data; GdkPixbuf *pixbuf; GError *error = NULL; pixbuf = gdk_pixbuf_new_from_stream_finish (res, &error); g_assert_no_error (error); g_assert (pixbuf_equal (pixbuf, ref)); g_object_unref (pixbuf); g_object_unref (ref); } static void test_stream_async (gconstpointer data) { const gchar *filename = data; const gchar *path; GError *error = NULL; GdkPixbuf *ref; gchar *buffer; gsize size; GInputStream *stream; if (!format_supported (filename)) { g_test_skip ("format not supported"); return; } path = g_test_get_filename (G_TEST_DIST, filename, NULL); ref = gdk_pixbuf_new_from_file (path, &error); g_assert_no_error (error); g_file_get_contents (path, &buffer, &size, &error); g_assert_no_error (error); stream = g_memory_input_stream_new_from_data (buffer, size, g_free); gdk_pixbuf_new_from_stream_async (stream, NULL, async_done_cb, ref); g_object_unref (stream); } static void test_stream_at_scale (gconstpointer data) { const gchar *filename = data; const gchar *path; GError *error = NULL; GdkPixbuf *pixbuf, *ref; GFile *file; GInputStream *stream; if (!format_supported (filename)) { g_test_skip ("format not supported"); return; } path = g_test_get_filename (G_TEST_DIST, filename, NULL); ref = gdk_pixbuf_new_from_file_at_scale (path, 20, 30, TRUE, &error); g_assert_no_error (error); file = g_file_new_for_path (path); stream = (GInputStream *)g_file_read (file, NULL, &error); g_assert_no_error (error); pixbuf = gdk_pixbuf_new_from_stream_at_scale (stream, 20, 30, TRUE, NULL, &error); g_assert_no_error (error); g_assert (pixbuf_equal (pixbuf, ref)); g_object_unref (pixbuf); g_object_unref (stream); g_object_unref (file); g_object_unref (ref); } static void test_stream_at_scale_async (gconstpointer data) { const gchar *filename = data; const gchar *path; GError *error = NULL; GdkPixbuf *ref; gchar *buffer; gsize size; GInputStream *stream; if (!format_supported (filename)) { g_test_skip ("format not supported"); return; } path = g_test_get_filename (G_TEST_DIST, filename, NULL); ref = gdk_pixbuf_new_from_file_at_scale (path, 40, 10, FALSE, &error); g_assert_no_error (error); g_file_get_contents (path, &buffer, &size, &error); g_assert_no_error (error); stream = g_memory_input_stream_new_from_data (buffer, size, g_free); gdk_pixbuf_new_from_stream_at_scale_async (stream, 40, 10, FALSE, NULL, async_done_cb, ref); g_object_unref (stream); } int main (int argc, char **argv) { g_test_init (&argc, &argv, NULL); g_test_add_data_func ("/pixbuf/stream", "icc-profile.png", test_stream); g_test_add_data_func ("/pixbuf/stream/async", "icc-profile.png", test_stream_async); g_test_add_data_func ("/pixbuf/stream/scale", "icc-profile.png", test_stream_at_scale); g_test_add_data_func ("/pixbuf/stream/scale/async", "icc-profile.png", test_stream_at_scale_async); return g_test_run (); }