diff --git a/tests/old/testsuite/refcounting/bin.c b/tests/old/testsuite/refcounting/bin.c index 066b66cc03..3e67bf46d6 100644 --- a/tests/old/testsuite/refcounting/bin.c +++ b/tests/old/testsuite/refcounting/bin.c @@ -21,6 +21,113 @@ create_bin (void) return bin; } +static GstElement* +create_bin_ghostpads (void) +{ + GstElement *bin; + GstElement *element1, *element2; + + bin = gst_bin_new ("testbin"); + element1 = gst_element_new (); + gst_element_set_name (element1, "test1"); + gst_element_add_pad (element1, gst_pad_new ("src1", GST_PAD_SRC)); + gst_bin_add (GST_BIN (bin), element1); + element2 = gst_element_new (); + gst_element_set_name (element2, "test2"); + gst_element_add_pad (element2, gst_pad_new ("sink1", GST_PAD_SINK)); + gst_bin_add (GST_BIN (bin), element2); + gst_element_connect (element1, "src1", element2, "sink1"); + gst_element_add_ghost_pad (bin, gst_element_get_pad (element2, "sink1"), "sink1"); + + return bin; +} + +static void +add_remove_test1 (void) +{ + GstElement *bin; + GstElement *element; + + bin = gst_bin_new ("testbin"); + element = gst_element_new (); + gst_element_set_name (element, "test1"); + g_assert (GST_OBJECT_FLOATING (element)); + gst_bin_add (GST_BIN (bin), element); + g_assert (!GST_OBJECT_FLOATING (element)); + gst_bin_remove (GST_BIN (bin), element); + + gst_object_unref (GST_OBJECT (bin)); +} + +static void +add_remove_test2 (void) +{ + GstElement *bin; + GstElement *element; + + bin = gst_bin_new ("testbin"); + element = gst_element_new (); + gst_element_set_name (element, "test1"); + gst_object_ref (GST_OBJECT (element)); + g_assert (GST_OBJECT_FLOATING (element)); + gst_bin_add (GST_BIN (bin), element); + g_assert (!GST_OBJECT_FLOATING (element)); + gst_bin_remove (GST_BIN (bin), element); + g_assert (!GST_OBJECT_FLOATING (element)); + g_assert (!GST_OBJECT_DESTROYED (element)); + + gst_object_destroy (GST_OBJECT (element)); + g_assert (GST_OBJECT_DESTROYED (element)); + gst_object_unref (GST_OBJECT (element)); + + gst_object_unref (GST_OBJECT (bin)); +} + +static void +add_remove_test3 (void) +{ + GstElement *bin; + GstElement *element; + + bin = gst_bin_new ("testbin"); + element = gst_element_new (); + gst_element_set_name (element, "test1"); + g_assert (GST_OBJECT_FLOATING (element)); + gst_bin_add (GST_BIN (bin), element); + g_assert (!GST_OBJECT_FLOATING (element)); + + gst_object_destroy (GST_OBJECT (element)); + g_assert (gst_bin_get_by_name (GST_BIN (bin), "test1") == NULL); + + gst_object_unref (GST_OBJECT (bin)); +} + +static void +add_remove_test4 (void) +{ + GstElement *bin, *bin2; + GstElement *element; + + bin = gst_bin_new ("testbin"); + element = gst_element_new (); + gst_element_set_name (element, "test1"); + g_assert (GST_OBJECT_FLOATING (element)); + gst_bin_add (GST_BIN (bin), element); + g_assert (!GST_OBJECT_FLOATING (element)); + + bin2 = create_bin (); + g_assert (GST_OBJECT_FLOATING (bin2)); + gst_bin_add (GST_BIN (bin), bin2); + g_assert (!GST_OBJECT_FLOATING (bin2)); + + gst_object_destroy (GST_OBJECT (bin2)); + g_assert (gst_bin_get_by_name (GST_BIN (bin), "testbin") == NULL); + gst_object_destroy (GST_OBJECT (element)); + g_assert (gst_bin_get_by_name (GST_BIN (bin), "test1") == NULL); + + gst_object_unref (GST_OBJECT (bin)); +} + int main (int argc, gchar *argv[]) { @@ -133,6 +240,32 @@ main (int argc, gchar *argv[]) } g_print ("create/unref %d bin with children %ld\n", iters, vmsize()-usage1); + for (i=0; i