2010-12-02 05:21:49 +00:00
|
|
|
/* GStreamer unit test for the videorecordingbin element
|
|
|
|
* Copyright (C) 2010 Thiago Santos <thiago.sousa.santos@collabora.co.uk>
|
|
|
|
*
|
|
|
|
* 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 <stdio.h>
|
|
|
|
#include <gst/check/gstcheck.h>
|
|
|
|
|
|
|
|
#define N_BUFFERS 100
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
GstElement *pipe;
|
|
|
|
GstElement *src;
|
|
|
|
GstElement *vrbin;
|
|
|
|
} GstVideoRecordingBinTestContext;
|
|
|
|
|
|
|
|
static void
|
|
|
|
gstvideorecordingbin_init_test_context (GstVideoRecordingBinTestContext * ctx,
|
|
|
|
gint num_buffers)
|
|
|
|
{
|
|
|
|
fail_unless (ctx != NULL);
|
|
|
|
|
|
|
|
ctx->pipe = gst_pipeline_new ("pipeline");
|
|
|
|
fail_unless (ctx->pipe != NULL);
|
|
|
|
ctx->src = gst_element_factory_make ("videotestsrc", "src");
|
|
|
|
fail_unless (ctx->src != NULL, "Failed to create videotestsrc element");
|
|
|
|
ctx->vrbin = gst_element_factory_make ("videorecordingbin", "icbin");
|
|
|
|
fail_unless (ctx->vrbin != NULL,
|
|
|
|
"Failed to create videorecordingbin element");
|
|
|
|
|
|
|
|
if (num_buffers > 0)
|
|
|
|
g_object_set (ctx->src, "num-buffers", num_buffers, NULL);
|
|
|
|
|
|
|
|
fail_unless (gst_bin_add (GST_BIN (ctx->pipe), ctx->src));
|
|
|
|
fail_unless (gst_bin_add (GST_BIN (ctx->pipe), ctx->vrbin));
|
|
|
|
fail_unless (gst_element_link (ctx->src, ctx->vrbin));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gstvideorecordingbin_unset_test_context (GstVideoRecordingBinTestContext * ctx)
|
|
|
|
{
|
|
|
|
gst_element_set_state (ctx->pipe, GST_STATE_NULL);
|
|
|
|
gst_object_unref (ctx->pipe);
|
|
|
|
memset (ctx, 0, sizeof (GstVideoRecordingBinTestContext));
|
|
|
|
}
|
|
|
|
|
|
|
|
static gchar *
|
|
|
|
make_test_file_name (gint num)
|
|
|
|
{
|
|
|
|
return g_strdup_printf ("%s" G_DIR_SEPARATOR_S
|
|
|
|
"videorecordingbintest_%d.cap", g_get_tmp_dir (), num);
|
|
|
|
}
|
|
|
|
|
|
|
|
GST_START_TEST (test_simple_recording)
|
|
|
|
{
|
|
|
|
GstVideoRecordingBinTestContext ctx;
|
|
|
|
GstBus *bus;
|
|
|
|
GstMessage *msg;
|
|
|
|
gchar *test_file_name;
|
|
|
|
FILE *f;
|
|
|
|
|
|
|
|
gstvideorecordingbin_init_test_context (&ctx, N_BUFFERS);
|
|
|
|
bus = gst_element_get_bus (ctx.pipe);
|
|
|
|
|
|
|
|
test_file_name = make_test_file_name (0);
|
|
|
|
g_object_set (ctx.vrbin, "location", test_file_name, NULL);
|
|
|
|
|
|
|
|
fail_if (gst_element_set_state (ctx.pipe, GST_STATE_PLAYING) ==
|
|
|
|
GST_STATE_CHANGE_FAILURE);
|
|
|
|
|
|
|
|
msg = gst_bus_timed_pop_filtered (bus, GST_SECOND * 10,
|
|
|
|
GST_MESSAGE_EOS | GST_MESSAGE_ERROR);
|
|
|
|
fail_unless (msg != NULL);
|
|
|
|
fail_unless (GST_MESSAGE_TYPE (msg) == GST_MESSAGE_EOS);
|
|
|
|
|
|
|
|
/* check there is a recorded file */
|
|
|
|
fail_unless (g_file_test (test_file_name, G_FILE_TEST_EXISTS));
|
|
|
|
fail_unless (g_file_test (test_file_name, G_FILE_TEST_IS_REGULAR));
|
|
|
|
fail_if (g_file_test (test_file_name, G_FILE_TEST_IS_SYMLINK));
|
|
|
|
|
|
|
|
/* check the file isn't empty */
|
|
|
|
f = fopen (test_file_name, "r");
|
|
|
|
fseek (f, 0, SEEK_END);
|
|
|
|
fail_unless (ftell (f) > 0);
|
|
|
|
fclose (f);
|
|
|
|
|
|
|
|
gstvideorecordingbin_unset_test_context (&ctx);
|
|
|
|
gst_object_unref (bus);
|
|
|
|
g_free (test_file_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
GST_END_TEST;
|
|
|
|
|
2010-12-14 10:21:57 +00:00
|
|
|
GST_START_TEST (test_setting_video_encoder)
|
|
|
|
{
|
|
|
|
GstVideoRecordingBinTestContext ctx;
|
|
|
|
GstBus *bus;
|
|
|
|
GstMessage *msg;
|
|
|
|
GstElement *encoder;
|
|
|
|
gchar *test_file_name;
|
|
|
|
FILE *f;
|
|
|
|
|
|
|
|
gstvideorecordingbin_init_test_context (&ctx, N_BUFFERS);
|
|
|
|
bus = gst_element_get_bus (ctx.pipe);
|
|
|
|
|
|
|
|
test_file_name = make_test_file_name (0);
|
|
|
|
g_object_set (ctx.vrbin, "location", test_file_name, NULL);
|
|
|
|
|
|
|
|
encoder = gst_element_factory_make ("theoraenc", NULL);
|
|
|
|
g_object_set (ctx.vrbin, "video-encoder", encoder, NULL);
|
|
|
|
|
|
|
|
fail_if (gst_element_set_state (ctx.pipe, GST_STATE_PLAYING) ==
|
|
|
|
GST_STATE_CHANGE_FAILURE);
|
|
|
|
|
|
|
|
msg = gst_bus_timed_pop_filtered (bus, GST_SECOND * 10,
|
|
|
|
GST_MESSAGE_EOS | GST_MESSAGE_ERROR);
|
|
|
|
fail_unless (msg != NULL);
|
|
|
|
fail_unless (GST_MESSAGE_TYPE (msg) == GST_MESSAGE_EOS);
|
|
|
|
|
|
|
|
/* check there is a recorded file */
|
|
|
|
fail_unless (g_file_test (test_file_name, G_FILE_TEST_EXISTS));
|
|
|
|
fail_unless (g_file_test (test_file_name, G_FILE_TEST_IS_REGULAR));
|
|
|
|
fail_if (g_file_test (test_file_name, G_FILE_TEST_IS_SYMLINK));
|
|
|
|
|
|
|
|
/* check the file isn't empty */
|
|
|
|
f = fopen (test_file_name, "r");
|
|
|
|
fseek (f, 0, SEEK_END);
|
|
|
|
fail_unless (ftell (f) > 0);
|
|
|
|
fclose (f);
|
|
|
|
|
|
|
|
gstvideorecordingbin_unset_test_context (&ctx);
|
|
|
|
gst_object_unref (bus);
|
|
|
|
g_free (test_file_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
GST_END_TEST;
|
|
|
|
|
2010-12-14 12:28:49 +00:00
|
|
|
GST_START_TEST (test_setting_video_muxer)
|
|
|
|
{
|
|
|
|
GstVideoRecordingBinTestContext ctx;
|
|
|
|
GstBus *bus;
|
|
|
|
GstMessage *msg;
|
|
|
|
GstElement *encoder;
|
|
|
|
GstElement *muxer;
|
|
|
|
gchar *test_file_name;
|
|
|
|
FILE *f;
|
|
|
|
|
|
|
|
gstvideorecordingbin_init_test_context (&ctx, N_BUFFERS);
|
|
|
|
bus = gst_element_get_bus (ctx.pipe);
|
|
|
|
|
|
|
|
test_file_name = make_test_file_name (0);
|
|
|
|
g_object_set (ctx.vrbin, "location", test_file_name, NULL);
|
|
|
|
|
|
|
|
encoder = gst_element_factory_make ("theoraenc", NULL);
|
|
|
|
g_object_set (ctx.vrbin, "video-encoder", encoder, NULL);
|
|
|
|
|
|
|
|
muxer = gst_element_factory_make ("oggmux", NULL);
|
|
|
|
g_object_set (ctx.vrbin, "video-muxer", muxer, NULL);
|
|
|
|
|
|
|
|
fail_if (gst_element_set_state (ctx.pipe, GST_STATE_PLAYING) ==
|
|
|
|
GST_STATE_CHANGE_FAILURE);
|
|
|
|
|
|
|
|
msg = gst_bus_timed_pop_filtered (bus, GST_SECOND * 10,
|
|
|
|
GST_MESSAGE_EOS | GST_MESSAGE_ERROR);
|
|
|
|
fail_unless (msg != NULL);
|
|
|
|
fail_unless (GST_MESSAGE_TYPE (msg) == GST_MESSAGE_EOS);
|
|
|
|
|
|
|
|
/* check there is a recorded file */
|
|
|
|
fail_unless (g_file_test (test_file_name, G_FILE_TEST_EXISTS));
|
|
|
|
fail_unless (g_file_test (test_file_name, G_FILE_TEST_IS_REGULAR));
|
|
|
|
fail_if (g_file_test (test_file_name, G_FILE_TEST_IS_SYMLINK));
|
|
|
|
|
|
|
|
/* check the file isn't empty */
|
|
|
|
f = fopen (test_file_name, "r");
|
|
|
|
fseek (f, 0, SEEK_END);
|
|
|
|
fail_unless (ftell (f) > 0);
|
|
|
|
fclose (f);
|
|
|
|
|
|
|
|
gstvideorecordingbin_unset_test_context (&ctx);
|
|
|
|
gst_object_unref (bus);
|
|
|
|
g_free (test_file_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
GST_END_TEST;
|
|
|
|
|
2010-12-02 05:21:49 +00:00
|
|
|
static Suite *
|
|
|
|
videorecordingbin_suite (void)
|
|
|
|
{
|
|
|
|
Suite *s = suite_create ("videorecordingbin");
|
|
|
|
TCase *tc_chain = tcase_create ("general");
|
|
|
|
|
|
|
|
suite_add_tcase (s, tc_chain);
|
|
|
|
tcase_add_test (tc_chain, test_simple_recording);
|
2010-12-14 10:21:57 +00:00
|
|
|
tcase_add_test (tc_chain, test_setting_video_encoder);
|
2010-12-14 12:28:49 +00:00
|
|
|
tcase_add_test (tc_chain, test_setting_video_muxer);
|
2010-12-02 05:21:49 +00:00
|
|
|
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
GST_CHECK_MAIN (videorecordingbin);
|