gstreamer/subprojects/gst-devtools/validate/launcher/testsuites/check.py
2024-10-26 02:09:44 +01:00

283 lines
20 KiB
Python

# -*- Mode: Python -*- vi:si:et:sw=4:sts=4:ts=4:syntax=python
#
# Copyright (c) 2016,Thibault Saunier <thibault.saunier@osg.samsung.com>
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.
#
# This program 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
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this program; if not, write to the
# Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
# Boston, MA 02110-1301, USA.
"""
GStreamer unit tests
"""
from launcher import utils
import os
TEST_MANAGER = "check"
KNOWN_NOT_LEAKY = r'^gst-devtools.*|^gstreamer.*|^gst-plugins-base|^gst-plugins-ugly|^gst-plugins-good'
# These tests take very long compared to what they add, so let's skip them.
LONG_VALGRIND_TESTS = [
(r'check.[a-z-]*.generic_states.test_state_changes_down_seq', 'enough to run one of the sequences'),
(r'check.[a-z-]*.generic_states.test_state_changes_up_seq', 'enough to run one of the sequences',),
(r'check.[a-z-]*.generic_states.test_state_changes_up_and_down_seq', 'enough to run the sequences'),
(r'check.gstreamer.gst_gstelement.test_foreach_pad$', '48s'),
(r'check.gstreamer.gst_gstinfo.info_post_gst_init_category_registration$', '21s'),
(r'check.gstreamer.gst_gstsystemclock.test_resolution$', '60s'),
(r'check.gstreamer.libs_aggregator.test_infinite_seek$', '20s'),
(r'check.gstreamer.libs_aggregator.test_infinite_seek_50_src$', '20s'),
(r'check.gstreamer.libs_gstharness.test_harness_element_ref$', '20s'),
(r'check.gstreamer.pipelines_simple_launch_lines.test_2_elements$', '58s'),
(r'check.gstreamer.pipelines_stress.test_stress$', '54s'),
(r'check.gstreamer.pipelines_stress.test_stress_preroll$', '27s'),
(r'check.gst-plugins-base.elements_appsrc.test_appsrc_limits', '53.37s'),
(r'check.gst-plugins-base.elements_appsrc.test_appsrc_send_event_before_buffer', '49.25s'),
(r'check.gst-plugins-base.elements_appsrc.test_appsrc_send_event_before_sample', '51.39s'),
(r'check.gst-plugins-base.elements_appsrc.test_appsrc_send_event_between_caps_buffer', '56.13s'),
(r'check.gst-plugins-base.elements_appsrc.test_appsrc_block_deadlock$', '265.595s'),
(r'check.gst-plugins-base.elements_audioresample.test_fft$', '91.247s'),
(r'check.gst-plugins-base.elements_audioresample.test_timestamp_drift$', '141.784s'),
(r'check.gst-plugins-base.elements-videoscale.*', 'superlong'),
(r'check.gst-plugins-base.libs_video.test_overlay_blend$', '74.096s'),
(r'check.gst-plugins-base.libs_video.test_video_color_convert$', '345.271s'),
(r'check.gst-plugins-base.libs_video.test_video_formats$', '70.987s'),
(r'check.gst-plugins-base.libs_video.test_video_size_convert$', '56.387s'),
(r'check.gst-plugins-base.elements_audiointerleave.test_audiointerleave_2ch_pipeline_$', '5 *51.069s'),
(r'check.gst-plugins-base.elements_multifdsink.test_client_kick$', '46.909s'),
(r'check.gst-plugins-base.elements_videotestsrc.test_all_patterns$', '?'),
(r'check.gst-plugins-base.elements_videotestsrc.test_patterns_are_deterministic$', '?'),
(r'check.gst-plugins-good.elements_shapewipe.test_general$', '325s'),
(r'check.gst-plugins-good.elements_videocrop.test_cropping$', '245s'),
(r'check.gst-plugins-good.elements_videomixer.*', '30s (alsodeprecated)'),
(r'check.gst-plugins-good.elements_rtp_payloading.rtp_jpeg_packet_loss$', '109s'),
(r'check.gst-plugins-good.elements_videomixer.test_play_twice_then_add_and_play_again$', '55s'),
(r'check.gst-plugins-good.pipelines_effectv.test_quarktv$', '53s'),
(r'check.gst-plugins-good.elements_deinterlace.test_mode_disabled_passthrough$', '52s'),
(r'check.gst-plugins-good.elements_deinterlace.test_mode_auto_deinterlaced_passthrough$', '28s'),
(r'check.gst-plugins-good.elements_deinterleave.test_2_channels_caps_change$', '30s'),
(r'check.gst-plugins-good.elements_deinterleave.test_2_channels$', '22s'),
(r'check.gst-plugins-good.elements_rtpjitterbuffer.test_fill_queue$', '22s'),
(r'check.gst-plugins-good.elements_splitmux.test_splitmuxsink_async$', '20s'),
(r'check.gst-plugins-good.elements_videomixer.test_play_twice$', '22s'),
(r'check.gst-editing-services.nle_simple.test_one_after_other$', '40s'),
(r'check.gst-editing-services.nle_nleoperation.test_pyramid_operations_expandable', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_nleoperation.test_complex_operations', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_nleoperation.test_pyramid_operations', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_nleoperation.test_pyramid_operations2', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_complex.test_one_above_another', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_nleoperation.test_simple_operation', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.seek_with_stop.check_clock_sync', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.edit_while_seeked_with_stop', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.seek_with_stop', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_tempochange.test_tempochange_seek', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
(r'check.gst-editing-services.nle_tempochange.test_tempochange_play', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/780'),
]
VALGRIND_BLACKLIST = [
(r'check.gstreamer.gst_gstsystemclock.test_stress_cleanup_unschedule', '?'),
(r'check.gstreamer.gst_gstsystemclock.test_stress_reschedule', '?'),
(r'check.gstreamer.tools_gstinspect', '?'),
(r'check.gst-plugins-base.elements_videoscale', '?'),
(r'check.gst-plugins-base.pipelines_gl_launch_lines', '?'),
(r'check.gst-plugins-base.libs_gstgl', 'driver leaks / memory access'),
(r'check.gst-plugins-base.elements_gl', 'driver leaks / memory access'),
(r'check.gst-plugins-base.elements_libvisual', 'uninitialized memory access'),
(r'check.gst-plugins-base.generic_states', 'need to add gl elements to ignore list but only if using valgrind'),
(r'check.gst-plugins-good.elements_rtpjitterbuffer.test_push_backward_seq', 'flaky in valgrind'),
(r'check.gst-plugins-good.elements_rtpjitterbuffer.test_push_unordered', 'flaky in valgrind'),
(r'check.gst-plugins-bad.elements_assrender', '?'),
(r'check.gst-plugins-bad.elements_autovideoconvert.test_autovideoconvert_videoconvert', 'Leak with GLX, https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3216'),
(r'check.gst-plugins-bad.elements_camerabin', '?'),
(r'check.gst-plugins-bad.elements_line21', '?'),
(r'check.gst-plugins-bad.elements_mpeg2enc', '?'),
(r'check.gst-plugins-bad.elements_mplex', '?'),
(r'check.gst-plugins-bad.elements_mxfmux', '?'),
(r'check.gst-plugins-bad.elements_srt.test_src_listener_sink_caller', 'Need to investigate libsrt leaks (flaky)'),
(r'check.gst-plugins-bad.elements_x265enc', '?'),
(r'check.gst-plugins-bad.elements_zbar', '?'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_remote_notify', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_pre_negotiated', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_low_threshold', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_transfer_data', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_transfer_string', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_create_after_negotiate', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_data_channel_max_message_size', 'Need to fix leaks'),
(r'check.gst-plugins-bad.elements_webrtcbin.test_renego_data_channel_add_stream', 'Need to fix leaks (possibly flaky)'),
(r'check.gst-libav.generic_plugin_test', '?'),
(r'check.gst-libav.generic_libavcodec_locking', '?'),
(r'check.gst-libav.elements_avdemux_ape', '?'),
(r'check.gst-editing-services.pythontests', 'Need to figure out how to introduce python suppressions'),
(r'check.gst-editing-services.check_keyframes_in_compositor_two_sources', 'Valgrind exit with an exitcode 20 but shows no issue: https://gitlab.freedesktop.org/thiblahute/gst-editing-services/-/jobs/4079972'),
(r'check.gst-plugins-good.elements_splitmuxsrc.test_splitmuxsrc_sparse_streams', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/739'),
(r'check.gst-plugins-good.elements_udpsrc.test_udpsrc_empty_packet', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/740'),
(r'check.gst-plugins-bad.elements_svthevc*', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3011'),
(r'check.gst-plugins-bad.elements_srtp.test_roc', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3939'),
]
BLACKLIST = [
(r'check.gstreamer.gst_gstsystemclock.test_stress_cleanup_unschedule', 'flaky under high server load'),
(r'check.gstreamer.gst_gstsystemclock.test_stress_reschedule', 'flaky under high server load'),
(r'check.gstreamer.pipelines_seek.test_loopback_2$', '?'),
(r'check.gstreamer.gst_gstelement.test_foreach_pad$', '?'),
(r'check.gstreamer.libs_baseparse.parser_pull_short_read$', '?'),
(r'check.gst-plugins-base.elements_multisocketsink.test_sending_buffers_with_9_gstmemories$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/779'),
(r'check.gst-plugins-base.elements_multisocketsink.test_client_next_keyframe$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/779'),
(r'check.gst-plugins-base.elements_multisocketsink.test_add_client$', ''),
(r'check.gst-plugins-base.elements_multisocketsink.test_burst_client_bytes$', ''),
(r'check.gst-plugins-base.libs_gstglcolorconvert.test_reorder_buffer$', '?'),
(r'check.gst-plugins-base.elements_audiotestsrc.test_layout$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/781'),
(r'check.gst-plugins-good.elements_souphttpsrc.test_icy_stream$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/782'),
(r'check.gst-plugins-good.elements_rtpbin.test_sender_eos$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/783'),
(r'check.gst-plugins-good.elements_rtpbin.test_cleanup_recv$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/784'),
(r'check.gst-plugins-good.elements_flvmux.test_incrementing_timestamps$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/785'),
(r'check.gst-plugins-good.elements_flvmux.test_video_caps_late$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/786'),
(r'check.gst-plugins-base.elements_appsrc.test_appsrc_blocked_on_caps$', '?'),
(r'check.gst-plugins-good.elements_splitmux.test_splitmuxsink$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/issues/626'),
(r'check.gst-plugins-good.elements_splitmux.test_splitmuxsrc_sparse_streams$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/739'),
(r'check.gst-plugins-good.elements_splitmux.test_splitmuxsrc_caps_change$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/issues/547'),
(r'check.gst-plugins-bad.elements_dtls.test_data_transfer$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/issues/811'),
(r'check.gst-plugins-bad.elements_dtls.test_create_and_unref$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/issues/811'),
(r'check.gst-plugins-bad.elements_camerabin.test_image_video_cycle$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/787'),
(r'check.gst-plugins-bad.elements_camerabin.test_single_video_recording$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/787#note_1101544'),
(r'check.gst-plugins-bad.elements_camerabin.test_multiple_video_recordings$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/787#note_1101546'),
(r'check.gst-plugins-bad.elements_curlhttpsrc.test_multiple_http_requests$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/788'),
(r'check.gst-plugins-good.elements_rtpsession.test_multiple_senders_roundrobin_rbs$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/789'),
(r'check.gst-plugins-bad.elements_shm.test_shm_live$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/790'),
(r'check.gst-plugins-bad.validate.autovideoconvert.renegotiate$', ''),
(r'check.gst-plugins-good.elements_splitmux.test_splitmuxsink_async$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/791'),
(r'check.gst-plugins-bad.elements_netsim.netsim_stress', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/792'),
(r'check.gst-editing-services.nle_complex.test_one_expandable_another$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/793'),
(r'check.gst-editing-services.nle_simple.test_simplest$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/794'),
(r'check.gst-editing-services.ges_basic.test_ges_pipeline_change_state$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/795'),
(r'check.gst-editing-services.pythontests.pyunittest.python.test_timeline.TestTransitions.test_transition_type$', '[FIXME -- SHOULD BE FIXED] https://gitlab.freedesktop.org/gstreamer/gst-editing-services/issues/62'),
(r'check.gst-editing-services.pythontests.pyunittest.python.test_timeline.TestTransitions.test_auto_transition$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/796'),
(r'check.gst-plugins-base.pipelines_tcp.test_that_tcpserversink_and_tcpclientsrc_are_symmetrical$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/797'),
(r'check.gstreamer.elements_capsfilter.test_unfixed_downstream_caps$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/issues/335'),
(r'check.gst-rtsp-server.gst_rtspclientsink.test_record$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/798'),
(r'check.gst-rtsp-server.gst_rtspserver.test_shared_udp$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/799'),
(r'check.gst-plugins-base.elements_audiomixer.test_flush_start_flush_stop$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/800'),
(r'check.gstreamer-sharp.SdpTests$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/801'),
(r'check.gst-devtools.validate.launcher_tests.test_validate.launch_pipeline.not_negotiated.caps_query_failure.play_15s$', '?'),
(r'check.gst-editing-services.nle_simple.test_one_bin_after_other$', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/802'),
(r'check.gstreamer-vaapi.*$', 'only run the tests explicitly'),
(r'check.gst-rtsp-server.gst_rtspserver.test_multiple_transports', 'https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/767'),
]
CI_BLACKLIST = [
(r'check.gst-plugins-bad.elements_vk*', 'Mesa in the CI image is older, will start passing once we update to llvm16 and mesa 23.1'),
(r'check.gst-plugins-bad.libs_vk*', 'Mesa in the CI image is older, will start passing once we update to llvm16 and mesa 23.1'),
(r'check.gst-plugins-good.elements_souphttpsrc2.test_icy_stream', 'flaky in valgrind, leaks in CI but not locally'),
]
KNOWN_ISSUES = {
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/2973": {
"tests": [
"check.gst-editing-services.complex_effect_bin_desc"
],
"issues": [
{
'returncode': 238,
'sometimes': True,
},
{
"issue-id": "validateflow::mismatch",
"summary": "The recorded log does not match the expectation file.",
"level": "critical",
# "details": "Mismatch error in pad videosink:sink, line 4. Expected:\nbuffer: checksum=369888c2612267760fcfaa74e52fc53bd73e4d15, pts=0:00:00.000000000, dur=0:00:00.033333333, meta=GstVideoMeta\nActual:\nbuffer: checksum=b7764dce84f311119c4c36b511ba5adb66de76af, pts=0:00:00.000000000, dur=0:00:00.033333333, meta=GstVideoMeta\n",
},
],
},
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/773": {
"tests": [
r"check.gst-plugins-bad.elements_webrtcbin.*",
],
"max_retries": 1,
},
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/775": {
"tests": [
r"check.gst-editing-services.check_edit_in_frames_with_framerate_mismatch",
],
"max_retries": 1,
},
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/776": {
"tests": [
r"check.gst-plugins-base.validate.giosrc.read-growing-file",
],
"max_retries": 1,
},
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/803": {
"tests": [
"check.gst-editing-services.edit_while_seeked_with_stop"
],
"issues": [
{
'returncode': None,
'sometimes': True,
},
{
'timeout': True,
'sometimes': True,
},
],
},
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/804": {
"tests": [
"check.gst-editing-services.check_layer_activness_gaps"
],
"issues": [
{
'returncode': 18,
'sometimes': True,
},
{
"issue-id": "scenario::execution-error",
"summary": "The execution of an action did not properly happen",
"level": "critical",
"detected-on": "check_layer_activness_gaps.scenario",
# "details": "\n> check_layer_activness_gaps.scenario:22\n 22 | check-property, target-element-factory-name=videotestsrc, property-name=pattern, property-value="Blue"\n >\n > <src>::pattern expected value: '(gchararray)Blue' different than observed: '(gchararray)"100\%\ Black"'",
},
],
},
"https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/1777": {
"tests": [
"check.gst-plugins-bad.elements_srtp.test_play.*"
],
"issues": [
{
'returncode': 1,
'sometimes': True,
},
],
},
}
def setup_tests(test_manager, options):
if options.gst_check_leak_trace_testnames == 'known-not-leaky':
options.gst_check_leak_trace_testnames = KNOWN_NOT_LEAKY
test_manager.set_default_blacklist(BLACKLIST)
if options.valgrind:
test_manager.set_default_blacklist(VALGRIND_BLACKLIST)
if options.long_limit <= utils.LONG_TEST:
test_manager.set_default_blacklist(LONG_VALGRIND_TESTS)
if 'CI_COMMIT_SHA' in os.environ:
test_manager.set_default_blacklist(CI_BLACKLIST)
test_manager.add_expected_issues(KNOWN_ISSUES)
test_manager.register_tests()
return True