/* GStreamer Editing Services * Copyright (C) 2010 Edward Hervey * * 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., 51 Franklin St, Fifth Floor, * Boston, MA 02110-1301, USA. */ #include "test-utils.h" #include #include #define LAYER_HEIGHT 1000 static gboolean my_fill_track_func (GESTimelineObject * object, GESTrackObject * trobject, GstElement * gnlobj, gpointer user_data) { GstElement *src; GST_DEBUG ("timelineobj:%p, trackobjec:%p, gnlobj:%p", object, trobject, gnlobj); /* Let's just put a fakesource in for the time being */ src = gst_element_factory_make ("fakesrc", NULL); /* If this fails... that means that there already was something * in it */ fail_unless (gst_bin_add (GST_BIN (gnlobj), src)); return TRUE; } GST_START_TEST (test_layer_properties) { GESTimeline *timeline; GESTimelineLayer *layer; GESTrack *track; GESTrackObject *trackobject; GESTimelineObject *object; ges_init (); /* Timeline and 1 Layer */ timeline = ges_timeline_new (); layer = (GESTimelineLayer *) ges_timeline_layer_new (); /* The default priority is 0 */ fail_unless_equals_int (ges_timeline_layer_get_priority (layer), 0); /* Layers are initially floating, once we add them to the timeline, * the timeline will take that reference. */ fail_unless (g_object_is_floating (layer)); fail_unless (ges_timeline_add_layer (timeline, layer)); fail_if (g_object_is_floating (layer)); track = ges_track_new (GES_TRACK_TYPE_CUSTOM, gst_caps_ref (GST_CAPS_ANY)); fail_unless (track != NULL); fail_unless (ges_timeline_add_track (timeline, track)); object = (GESTimelineObject *) ges_custom_timeline_source_new (my_fill_track_func, NULL); 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); assert_equals_uint64 (GES_TIMELINE_OBJECT_PRIORITY (object), 0); /* Add the object to the timeline */ fail_unless (g_object_is_floating (object)); fail_unless (ges_timeline_layer_add_object (layer, GES_TIMELINE_OBJECT (object))); fail_if (g_object_is_floating (object)); trackobject = ges_timeline_object_find_track_object (object, track, G_TYPE_NONE); fail_unless (trackobject != NULL); /* This is not a SimpleLayer, therefore the properties shouldn't have changed */ 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); assert_equals_uint64 (GES_TIMELINE_OBJECT_PRIORITY (object), 0); gnl_object_check (ges_track_object_get_gnlobject (trackobject), 42, 51, 12, 51, 0, TRUE); /* Change the priority of the layer */ g_object_set (layer, "priority", 1, NULL); assert_equals_int (ges_timeline_layer_get_priority (layer), 1); assert_equals_uint64 (GES_TIMELINE_OBJECT_PRIORITY (object), 0); gnl_object_check (ges_track_object_get_gnlobject (trackobject), 42, 51, 12, 51, LAYER_HEIGHT, TRUE); /* Change it to an insanely high value */ g_object_set (layer, "priority", 31, NULL); assert_equals_int (ges_timeline_layer_get_priority (layer), 31); assert_equals_uint64 (GES_TIMELINE_OBJECT_PRIORITY (object), 0); gnl_object_check (ges_track_object_get_gnlobject (trackobject), 42, 51, 12, 51, LAYER_HEIGHT * 31, TRUE); /* and back to 0 */ g_object_set (layer, "priority", 0, NULL); assert_equals_int (ges_timeline_layer_get_priority (layer), 0); assert_equals_uint64 (GES_TIMELINE_OBJECT_PRIORITY (object), 0); gnl_object_check (ges_track_object_get_gnlobject (trackobject), 42, 51, 12, 51, 0, TRUE); g_object_unref (trackobject); fail_unless (ges_timeline_layer_remove_object (layer, object)); fail_unless (ges_timeline_remove_track (timeline, track)); fail_unless (ges_timeline_remove_layer (timeline, layer)); g_object_unref (timeline); } GST_END_TEST; GST_START_TEST (test_layer_priorities) { GESTrack *track; GESTimeline *timeline; GESTimelineLayer *layer1, *layer2, *layer3; GESTrackObject *tckobj1, *tckobj2, *tckobj3; GESTimelineObject *object1, *object2, *object3; GstElement *gnlobj1, *gnlobj2, *gnlobj3; guint prio1, prio2, prio3; GList *objs, *tmp; ges_init (); /* Timeline and 3 Layer */ timeline = ges_timeline_new (); layer1 = (GESTimelineLayer *) ges_timeline_layer_new (); layer2 = (GESTimelineLayer *) ges_timeline_layer_new (); layer3 = (GESTimelineLayer *) ges_timeline_layer_new (); ges_timeline_layer_set_priority (layer2, 1); ges_timeline_layer_set_priority (layer3, 2); fail_unless (ges_timeline_add_layer (timeline, layer1)); fail_unless (ges_timeline_add_layer (timeline, layer2)); fail_unless (ges_timeline_add_layer (timeline, layer3)); fail_unless_equals_int (ges_timeline_layer_get_priority (layer1), 0); fail_unless_equals_int (ges_timeline_layer_get_priority (layer2), 1); fail_unless_equals_int (ges_timeline_layer_get_priority (layer3), 2); track = ges_track_video_raw_new (); fail_unless (track != NULL); fail_unless (ges_timeline_add_track (timeline, track)); object1 = GES_TIMELINE_OBJECT (ges_custom_timeline_source_new (my_fill_track_func, NULL)); ges_timeline_object_set_supported_formats (object1, GES_TRACK_TYPE_AUDIO | GES_TRACK_TYPE_VIDEO); object2 = GES_TIMELINE_OBJECT (ges_custom_timeline_source_new (my_fill_track_func, NULL)); ges_timeline_object_set_supported_formats (object2, GES_TRACK_TYPE_AUDIO | GES_TRACK_TYPE_VIDEO); object3 = GES_TIMELINE_OBJECT (ges_custom_timeline_source_new (my_fill_track_func, NULL)); ges_timeline_object_set_supported_formats (object3, GES_TRACK_TYPE_AUDIO | GES_TRACK_TYPE_VIDEO); fail_unless (object1 != NULL); fail_unless (object2 != NULL); fail_unless (object3 != NULL); /* Set priorities on the objects */ g_object_set (object1, "priority", 0, NULL); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object1), 0); g_object_set (object2, "priority", 1, NULL); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object2), 1); g_object_set (object3, "priority", LAYER_HEIGHT + 1, NULL); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object3), LAYER_HEIGHT + 1); /* Add objects to the timeline */ fail_unless (ges_timeline_layer_add_object (layer1, object1)); tckobj1 = ges_timeline_object_find_track_object (object1, track, G_TYPE_NONE); fail_unless (tckobj1 != NULL); fail_unless (ges_timeline_layer_add_object (layer2, object2)); tckobj2 = ges_timeline_object_find_track_object (object2, track, G_TYPE_NONE); fail_unless (tckobj2 != NULL); fail_unless (ges_timeline_layer_add_object (layer3, object3)); tckobj3 = ges_timeline_object_find_track_object (object3, track, G_TYPE_NONE); fail_unless (tckobj3 != NULL); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object1), 0); gnlobj1 = ges_track_object_get_gnlobject (tckobj1); fail_unless (gnlobj1 != NULL); g_object_get (gnlobj1, "priority", &prio1, NULL); assert_equals_int (prio1, 0); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object2), 1); gnlobj2 = ges_track_object_get_gnlobject (tckobj2); fail_unless (gnlobj2 != NULL); g_object_get (gnlobj2, "priority", &prio2, NULL); /* object2 is on the second layer and has a priority of 1 */ assert_equals_int (prio2, LAYER_HEIGHT + 1); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object3), LAYER_HEIGHT - 1); gnlobj3 = ges_track_object_get_gnlobject (tckobj3); fail_unless (gnlobj3 != NULL); /* object3 is on the third layer and has a priority of LAYER_HEIGHT + 1 * it priority must have the maximum priority of this layer*/ g_object_get (gnlobj3, "priority", &prio3, NULL); assert_equals_int (prio3, LAYER_HEIGHT * 3 - 1); /* Move layers around */ g_object_set (layer1, "priority", 2, NULL); g_object_set (layer2, "priority", 0, NULL); g_object_set (layer3, "priority", 1, NULL); /* And check the new priorities */ assert_equals_int (ges_timeline_layer_get_priority (layer1), 2); assert_equals_int (ges_timeline_layer_get_priority (layer2), 0); assert_equals_int (ges_timeline_layer_get_priority (layer3), 1); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object1), 0); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object2), 1); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object3), LAYER_HEIGHT - 1); g_object_get (gnlobj1, "priority", &prio1, NULL); g_object_get (gnlobj2, "priority", &prio2, NULL); g_object_get (gnlobj3, "priority", &prio3, NULL); assert_equals_int (prio1, 2 * LAYER_HEIGHT); assert_equals_int (prio2, 1); assert_equals_int (prio3, LAYER_HEIGHT * 2 - 1); /* And move objects around */ fail_unless (ges_timeline_object_move_to_layer (object2, layer1)); fail_unless (ges_timeline_object_move_to_layer (object3, layer1)); objs = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objs), 3); fail_unless (ges_timeline_layer_get_objects (layer2) == NULL); fail_unless (ges_timeline_layer_get_objects (layer3) == NULL); for (tmp = objs; tmp; tmp = g_list_next (tmp)) { g_object_unref (tmp->data); } g_list_free (objs); /* Check their priorities (layer1 priority is now 2) */ assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object1), 0); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object2), 1); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object3), LAYER_HEIGHT - 1); g_object_get (gnlobj1, "priority", &prio1, NULL); g_object_get (gnlobj2, "priority", &prio2, NULL); g_object_get (gnlobj3, "priority", &prio3, NULL); assert_equals_int (prio1, 2 * LAYER_HEIGHT); assert_equals_int (prio2, 2 * LAYER_HEIGHT + 1); assert_equals_int (prio3, LAYER_HEIGHT * 3 - 1); /* And change TrackObject-s priorities and check that changes are well * refected on it containing TimelineObject */ ges_track_object_set_priority (tckobj3, LAYER_HEIGHT * 2); g_object_get (gnlobj3, "priority", &prio3, NULL); assert_equals_int (prio3, 2 * LAYER_HEIGHT); assert_equals_int (GES_TIMELINE_OBJECT_PRIORITY (object3), 0); g_object_unref (tckobj1); g_object_unref (tckobj2); g_object_unref (tckobj3); g_object_unref (timeline); } GST_END_TEST; GST_START_TEST (test_single_layer_automatic_transition) { GESAsset *asset; GESTimeline *timeline; GList *objects, *current; GESTimelineObject *transition; GESTimelineLayer *layer; GESTimelineObject *src, *src1, *src2; ges_init (); asset = ges_asset_request (GES_TYPE_TIMELINE_TEST_SOURCE, NULL, NULL); fail_unless (GES_IS_ASSET (asset)); GST_DEBUG ("Create timeline"); timeline = ges_timeline_new_audio_video (); assert_is_type (timeline, GES_TYPE_TIMELINE); GST_DEBUG ("Create first layer"); layer = ges_timeline_layer_new (); assert_is_type (layer, GES_TYPE_TIMELINE_LAYER); GST_DEBUG ("Add first layer to timeline"); fail_unless (ges_timeline_add_layer (timeline, layer)); GST_DEBUG ("Set auto transition to first layer"); ges_timeline_layer_set_auto_transition (layer, TRUE); GST_DEBUG ("Check that auto-transition was properly set"); fail_unless (ges_timeline_layer_get_auto_transition (layer)); GST_DEBUG ("Adding assets to first layer"); GST_DEBUG ("Adding object from 0 -- 1000 to first layer"); src = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 0, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src)); GST_DEBUG ("Adding object from 500 -- 1000 to first layer"); src1 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 500, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src1)); /* * 500__transition__1000 * 0___________src_________1000 * 500___________src1_________1500 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); GST_DEBUG ("Checking that a transition has been added"); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (objects->data, GES_TYPE_TIMELINE_TEST_SOURCE); transition = objects->next->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); transition = objects->next->next->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Moving first source to 250"); ges_timeline_object_set_start (src, 250); /* * 500_____transition____1250 * 250___________src_________1250 * 500___________src1_________1500 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 250); assert_equals_uint64 (src->duration, 1250 - 250); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (objects->data, GES_TYPE_TIMELINE_TEST_SOURCE); transition = objects->next->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 750); transition = objects->next->next->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_int (transition->start, 500); assert_equals_uint64 (transition->duration, 750); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Moving second source to 250, the transitions should be removed"); ges_timeline_object_set_start (src1, 250); /* The transition should be removed * 250___________src_________1250 * 250___________src1________1250 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 250); assert_equals_uint64 (src->duration, 1250 - 250); assert_equals_uint64 (src1->start, 250); assert_equals_uint64 (src1->duration, 1250 - 250); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Trimming second source to 500 no transition should be created " "as they have the same end"); ges_timeline_object_edit (src1, NULL, -1, GES_EDIT_MODE_TRIM, GES_EDGE_START, 500); /* 250___________src_________1250 * 500______src1_______1250 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 250); assert_equals_uint64 (src->duration, 1250 - 250); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Trimming second source to 500, no transition should be created"); ges_timeline_object_trim_start (src, 500); /* 500___________src_________1250 * 500___________src1________1250 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 500); assert_equals_uint64 (src->duration, 1250 - 500); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); GST_DEBUG ("Trimming first source to 750, no transition should be created"); ges_timeline_object_trim_start (src, 750); /* 750_______src_______1250 * 500___________src1________1250 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 750); assert_equals_uint64 (src->duration, 1250 - 750); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Moving first source to 500, no transition should be created"); ges_timeline_object_set_start (src, 500); /* 500________src______1000 * 500___________src1________1250 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 500); assert_equals_uint64 (src->duration, 1000 - 500); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Moving first source to 600, no transition should be created"); ges_timeline_object_set_start (src, 600); /* 600____src___1100 * 500___________src1________1250 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 600); assert_equals_uint64 (src->duration, 1100 - 600); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Adding asset to first layer"); GST_DEBUG ("Adding object from 1250 -- 1000 to first layer"); src2 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 1250, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); assert_is_type (src2, GES_TYPE_TIMELINE_TEST_SOURCE); /* 600____src___1100 * 500___________src1________1250 * 1250___________src2________2250 */ assert_equals_uint64 (src->start, 600); assert_equals_uint64 (src->duration, 1100 - 600); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); assert_equals_uint64 (src2->start, 1250); assert_equals_uint64 (src2->duration, 1000); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 3); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Changig first source duration to 800 2 transitions should be created"); ges_timeline_object_set_duration (src, 800); /* 600__________________src_____________1400 * 500___________src1________1250 * 1250___________src2________2250 * 600_____trans1_______1250 * 1250___trans2___1400 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 600); assert_equals_uint64 (src->duration, 1400 - 600); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 7); assert_is_type (objects->data, GES_TYPE_TIMELINE_TEST_SOURCE); fail_unless (objects->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 600); assert_equals_uint64 (transition->duration, 1250 - 600); ASSERT_OBJECT_REFCOUNT (transition, "The layer and ourself own a ref", 2); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 600); assert_equals_uint64 (transition->duration, 1250 - 600); ASSERT_OBJECT_REFCOUNT (transition, "The layer and ourself own a ref", 2); current = current->next; fail_unless (current->data == src); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1250); assert_equals_uint64 (transition->duration, 1400 - 1250); ASSERT_OBJECT_REFCOUNT (transition, "The layer and ourself own a ref", 2); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1250); assert_equals_uint64 (transition->duration, 1400 - 1250); ASSERT_OBJECT_REFCOUNT (transition, "The layer and ourself own a ref", 2); current = current->next; fail_unless (current->data == src2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Back to previous state"); ges_timeline_object_set_duration (src, 1100 - 600); /* 600____src___1100 * 500___________src1________1250 * 1250___________src2________2250 */ assert_equals_uint64 (src->start, 600); assert_equals_uint64 (src->duration, 1100 - 600); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); assert_equals_uint64 (src2->start, 1250); assert_equals_uint64 (src2->duration, 1000); /* We check that the transition as actually been freed */ fail_if (GES_IS_TIMELINE_STANDARD_TRANSITION (transition)); objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 3); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Set third object start to 1100, 1 new transition should be created"); ges_timeline_object_set_start (src2, 1100); /* 600____src___1100 * 500___________src1________1250 * 1100___________src2________2100 * ^__trans___^ */ assert_equals_uint64 (src->start, 600); assert_equals_uint64 (src->duration, 1100 - 600); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); assert_equals_uint64 (src2->start, 1100); assert_equals_uint64 (src2->duration, 1000); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 5); assert_is_type (objects->data, GES_TYPE_TIMELINE_TEST_SOURCE); fail_unless (current->data == src1); current = current->next; fail_unless (current->data == src); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1100); assert_equals_uint64 (transition->duration, 1250 - 1100); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1100); assert_equals_uint64 (transition->duration, 1250 - 1100); current = current->next; fail_unless (current->data == src2); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Set third object start to 1000, Transition should be updated"); ges_timeline_object_edit (src2, NULL, -1, GES_EDIT_MODE_NORMAL, GES_EDGE_START, 1000); /* 600____src___1100 * !_tr__^ * 500___________src1________1250 * 1000___________src2________2000 * ^____trans____^ */ assert_equals_uint64 (src->start, 600); assert_equals_uint64 (src->duration, 500); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1250 - 500); assert_equals_uint64 (src2->start, 1000); assert_equals_uint64 (src2->duration, 1000); current = objects = ges_timeline_layer_get_objects (layer); current = objects; assert_equals_int (g_list_length (objects), 7); assert_is_type (objects->data, GES_TYPE_TIMELINE_TEST_SOURCE); fail_unless (current->data == src1); current = current->next; fail_unless (current->data == src); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1100 - 1000); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1100 - 1000); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1250 - 1000); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1250 - 1000); current = current->next; fail_unless (current->data == src2); g_list_free_full (objects, gst_object_unref); g_object_unref (timeline); } GST_END_TEST; GST_START_TEST (test_multi_layer_automatic_transition) { GESAsset *asset; GESTimeline *timeline; GList *objects, *current; GESTimelineObject *transition; GESTimelineLayer *layer, *layer1; GESTimelineObject *src, *src1, *src2, *src3; ges_init (); asset = ges_asset_request (GES_TYPE_TIMELINE_TEST_SOURCE, NULL, NULL); fail_unless (GES_IS_ASSET (asset)); GST_DEBUG ("Create timeline"); timeline = ges_timeline_new_audio_video (); assert_is_type (timeline, GES_TYPE_TIMELINE); GST_DEBUG ("Create first layer"); layer = ges_timeline_layer_new (); assert_is_type (layer, GES_TYPE_TIMELINE_LAYER); GST_DEBUG ("Add first layer to timeline"); fail_unless (ges_timeline_add_layer (timeline, layer)); GST_DEBUG ("Append a new layer to the timeline"); layer1 = ges_timeline_append_layer (timeline); assert_is_type (layer1, GES_TYPE_TIMELINE_LAYER); GST_DEBUG ("Set auto transition to first layer"); ges_timeline_layer_set_auto_transition (layer, TRUE); GST_DEBUG ("Check that auto-transition was properly set"); fail_unless (ges_timeline_layer_get_auto_transition (layer)); fail_if (ges_timeline_layer_get_auto_transition (layer1)); GST_DEBUG ("Adding assets to first layer"); GST_DEBUG ("Adding object from 0 -- 1000 to first layer"); src = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 0, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src)); GST_DEBUG ("Adding object from 500 -- 1000 to first layer"); src1 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 500, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src1)); /* * 500__transition__1000 * 0___________src_________1000 * 500___________src1_________1500 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); GST_DEBUG ("Checking that a transition has been added"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Adding object 2 from 500 -- 1000 to second layer"); src2 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer1, asset, 0, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); GST_DEBUG ("Adding object 3 from 500 -- 1000 to second layer"); src3 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer1, asset, 500, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); assert_is_type (src3, GES_TYPE_TIMELINE_TEST_SOURCE); /* 500__transition__1000 * 0___________src_________1000 * 500___________src1_________1500 *---------------------------------------------------- * 0___________src2_________1000 * 500___________src3_________1500 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 500); assert_equals_uint64 (src3->duration, 1500 - 500); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking transitions on second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 2); fail_unless (current->data == src2); fail_unless (current->next->data == src3); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Set auto transition to second layer, a new transition should be added"); ges_timeline_layer_set_auto_transition (layer1, TRUE); /* 500__transition__1000 * 0___________src_________1000 * 500___________src1_________1500 *---------------------------------------------------- * 500__transition__1000 * 0__________src2_________1000 * 500___________src3_________1500 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 500); assert_equals_uint64 (src3->duration, 1500 - 500); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking transitions has been added on second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 4); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Moving src3 to 1000. should remove transition"); ges_timeline_object_set_start (src3, 1000); /* 500__transition__1000 * 0___________src_________1000 * 500___________src1_________1500 Layer *---------------------------------------------------- * 0__________src2_________1000 * 1000___________src3_________2000 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 1000); assert_equals_uint64 (src3->duration, 2000 - 1000); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking transitions has been removed on second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 2); fail_unless (current->data == src2); fail_unless (current->next->data == src3); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Moving src3 to first layer, should add a transition"); ges_timeline_object_move_to_layer (src3, layer); /* 500__transition__1000 * 0___________src_________1000 * 500___________src1_________1500 * 1000___________src3_________2000 Layer * 1000__tr__1500 *---------------------------------------------------- * 0__________src2_________1000 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 1000); assert_equals_uint64 (src3->duration, 2000 - 1000); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 7); fail_unless (current->data == src); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1500 - 1000); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1500 - 1000); current = current->next; fail_unless (current->data == src3); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 1); fail_unless (current->data == src2); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Moving src to second layer, should remove first transition on first layer"); ges_timeline_object_move_to_layer (src, layer1); /* 500___________src1_________1500 * 1000___________src3_________2000 Layer * 1000__tr__1500 *---------------------------------------------------- * 0___________src_________1000 * 0__________src2_________1000 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 1000); assert_equals_uint64 (src3->duration, 2000 - 1000); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); fail_unless (current->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src3); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 2); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); assert_is_type (current->next->data, GES_TYPE_TIMELINE_TEST_SOURCE); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Edit src to first layer start=1500"); ges_timeline_object_edit (src, NULL, 0, GES_EDIT_MODE_NORMAL, GES_EDGE_NONE, 1500); /* 1500___________src_________2500 * 1500______tr______2000 * 500___________src1_________1500 ^ * 1000_________^_src3_________2000 Layer * 1000__tr__1500 *--------------------------------------------------------------------------- * 0__________src2_________1000 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 1500); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 1000); assert_equals_uint64 (src3->duration, 2000 - 1000); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 7); fail_unless (current->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src3); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1500); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 1); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Ripple src1 to 700"); ges_timeline_object_edit (src1, NULL, 0, GES_EDIT_MODE_RIPPLE, GES_EDGE_NONE, 700); /* 1700___________src_________2700 * 1700__tr__2000 * 700___________src1_________1700 * 1000___________src3_________2000 Layer * 1000______tr______1700 *--------------------------------------------------------------------------- * 0__________src2_________1000 Layer1 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 1700); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 700); assert_equals_uint64 (src1->duration, 1700 - 700); assert_equals_uint64 (src2->start, 0); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 1000); assert_equals_uint64 (src3->duration, 2000 - 1000); GST_DEBUG ("Checking transitions on first layer"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 7); fail_unless (current->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1700 - 1000); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 1700 - 1000); current = current->next; fail_unless (current->data == src3); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1700); assert_equals_uint64 (transition->duration, 2000 - 1700); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1700); assert_equals_uint64 (transition->duration, 2000 - 1700); current = current->next; fail_unless (current->data == src); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Checking second layer"); current = objects = ges_timeline_layer_get_objects (layer1); assert_equals_int (g_list_length (objects), 1); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); g_object_unref (timeline); } GST_END_TEST; GST_START_TEST (test_layer_activate_automatic_transition) { GESAsset *asset, *transition_asset; GESTimeline *timeline; GESTimelineLayer *layer; GList *objects, *current; GESTimelineObject *transition; GESTimelineObject *src, *src1, *src2, *src3; ges_init (); asset = ges_asset_request (GES_TYPE_TIMELINE_TEST_SOURCE, NULL, NULL); transition_asset = ges_asset_request (GES_TYPE_TIMELINE_STANDARD_TRANSITION, "crossfade", NULL); fail_unless (GES_IS_ASSET (asset)); GST_DEBUG ("Create timeline"); timeline = ges_timeline_new_audio_video (); assert_is_type (timeline, GES_TYPE_TIMELINE); GST_DEBUG ("Append a layer to the timeline"); layer = ges_timeline_append_layer (timeline); assert_is_type (layer, GES_TYPE_TIMELINE_LAYER); GST_DEBUG ("Adding object from 0 -- 1000 to layer"); src = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 0, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src)); GST_DEBUG ("Adding object from 500 -- 1000 to first layer"); src1 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 500, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src1)); GST_DEBUG ("Adding object from 1000 -- 2000 to layer"); src2 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 1000, 0, 1000, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src2)); GST_DEBUG ("Adding object from 2000 -- 2500 to layer"); src3 = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, asset, 2000, 0, 500, 1, GES_TRACK_TYPE_UNKNOWN)); fail_unless (GES_IS_TIMELINE_OBJECT (src3)); /* * 0___________src_________1000 * 500___________src1_________1500 * 1000____src2_______2000 * 2000_______src2_____2500 */ GST_DEBUG ("Checking src timing values"); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 1000); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 2000); assert_equals_uint64 (src3->duration, 500); GST_DEBUG ("Checking that no transition has been added"); current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 4); assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Adding transition from 1000 -- 1500 to layer"); transition = GES_TIMELINE_OBJECT (ges_timeline_layer_add_asset (layer, transition_asset, 1000, 0, 500, 1, GES_TRACK_TYPE_VIDEO)); fail_unless (GES_IS_TIMELINE_STANDARD_TRANSITION (transition)); objects = ges_timeline_object_get_track_objects (transition); assert_equals_int (g_list_length (objects), 1); g_list_free_full (objects, gst_object_unref); GST_DEBUG ("Checking the transitions"); /* * 0___________src_________1000 * 500___________src1_________1500 * 1000__tr__1500 (1 of the 2 tracks only) * 1000____src2_______2000 * 2000_______src3_____2500 */ current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 5); current = current->next; assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; assert_is_type (current->data, GES_TYPE_TIMELINE_STANDARD_TRANSITION); current = current->next; assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); current = current->next; assert_is_type (current->data, GES_TYPE_TIMELINE_TEST_SOURCE); g_list_free_full (objects, gst_object_unref); ges_timeline_layer_set_auto_transition (layer, TRUE); /* * 0___________src_________1000 * 500______tr______1000 * 500___________src1_________1500 * 1000__tr__1500 * 1000____src2_______2000 * 2000_______src3_____2500 */ current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 8); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 1000); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 2000); assert_equals_uint64 (src3->duration, 500); GST_DEBUG ("Checking transitions"); fail_unless (current->data == src); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1000); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src2); current = current->next; fail_unless (current->data == src3); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); GST_DEBUG ("Moving src2 to 1200, check everything updates properly"); ges_timeline_object_set_start (src2, 1200); /* * 0___________src_________1000 * 500______tr______1000 * 500___________src1_________1500 * 1200_tr_1500 * 1200____src2_______2200 * !__tr__^ * 2000_______src3_____2500 */ current = objects = ges_timeline_layer_get_objects (layer); assert_equals_int (g_list_length (objects), 10); assert_equals_uint64 (src->start, 0); assert_equals_uint64 (src->duration, 1000); assert_equals_uint64 (src1->start, 500); assert_equals_uint64 (src1->duration, 1500 - 500); assert_equals_uint64 (src2->start, 1200); assert_equals_uint64 (src2->duration, 1000); assert_equals_uint64 (src3->start, 2000); assert_equals_uint64 (src3->duration, 500); GST_DEBUG ("Checking transitions"); fail_unless (current->data == src); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 500); assert_equals_uint64 (transition->duration, 500); current = current->next; fail_unless (current->data == src1); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1200); assert_equals_uint64 (transition->duration, 300); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 1200); assert_equals_uint64 (transition->duration, 300); current = current->next; fail_unless (current->data == src2); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 2000); assert_equals_uint64 (transition->duration, 200); current = current->next; transition = current->data; assert_is_type (transition, GES_TYPE_TIMELINE_STANDARD_TRANSITION); assert_equals_uint64 (transition->start, 2000); assert_equals_uint64 (transition->duration, 200); current = current->next; fail_unless (current->data == src3); g_list_free_full (objects, gst_object_unref); ASSERT_OBJECT_REFCOUNT (transition, "Only the layer owns a ref", 1); gst_object_unref (timeline); } GST_END_TEST; GST_START_TEST (test_layer_meta_string) { GESTimeline *timeline; GESTimelineLayer *layer; const gchar *result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_string (GES_META_CONTAINER (layer), "ges-test", "blub"); fail_unless ((result = ges_meta_container_get_string (GES_META_CONTAINER (layer), "ges-test")) != NULL); assert_equals_string (result, "blub"); } GST_END_TEST; GST_START_TEST (test_layer_meta_boolean) { GESTimeline *timeline; GESTimelineLayer *layer; gboolean result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_boolean (GES_META_CONTAINER (layer), "ges-test", TRUE); fail_unless (ges_meta_container_get_boolean (GES_META_CONTAINER (layer), "ges-test", &result)); fail_unless (result); } GST_END_TEST; GST_START_TEST (test_layer_meta_int) { GESTimeline *timeline; GESTimelineLayer *layer; gint result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_int (GES_META_CONTAINER (layer), "ges-test", 1234); fail_unless (ges_meta_container_get_int (GES_META_CONTAINER (layer), "ges-test", &result)); assert_equals_int (result, 1234); } GST_END_TEST; GST_START_TEST (test_layer_meta_uint) { GESTimeline *timeline; GESTimelineLayer *layer; guint result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_uint (GES_META_CONTAINER (layer), "ges-test", 42); fail_unless (ges_meta_container_get_uint (GES_META_CONTAINER (layer), "ges-test", &result)); assert_equals_int (result, 42); } GST_END_TEST; GST_START_TEST (test_layer_meta_int64) { GESTimeline *timeline; GESTimelineLayer *layer; gint64 result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_int64 (GES_META_CONTAINER (layer), "ges-test", 1234); fail_unless (ges_meta_container_get_int64 (GES_META_CONTAINER (layer), "ges-test", &result)); assert_equals_int64 (result, 1234); } GST_END_TEST; GST_START_TEST (test_layer_meta_uint64) { GESTimeline *timeline; GESTimelineLayer *layer; guint64 result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_uint64 (GES_META_CONTAINER (layer), "ges-test", 42); fail_unless (ges_meta_container_get_uint64 (GES_META_CONTAINER (layer), "ges-test", &result)); assert_equals_uint64 (result, 42); } GST_END_TEST; GST_START_TEST (test_layer_meta_float) { GESTimeline *timeline; GESTimelineLayer *layer; gfloat result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); fail_unless (ges_meta_container_set_float (GES_META_CONTAINER (layer), "ges-test", 23.456)); fail_unless (ges_meta_container_get_float (GES_META_CONTAINER (layer), "ges-test", &result)); assert_equals_float (result, 23.456f); } GST_END_TEST; GST_START_TEST (test_layer_meta_double) { GESTimeline *timeline; GESTimelineLayer *layer; gdouble result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_double (GES_META_CONTAINER (layer), "ges-test", 23.456); fail_unless (ges_meta_container_get_double (GES_META_CONTAINER (layer), "ges-test", &result)); fail_unless (result == 23.456); //TODO CHECK assert_equals_float (result, 23.456); } GST_END_TEST; GST_START_TEST (test_layer_meta_date) { GESTimeline *timeline; GESTimelineLayer *layer; GDate *input; GDate *result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); input = g_date_new_dmy (1, 1, 2012); ges_meta_container_set_date (GES_META_CONTAINER (layer), "ges-test", input); fail_unless (ges_meta_container_get_date (GES_META_CONTAINER (layer), "ges-test", &result)); fail_unless (g_date_compare (result, input) == 0); g_date_free (input); g_date_free (result); } GST_END_TEST; GST_START_TEST (test_layer_meta_date_time) { GESTimeline *timeline; GESTimelineLayer *layer; GstDateTime *input; GstDateTime *result = NULL; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); input = gst_date_time_new_from_unix_epoch_local_time (123456789); fail_unless (ges_meta_container_set_date_time (GES_META_CONTAINER (layer), "ges-test", input)); fail_unless (ges_meta_container_get_date_time (GES_META_CONTAINER (layer), "ges-test", &result)); fail_unless (result != NULL); fail_unless (gst_date_time_get_day (input) == gst_date_time_get_day (result)); fail_unless (gst_date_time_get_hour (input) == gst_date_time_get_hour (result)); gst_date_time_unref (input); gst_date_time_unref (result); } GST_END_TEST; GST_START_TEST (test_layer_meta_value) { GESTimeline *timeline; GESTimelineLayer *layer; GValue data = G_VALUE_INIT; const GValue *result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); g_value_init (&data, G_TYPE_STRING); g_value_set_string (&data, "Hello world!"); ges_meta_container_set_meta (GES_META_CONTAINER (layer), "ges-test-value", &data); result = ges_meta_container_get_meta (GES_META_CONTAINER (layer), "ges-test-value"); assert_equals_string (g_value_get_string (result), "Hello world!"); g_value_unset (&data); } GST_END_TEST; GST_START_TEST (test_layer_meta_register) { GESTimeline *timeline; GESTimelineLayer *layer; const gchar *result; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); fail_unless (ges_meta_container_register_meta_string (GES_META_CONTAINER (layer), GES_META_READABLE, "ges-test-value", "Hello world!")); result = ges_meta_container_get_string (GES_META_CONTAINER (layer), "ges-test-value"); assert_equals_string (result, "Hello world!"); fail_if (ges_meta_container_set_int (GES_META_CONTAINER (layer), "ges-test-value", 123456)); result = ges_meta_container_get_string (GES_META_CONTAINER (layer), "ges-test-value"); assert_equals_string (result, "Hello world!"); } GST_END_TEST; static void test_foreach (const GESMetaContainer * container, const gchar * key, GValue * value, gpointer user_data) { fail_unless ((0 == g_strcmp0 (key, "some-string")) || (0 == g_strcmp0 (key, "some-int"))); } GST_START_TEST (test_layer_meta_foreach) { GESTimeline *timeline; GESTimelineLayer *layer; ges_init (); timeline = ges_timeline_new_audio_video (); layer = ges_timeline_layer_new (); ges_timeline_add_layer (timeline, layer); ges_meta_container_set_string (GES_META_CONTAINER (layer), "some-string", "some-content"); ges_meta_container_set_int (GES_META_CONTAINER (layer), "some-int", 123456); ges_meta_container_foreach (GES_META_CONTAINER (layer), (GESMetaForeachFunc) test_foreach, NULL); } GST_END_TEST; static Suite * ges_suite (void) { Suite *s = suite_create ("ges-timeline-layer"); TCase *tc_chain = tcase_create ("timeline-layer"); suite_add_tcase (s, tc_chain); tcase_add_test (tc_chain, test_layer_properties); tcase_add_test (tc_chain, test_layer_priorities); tcase_add_test (tc_chain, test_single_layer_automatic_transition); tcase_add_test (tc_chain, test_multi_layer_automatic_transition); tcase_add_test (tc_chain, test_layer_activate_automatic_transition); tcase_add_test (tc_chain, test_layer_meta_string); tcase_add_test (tc_chain, test_layer_meta_boolean); tcase_add_test (tc_chain, test_layer_meta_int); tcase_add_test (tc_chain, test_layer_meta_uint); tcase_add_test (tc_chain, test_layer_meta_int64); tcase_add_test (tc_chain, test_layer_meta_uint64); tcase_add_test (tc_chain, test_layer_meta_float); tcase_add_test (tc_chain, test_layer_meta_double); tcase_add_test (tc_chain, test_layer_meta_date); tcase_add_test (tc_chain, test_layer_meta_date_time); tcase_add_test (tc_chain, test_layer_meta_value); tcase_add_test (tc_chain, test_layer_meta_register); tcase_add_test (tc_chain, test_layer_meta_foreach); return s; } int main (int argc, char **argv) { int nf; Suite *s = ges_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; }