summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVíctor Manuel Jáquez Leal <vjaquez@igalia.com>2017-12-01 20:18:28 +0100
committerMichael Olbrich <m.olbrich@pengutronix.de>2020-07-31 14:02:33 +0200
commit283fceac0b048fe95c6a15b2690d818ece2a519e (patch)
treec7204e10a081373c31624cc3c7b55724a17fadf4
parent672b2dd991ddc2f7487fdc500ef194524f4c716b (diff)
downloadgstreamer-vaapi-283fceac0b048fe95c6a15b2690d818ece2a519e.tar.gz
test: vaapicontext: use playbin to test files
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-vaapi/-/merge_requests/342>
-rw-r--r--tests/examples/test-vaapicontext.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/tests/examples/test-vaapicontext.c b/tests/examples/test-vaapicontext.c
index 355d2cee..ed5b4504 100644
--- a/tests/examples/test-vaapicontext.c
+++ b/tests/examples/test-vaapicontext.c
@@ -35,12 +35,12 @@
static gboolean g_multisink;
static gchar *g_filepath;
+static GstElement *g_vaapisink;
static GOptionEntry g_options[] = {
{"multi", 'm', 0, G_OPTION_ARG_NONE, &g_multisink, "test multiple vaapisink",
NULL},
- {"file", 'f', 0, G_OPTION_ARG_STRING, &g_filepath,
- "file path to play (only mp4/h264)", NULL},
+ {"file", 'f', 0, G_OPTION_ARG_STRING, &g_filepath, "file path to play", NULL},
{NULL,}
};
@@ -258,11 +258,14 @@ create_rotate_button (AppData * app, const gchar * name)
GstElement *sink;
sink = gst_bin_get_by_name (GST_BIN (app->pipeline), name);
+ if (!sink && !g_strcmp0 (name, "sink1"))
+ sink = g_vaapisink;
g_assert (sink);
rotate = gtk_button_new_with_label ("Rotate");
g_signal_connect (rotate, "clicked", G_CALLBACK (button_rotate_cb), sink);
- gst_object_unref (sink);
+ if (sink != g_vaapisink)
+ gst_object_unref (sink);
return rotate;
}
@@ -344,8 +347,8 @@ main (gint argc, gchar ** argv)
app.pipeline = gst_parse_launch ("videotestsrc ! vaapih264enc ! "
"vaapidecodebin ! vaapisink name=sink1", &error);
} else {
- app.pipeline = gst_parse_launch ("filesrc name=src ! qtdemux ! h264parse ! "
- "vaapidecodebin ! vaapisink name=sink1", &error);
+ app.pipeline = gst_element_factory_make ("playbin", NULL);
+ g_assert (app.pipeline);
}
if (error) {
@@ -355,12 +358,10 @@ main (gint argc, gchar ** argv)
}
if (!g_multisink && g_filepath) {
- GstElement *src;
-
- src = gst_bin_get_by_name (GST_BIN (app.pipeline), "src");
- g_assert (src);
- g_object_set (src, "location", g_filepath, NULL);
- gst_object_unref (src);
+ g_vaapisink = gst_element_factory_make ("vaapisink", "sink1");
+ g_assert (g_vaapisink);
+ g_object_set (app.pipeline, "uri", g_filepath, "video-sink", g_vaapisink,
+ NULL);
}
build_ui (&app);