From fcaf46b0134e54942503b27ef9c9b634ce97d17a Mon Sep 17 00:00:00 2001 From: Edward Hervey Date: Fri, 5 Mar 2010 15:50:49 +0100 Subject: [PATCH] check: Add a test for checking timelinefilesource properties This include the mute feature --- tests/check/ges/filesource.c | 79 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) diff --git a/tests/check/ges/filesource.c b/tests/check/ges/filesource.c index 634c16b..7c100be 100644 --- a/tests/check/ges/filesource.c +++ b/tests/check/ges/filesource.c @@ -62,6 +62,84 @@ GST_START_TEST (test_filesource_basic) GST_END_TEST; +#define gnl_object_check(gnlobj, start, duration, mstart, mduration, priority, active) { \ + guint64 pstart, pdur, pmstart, pmdur, pprio, pact; \ + g_object_get (gnlobj, "start", &pstart, "duration", &pdur, \ + "media-start", &pmstart, "media-duration", &pmdur, \ + "priority", &pprio, "active", &pact, \ + NULL); \ + assert_equals_uint64 (pstart, start); \ + assert_equals_uint64 (pdur, duration); \ + assert_equals_uint64 (pmstart, mstart); \ + assert_equals_uint64 (pmdur, mduration); \ + assert_equals_int (pprio, priority); \ + assert_equals_int (pact, active); \ + } + + +GST_START_TEST (test_filesource_properties) +{ + GESTrack *track; + GESTrackObject *trackobject; + GESTimelineObject *object; + + ges_init (); + + track = ges_track_new (GES_TRACK_TYPE_AUDIO, GST_CAPS_ANY); + fail_unless (track != NULL); + + object = (GESTimelineObject *) + ges_timeline_filesource_new ("crack:///there/is/no/way/this/exists"); + fail_unless (object != NULL); + + /* Set some properties */ + g_object_set (object, "start", (guint64) 42, "duration", (guint64) 51, + "in-point", (guint64) 12, NULL); + assert_equals_uint64 (GES_TIMELINE_OBJECT_START (object), 42); + assert_equals_uint64 (GES_TIMELINE_OBJECT_DURATION (object), 51); + assert_equals_uint64 (GES_TIMELINE_OBJECT_INPOINT (object), 12); + + trackobject = ges_timeline_object_create_track_object (object, track); + fail_unless (trackobject != NULL); + fail_unless (ges_track_object_set_track (trackobject, track)); + + /* Check that trackobject has the same properties */ + assert_equals_uint64 (GES_TRACK_OBJECT_START (trackobject), 42); + assert_equals_uint64 (GES_TRACK_OBJECT_DURATION (trackobject), 51); + assert_equals_uint64 (GES_TRACK_OBJECT_INPOINT (trackobject), 12); + + /* And let's also check that it propagated correctly to GNonLin */ + gnl_object_check (trackobject->gnlobject, 42, 51, 12, 51, 0, TRUE); + + /* Change more properties, see if they propagate */ + g_object_set (object, "start", (guint64) 420, "duration", (guint64) 510, + "in-point", (guint64) 120, NULL); + assert_equals_uint64 (GES_TIMELINE_OBJECT_START (object), 420); + assert_equals_uint64 (GES_TIMELINE_OBJECT_DURATION (object), 510); + assert_equals_uint64 (GES_TIMELINE_OBJECT_INPOINT (object), 120); + assert_equals_uint64 (GES_TRACK_OBJECT_START (trackobject), 420); + assert_equals_uint64 (GES_TRACK_OBJECT_DURATION (trackobject), 510); + assert_equals_uint64 (GES_TRACK_OBJECT_INPOINT (trackobject), 120); + + /* And let's also check that it propagated correctly to GNonLin */ + gnl_object_check (trackobject->gnlobject, 420, 510, 120, 510, 0, TRUE); + + /* Test mute support */ + g_object_set (object, "mute", TRUE, NULL); + gnl_object_check (trackobject->gnlobject, 420, 510, 120, 510, 0, FALSE); + g_object_set (object, "mute", FALSE, NULL); + gnl_object_check (trackobject->gnlobject, 420, 510, 120, 510, 0, TRUE); + + ges_timeline_object_release_track_object (object, trackobject); + + g_object_unref (object); + g_object_unref (track); +} + +GST_END_TEST; + + + static Suite * ges_suite (void) { @@ -71,6 +149,7 @@ ges_suite (void) suite_add_tcase (s, tc_chain); tcase_add_test (tc_chain, test_filesource_basic); + tcase_add_test (tc_chain, test_filesource_properties); return s; } -- 2.7.4