/* GStreamer * * unit tests for the navigation interface library * * Copyright (C) 2009 Jan Schmidt <thaytan@noraisin.net> * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include <gst/check/gstcheck.h> #include <gst/interfaces/navigation.h> #include <string.h> #define TEST_ELEMENT_TYPE (test_element_get_type()) typedef struct TestElement TestElement; typedef struct TestElementClass TestElementClass; struct TestElement { GstElement parent; GstNavigationEventType sent_type; const gchar *sent_key; gdouble sent_x, sent_y; gint sent_button; GstNavigationCommand sent_command; }; struct TestElementClass { GstElementClass parent_class; }; static void init_interface (GType type); static void gst_implements_interface_init (GstImplementsInterfaceClass * klass); static void nav_send_event (GstNavigation * navigation, GstStructure * structure); GST_BOILERPLATE_FULL (TestElement, test_element, GstElement, GST_TYPE_ELEMENT, init_interface); static void test_element_navigation_interface_init (GstNavigationInterface * klass) { klass->send_event = nav_send_event; } static void init_interface (GType type) { static const GInterfaceInfo navigation_iface_info = { (GInterfaceInitFunc) test_element_navigation_interface_init, NULL, NULL, }; static const GInterfaceInfo implements_iface_info = { (GInterfaceInitFunc) gst_implements_interface_init, NULL, NULL, }; g_type_add_interface_static (type, GST_TYPE_IMPLEMENTS_INTERFACE, &implements_iface_info); g_type_add_interface_static (type, GST_TYPE_NAVIGATION, &navigation_iface_info); } static void test_element_base_init (gpointer klass) { } static void test_element_class_init (TestElementClass * klass) { } static gboolean test_element_interface_supported (GstImplementsInterface * ifacE, GType interface_type) { if (interface_type == GST_TYPE_NAVIGATION) return TRUE; return FALSE; } static void gst_implements_interface_init (GstImplementsInterfaceClass * klass) { klass->supported = test_element_interface_supported; } static void test_element_init (TestElement * this, TestElementClass * klass) { } static void nav_send_event (GstNavigation * navigation, GstStructure * structure) { GstEvent *event = gst_event_new_navigation (structure); GstNavigationEventType etype = gst_navigation_event_get_type (event); TestElement *self = (TestElement *) (navigation); fail_if (etype == GST_NAVIGATION_EVENT_INVALID, "Received navigation event could not be parsed"); fail_unless (etype == self->sent_type, "Received navigation event did not match sent"); switch (etype) { case GST_NAVIGATION_EVENT_KEY_PRESS: case GST_NAVIGATION_EVENT_KEY_RELEASE:{ const gchar *key; fail_unless (gst_navigation_event_parse_key_event (event, &key)); fail_unless (strcmp (key, self->sent_key) == 0); break; } case GST_NAVIGATION_EVENT_MOUSE_BUTTON_PRESS: case GST_NAVIGATION_EVENT_MOUSE_BUTTON_RELEASE:{ gint button; gdouble x, y; fail_unless (gst_navigation_event_parse_mouse_button_event (event, &button, &x, &y)); fail_unless (button == self->sent_button); fail_unless (x == self->sent_x); fail_unless (y == self->sent_y); break; } case GST_NAVIGATION_EVENT_MOUSE_MOVE:{ gdouble x, y; fail_unless (gst_navigation_event_parse_mouse_move_event (event, &x, &y)); fail_unless (x == self->sent_x); fail_unless (y == self->sent_y); break; } case GST_NAVIGATION_EVENT_COMMAND:{ GstNavigationCommand cmd; fail_unless (gst_navigation_event_parse_command (event, &cmd)); fail_unless (cmd == self->sent_command); } default: break; } gst_event_unref (event); } GST_START_TEST (test_events) { /* Create an empty GstElement that has a GstNavigation interface and then * send some navigation events and validate them */ TestElement *test_element = (TestElement *) g_object_new (TEST_ELEMENT_TYPE, NULL); GstNavigationCommand cmds[] = { GST_NAVIGATION_COMMAND_MENU1, GST_NAVIGATION_COMMAND_MENU2, GST_NAVIGATION_COMMAND_MENU3, GST_NAVIGATION_COMMAND_MENU4, GST_NAVIGATION_COMMAND_MENU5, GST_NAVIGATION_COMMAND_MENU6, GST_NAVIGATION_COMMAND_MENU7, GST_NAVIGATION_COMMAND_LEFT, GST_NAVIGATION_COMMAND_RIGHT, GST_NAVIGATION_COMMAND_UP, GST_NAVIGATION_COMMAND_DOWN, GST_NAVIGATION_COMMAND_ACTIVATE, GST_NAVIGATION_COMMAND_PREV_ANGLE, GST_NAVIGATION_COMMAND_NEXT_ANGLE }; gint i; test_element->sent_type = GST_NAVIGATION_EVENT_KEY_PRESS; test_element->sent_key = "1"; gst_navigation_send_key_event (GST_NAVIGATION (test_element), "key-press", "1"); test_element->sent_type = GST_NAVIGATION_EVENT_KEY_RELEASE; test_element->sent_key = "2"; gst_navigation_send_key_event (GST_NAVIGATION (test_element), "key-release", "2"); test_element->sent_type = GST_NAVIGATION_EVENT_MOUSE_MOVE; test_element->sent_x = 50; test_element->sent_y = 100; gst_navigation_send_mouse_event (GST_NAVIGATION (test_element), "mouse-move", 0, 50, 100); test_element->sent_type = GST_NAVIGATION_EVENT_MOUSE_BUTTON_PRESS; test_element->sent_x = 10; test_element->sent_y = 20; test_element->sent_button = 1; gst_navigation_send_mouse_event (GST_NAVIGATION (test_element), "mouse-button-press", 1, 10, 20); for (i = 0; i < G_N_ELEMENTS (cmds); i++) { test_element->sent_type = GST_NAVIGATION_EVENT_COMMAND; test_element->sent_command = cmds[i]; gst_navigation_send_command (GST_NAVIGATION (test_element), cmds[i]); } gst_object_unref (test_element); } GST_END_TEST; GST_START_TEST (test_messages) { GstMessage *m; /* GST_NAVIGATION_MESSAGE_MOUSE_OVER */ { gboolean active; m = gst_navigation_message_new_mouse_over (NULL, TRUE); fail_if (m == NULL); fail_unless (gst_navigation_message_get_type (m) == GST_NAVIGATION_MESSAGE_MOUSE_OVER); fail_unless (GST_MESSAGE_SRC (m) == NULL); fail_unless (gst_navigation_message_parse_mouse_over (m, &active)); fail_unless (active == TRUE); gst_message_unref (m); m = gst_navigation_message_new_mouse_over (NULL, FALSE); fail_if (m == NULL); fail_unless (GST_MESSAGE_SRC (m) == NULL); fail_unless (gst_navigation_message_get_type (m) == GST_NAVIGATION_MESSAGE_MOUSE_OVER); fail_unless (gst_navigation_message_parse_mouse_over (m, &active)); fail_unless (active == FALSE); gst_message_unref (m); } /* GST_NAVIGATION_MESSAGE_COMMANDS_CHANGED */ { m = gst_navigation_message_new_commands_changed (NULL); fail_if (m == NULL); fail_unless (GST_MESSAGE_SRC (m) == NULL); fail_unless (gst_navigation_message_get_type (m) == GST_NAVIGATION_MESSAGE_COMMANDS_CHANGED); gst_message_unref (m); } /* GST_NAVIGATION_MESSAGE_ANGLES_CHANGED */ { guint angle, angles; m = gst_navigation_message_new_angles_changed (NULL, 1, 5); fail_if (m == NULL); fail_unless (GST_MESSAGE_SRC (m) == NULL); fail_unless (gst_navigation_message_get_type (m) == GST_NAVIGATION_MESSAGE_ANGLES_CHANGED); fail_unless (gst_navigation_message_parse_angles_changed (m, &angle, &angles)); fail_unless (angle == 1); fail_unless (angles == 5); gst_message_unref (m); } } GST_END_TEST; GST_START_TEST (test_queries) { GstQuery *q; /* GST_NAVIGATION_QUERY_COMMANDS */ { guint n; GstNavigationCommand cmd; q = gst_navigation_query_new_commands (); fail_unless (q != NULL); fail_unless (gst_navigation_query_get_type (q) == GST_NAVIGATION_QUERY_COMMANDS); gst_navigation_query_set_commands (q, 3, GST_NAVIGATION_COMMAND_LEFT, GST_NAVIGATION_COMMAND_MENU1, GST_NAVIGATION_COMMAND_MENU5); fail_unless (gst_navigation_query_parse_commands_length (q, &n)); fail_unless (n == 3); fail_unless (gst_navigation_query_parse_commands_nth (q, 1, &cmd)); fail_unless (cmd == GST_NAVIGATION_COMMAND_MENU1); fail_unless (gst_navigation_query_parse_commands_length (q, NULL)); fail_unless (gst_navigation_query_parse_commands_nth (q, 2, NULL)); gst_query_unref (q); } /* GST_NAVIGATION_QUERY_ANGLES */ { guint angle, angles; q = gst_navigation_query_new_angles (); fail_unless (q != NULL); fail_unless (gst_navigation_query_get_type (q) == GST_NAVIGATION_QUERY_ANGLES); gst_navigation_query_set_angles (q, 4, 8); fail_unless (gst_navigation_query_parse_angles (q, &angle, &angles)); fail_unless (angle == 4); fail_unless (angles == 8); fail_unless (gst_navigation_query_parse_angles (q, NULL, &angles)); fail_unless (gst_navigation_query_parse_angles (q, &angle, NULL)); fail_unless (gst_navigation_query_parse_angles (q, NULL, NULL)); gst_query_unref (q); } } GST_END_TEST; static Suite * navigation_suite (void) { Suite *s = suite_create ("navigation interface"); TCase *tc_chain = tcase_create ("notifications"); suite_add_tcase (s, tc_chain); tcase_add_test (tc_chain, test_events); tcase_add_test (tc_chain, test_messages); tcase_add_test (tc_chain, test_queries); return s; } int main (int argc, char **argv) { int nf; Suite *s = navigation_suite (); SRunner *sr = srunner_create (s); gst_check_init (&argc, &argv); srunner_run_all (sr, CK_NORMAL); nf = srunner_ntests_failed (sr); srunner_free (sr); return nf; }