mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 09:08:14 +00:00
tests: matroskamux, qtmux: don't add codec_data buffers to template caps
streamheader and codec_data buffers fields are only meant to be in the negotiated caps, not the template caps. Fixes false-positive leaks of those buffers detected by the leaks tracer, as template caps are static, and we decided to not include code in gstreamer core to handle this unusual case of template caps having buffers in them. https://bugzilla.gnome.org/show_bug.cgi?id=768762
This commit is contained in:
parent
29f9062016
commit
0f719af307
2 changed files with 44 additions and 33 deletions
|
@ -33,10 +33,12 @@ GstPad *mysrcpad, *mysinkpad;
|
||||||
#define AC3_CAPS_STRING "audio/x-ac3, " \
|
#define AC3_CAPS_STRING "audio/x-ac3, " \
|
||||||
"channels = (int) 1, " \
|
"channels = (int) 1, " \
|
||||||
"rate = (int) 8000"
|
"rate = (int) 8000"
|
||||||
#define VORBIS_CAPS_STRING "audio/x-vorbis, " \
|
#define VORBIS_TMPL_CAPS_STRING "audio/x-vorbis, " \
|
||||||
"channels = (int) 1, " \
|
"channels = (int) 1, " \
|
||||||
"rate = (int) 8000, " \
|
"rate = (int) 8000"
|
||||||
"streamheader=(buffer)<10, 2020, 303030>"
|
/* streamheader shouldn't be in the template caps, only in the actual caps */
|
||||||
|
#define VORBIS_CAPS_STRING VORBIS_TMPL_CAPS_STRING \
|
||||||
|
", streamheader=(buffer)<10, 2020, 303030>"
|
||||||
|
|
||||||
static GstStaticPadTemplate sinktemplate = GST_STATIC_PAD_TEMPLATE ("sink",
|
static GstStaticPadTemplate sinktemplate = GST_STATIC_PAD_TEMPLATE ("sink",
|
||||||
GST_PAD_SINK,
|
GST_PAD_SINK,
|
||||||
|
@ -45,7 +47,7 @@ static GstStaticPadTemplate sinktemplate = GST_STATIC_PAD_TEMPLATE ("sink",
|
||||||
static GstStaticPadTemplate srcvorbistemplate = GST_STATIC_PAD_TEMPLATE ("src",
|
static GstStaticPadTemplate srcvorbistemplate = GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
GST_PAD_SRC,
|
GST_PAD_SRC,
|
||||||
GST_PAD_ALWAYS,
|
GST_PAD_ALWAYS,
|
||||||
GST_STATIC_CAPS (VORBIS_CAPS_STRING));
|
GST_STATIC_CAPS (VORBIS_TMPL_CAPS_STRING));
|
||||||
|
|
||||||
static GstStaticPadTemplate srcac3template = GST_STATIC_PAD_TEMPLATE ("src",
|
static GstStaticPadTemplate srcac3template = GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
GST_PAD_SRC,
|
GST_PAD_SRC,
|
||||||
|
|
|
@ -46,15 +46,17 @@ static GstPad *mysrcpad, *mysinkpad;
|
||||||
"channels = (int) 2, " \
|
"channels = (int) 2, " \
|
||||||
"rate = (int) 48000"
|
"rate = (int) 48000"
|
||||||
|
|
||||||
#define AUDIO_AAC_CAPS_STRING "audio/mpeg, " \
|
#define AUDIO_AAC_TMPL_CAPS_STRING "audio/mpeg, " \
|
||||||
"mpegversion=(int)4, " \
|
"mpegversion=(int)4, " \
|
||||||
"channels=(int)1, " \
|
"channels=(int)1, " \
|
||||||
"rate=(int)44100, " \
|
"rate=(int)44100, " \
|
||||||
"stream-format=(string)raw, " \
|
"stream-format=(string)raw, " \
|
||||||
"level=(string)2, " \
|
"level=(string)2, " \
|
||||||
"base-profile=(string)lc, " \
|
"base-profile=(string)lc, " \
|
||||||
"profile=(string)lc, " \
|
"profile=(string)lc"
|
||||||
"codec_data=(buffer)1208"
|
/* codec_data shouldn't be in the template caps, only in the actual caps */
|
||||||
|
#define AUDIO_AAC_CAPS_STRING AUDIO_AAC_TMPL_CAPS_STRING \
|
||||||
|
", codec_data=(buffer)1208"
|
||||||
|
|
||||||
#define VIDEO_CAPS_STRING "video/mpeg, " \
|
#define VIDEO_CAPS_STRING "video/mpeg, " \
|
||||||
"mpegversion = (int) 4, " \
|
"mpegversion = (int) 4, " \
|
||||||
|
@ -63,18 +65,20 @@ static GstPad *mysrcpad, *mysinkpad;
|
||||||
"height = (int) 288, " \
|
"height = (int) 288, " \
|
||||||
"framerate = (fraction) 25/1"
|
"framerate = (fraction) 25/1"
|
||||||
|
|
||||||
#define VIDEO_CAPS_H264_STRING "video/x-h264, " \
|
#define VIDEO_TMPL_CAPS_H264_STRING "video/x-h264, " \
|
||||||
"width=(int)320, " \
|
"width=(int)320, " \
|
||||||
"height=(int)240, " \
|
"height=(int)240, " \
|
||||||
"framerate=(fraction)30/1, " \
|
"framerate=(fraction)30/1, " \
|
||||||
"pixel-aspect-ratio=(fraction)1/1, " \
|
"pixel-aspect-ratio=(fraction)1/1, " \
|
||||||
"codec_data=(buffer)01640014ffe1001867640014a" \
|
"stream-format=(string)avc, " \
|
||||||
|
"alignment=(string)au, " \
|
||||||
|
"level=(string)2, " \
|
||||||
|
"profile=(string)high"
|
||||||
|
/* codec_data shouldn't be in the template caps, only in the actual caps */
|
||||||
|
#define VIDEO_CAPS_H264_STRING VIDEO_TMPL_CAPS_H264_STRING \
|
||||||
|
", codec_data=(buffer)01640014ffe1001867640014a" \
|
||||||
"cd94141fb0110000003001773594000f14299600" \
|
"cd94141fb0110000003001773594000f14299600" \
|
||||||
"1000568ebecb22c, " \
|
"1000568ebecb22c"
|
||||||
"stream-format=(string)avc, " \
|
|
||||||
"alignment=(string)au, " \
|
|
||||||
"level=(string)2, " \
|
|
||||||
"profile=(string)high"
|
|
||||||
|
|
||||||
static GstStaticPadTemplate sinktemplate = GST_STATIC_PAD_TEMPLATE ("sink",
|
static GstStaticPadTemplate sinktemplate = GST_STATIC_PAD_TEMPLATE ("sink",
|
||||||
GST_PAD_SINK,
|
GST_PAD_SINK,
|
||||||
|
@ -90,7 +94,7 @@ static GstStaticPadTemplate srcvideoh264template =
|
||||||
GST_STATIC_PAD_TEMPLATE ("src",
|
GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
GST_PAD_SRC,
|
GST_PAD_SRC,
|
||||||
GST_PAD_ALWAYS,
|
GST_PAD_ALWAYS,
|
||||||
GST_STATIC_CAPS (VIDEO_CAPS_H264_STRING));
|
GST_STATIC_CAPS (VIDEO_TMPL_CAPS_H264_STRING));
|
||||||
|
|
||||||
static GstStaticPadTemplate srcvideorawtemplate =
|
static GstStaticPadTemplate srcvideorawtemplate =
|
||||||
GST_STATIC_PAD_TEMPLATE ("src",
|
GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
|
@ -107,7 +111,7 @@ static GstStaticPadTemplate srcaudioaactemplate =
|
||||||
GST_STATIC_PAD_TEMPLATE ("src",
|
GST_STATIC_PAD_TEMPLATE ("src",
|
||||||
GST_PAD_SRC,
|
GST_PAD_SRC,
|
||||||
GST_PAD_ALWAYS,
|
GST_PAD_ALWAYS,
|
||||||
GST_STATIC_CAPS (AUDIO_AAC_CAPS_STRING));
|
GST_STATIC_CAPS (AUDIO_AAC_TMPL_CAPS_STRING));
|
||||||
|
|
||||||
/* setup and teardown needs some special handling for muxer */
|
/* setup and teardown needs some special handling for muxer */
|
||||||
static GstPad *
|
static GstPad *
|
||||||
|
@ -819,7 +823,8 @@ extract_tags (const gchar * location, GstTagList ** taglist)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_average_bitrate_custom (const gchar * elementname,
|
test_average_bitrate_custom (const gchar * elementname,
|
||||||
GstStaticPadTemplate * tmpl, const gchar * sinkpadname)
|
GstStaticPadTemplate * tmpl, const gchar * caps_str,
|
||||||
|
const gchar * sinkpadname)
|
||||||
{
|
{
|
||||||
gchar *location;
|
gchar *location;
|
||||||
GstElement *qtmux;
|
GstElement *qtmux;
|
||||||
|
@ -854,7 +859,7 @@ test_average_bitrate_custom (const gchar * elementname,
|
||||||
|
|
||||||
gst_pad_push_event (mysrcpad, gst_event_new_stream_start ("test"));
|
gst_pad_push_event (mysrcpad, gst_event_new_stream_start ("test"));
|
||||||
|
|
||||||
caps = gst_pad_get_pad_template_caps (mysrcpad);
|
caps = gst_caps_from_string (caps_str);
|
||||||
gst_pad_set_caps (mysrcpad, caps);
|
gst_pad_set_caps (mysrcpad, caps);
|
||||||
gst_caps_unref (caps);
|
gst_caps_unref (caps);
|
||||||
|
|
||||||
|
@ -910,11 +915,15 @@ test_average_bitrate_custom (const gchar * elementname,
|
||||||
|
|
||||||
GST_START_TEST (test_average_bitrate)
|
GST_START_TEST (test_average_bitrate)
|
||||||
{
|
{
|
||||||
test_average_bitrate_custom ("mp4mux", &srcaudioaactemplate, "audio_%u");
|
test_average_bitrate_custom ("mp4mux", &srcaudioaactemplate,
|
||||||
test_average_bitrate_custom ("mp4mux", &srcvideoh264template, "video_%u");
|
AUDIO_AAC_CAPS_STRING, "audio_%u");
|
||||||
|
test_average_bitrate_custom ("mp4mux", &srcvideoh264template,
|
||||||
|
VIDEO_CAPS_H264_STRING, "video_%u");
|
||||||
|
|
||||||
test_average_bitrate_custom ("qtmux", &srcaudioaactemplate, "audio_%u");
|
test_average_bitrate_custom ("qtmux", &srcaudioaactemplate,
|
||||||
test_average_bitrate_custom ("qtmux", &srcvideoh264template, "video_%u");
|
AUDIO_AAC_CAPS_STRING, "audio_%u");
|
||||||
|
test_average_bitrate_custom ("qtmux", &srcvideoh264template,
|
||||||
|
VIDEO_CAPS_H264_STRING, "video_%u");
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_END_TEST;
|
GST_END_TEST;
|
||||||
|
|
Loading…
Reference in a new issue