kumquat-buildroot/support/testing/tests/package/sample_gst1_python.py

33 lines
803 B
Python
Raw Normal View History

#!/usr/bin/env python3
support/testing: fix test_gst1_python The config is missing the following packages: - BR2_PACKAGE_GST1_PLUGINS_BASE This is needed for the videotestsrc plugin which provides videotestsrc. - BR2_PACKAGE_GST1_PLUGINS_BAD This is needed for the debugutils plugin which provides fakevideosink. - BR2_PACKAGE_GST1_PLUGINS_BASE_PLUGIN_VIDEOTESTSRC videotestsrcplugin used by the example pipeline. - BR2_PACKAGE_GST1_PLUGINS_BAD_PLUGIN_DEBUGUTILS fakevideosink plugin used by the example pipeline. The sample was also amended to fix: - no call to main. - using autovideosink instead of fakevideosink. Using Fakevideoskink is preferred because its primary purpose is for debugging and sample pipelines. Autovideosink does not work because there is no video output device. - No function on_message. Without this function, the script fails because of the missing function. - The script sets the pipeline to Gst.State.EOS instead of Gst.State.NULL which results in a failed pipeline state. When the state is set to NULL, gstreamer automatically calls EOS. Manually setting the pipeline state to EOS results in the following error: Trying to dispose element sink, but it is in PLAYING instead of the NULL state. You need to explicitly set elements to the NULL state before dropping the final reference, to allow them to clean up. A refcounting bug may also cause this problem in the application or some element. In addition, the default timeout is set too low and would result in a test failure, this has been changed to 200 seconds. These issues are now properly fixed, and the sample script passes. Signed-off-by: Adam Duskett <Aduskett@gmail.com> [yann.morin.1998@free.fr: - meld the two patches together - add the print() in the on_demand callback ] Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
2020-03-24 18:38:53 +01:00
"""A simple test that uses gst1-python to run a fake videotestsrc for 100
frames
"""
import sys
import gi
gi.require_version('Gst', '1.0')
from gi.repository import Gst, GLib # noqa: E402
def on_message(bus, message, loop):
support/testing: fix test_gst1_python The config is missing the following packages: - BR2_PACKAGE_GST1_PLUGINS_BASE This is needed for the videotestsrc plugin which provides videotestsrc. - BR2_PACKAGE_GST1_PLUGINS_BAD This is needed for the debugutils plugin which provides fakevideosink. - BR2_PACKAGE_GST1_PLUGINS_BASE_PLUGIN_VIDEOTESTSRC videotestsrcplugin used by the example pipeline. - BR2_PACKAGE_GST1_PLUGINS_BAD_PLUGIN_DEBUGUTILS fakevideosink plugin used by the example pipeline. The sample was also amended to fix: - no call to main. - using autovideosink instead of fakevideosink. Using Fakevideoskink is preferred because its primary purpose is for debugging and sample pipelines. Autovideosink does not work because there is no video output device. - No function on_message. Without this function, the script fails because of the missing function. - The script sets the pipeline to Gst.State.EOS instead of Gst.State.NULL which results in a failed pipeline state. When the state is set to NULL, gstreamer automatically calls EOS. Manually setting the pipeline state to EOS results in the following error: Trying to dispose element sink, but it is in PLAYING instead of the NULL state. You need to explicitly set elements to the NULL state before dropping the final reference, to allow them to clean up. A refcounting bug may also cause this problem in the application or some element. In addition, the default timeout is set too low and would result in a test failure, this has been changed to 200 seconds. These issues are now properly fixed, and the sample script passes. Signed-off-by: Adam Duskett <Aduskett@gmail.com> [yann.morin.1998@free.fr: - meld the two patches together - add the print() in the on_demand callback ] Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
2020-03-24 18:38:53 +01:00
print('Received Gst.Message.type: {}'.format(message.type))
if message.type == Gst.MessageType.EOS:
loop.quit()
return True
def main():
# Initializes Gstreamer
Gst.init(sys.argv)
support/testing: fix test_gst1_python The config is missing the following packages: - BR2_PACKAGE_GST1_PLUGINS_BASE This is needed for the videotestsrc plugin which provides videotestsrc. - BR2_PACKAGE_GST1_PLUGINS_BAD This is needed for the debugutils plugin which provides fakevideosink. - BR2_PACKAGE_GST1_PLUGINS_BASE_PLUGIN_VIDEOTESTSRC videotestsrcplugin used by the example pipeline. - BR2_PACKAGE_GST1_PLUGINS_BAD_PLUGIN_DEBUGUTILS fakevideosink plugin used by the example pipeline. The sample was also amended to fix: - no call to main. - using autovideosink instead of fakevideosink. Using Fakevideoskink is preferred because its primary purpose is for debugging and sample pipelines. Autovideosink does not work because there is no video output device. - No function on_message. Without this function, the script fails because of the missing function. - The script sets the pipeline to Gst.State.EOS instead of Gst.State.NULL which results in a failed pipeline state. When the state is set to NULL, gstreamer automatically calls EOS. Manually setting the pipeline state to EOS results in the following error: Trying to dispose element sink, but it is in PLAYING instead of the NULL state. You need to explicitly set elements to the NULL state before dropping the final reference, to allow them to clean up. A refcounting bug may also cause this problem in the application or some element. In addition, the default timeout is set too low and would result in a test failure, this has been changed to 200 seconds. These issues are now properly fixed, and the sample script passes. Signed-off-by: Adam Duskett <Aduskett@gmail.com> [yann.morin.1998@free.fr: - meld the two patches together - add the print() in the on_demand callback ] Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
2020-03-24 18:38:53 +01:00
pipeline = Gst.parse_launch("videotestsrc num-buffers=100 ! fakevideosink")
bus = pipeline.get_bus()
bus.add_signal_watch()
pipeline.set_state(Gst.State.PLAYING)
loop = GLib.MainLoop()
bus.connect("message", on_message, loop)
loop.run()
support/testing: fix test_gst1_python The config is missing the following packages: - BR2_PACKAGE_GST1_PLUGINS_BASE This is needed for the videotestsrc plugin which provides videotestsrc. - BR2_PACKAGE_GST1_PLUGINS_BAD This is needed for the debugutils plugin which provides fakevideosink. - BR2_PACKAGE_GST1_PLUGINS_BASE_PLUGIN_VIDEOTESTSRC videotestsrcplugin used by the example pipeline. - BR2_PACKAGE_GST1_PLUGINS_BAD_PLUGIN_DEBUGUTILS fakevideosink plugin used by the example pipeline. The sample was also amended to fix: - no call to main. - using autovideosink instead of fakevideosink. Using Fakevideoskink is preferred because its primary purpose is for debugging and sample pipelines. Autovideosink does not work because there is no video output device. - No function on_message. Without this function, the script fails because of the missing function. - The script sets the pipeline to Gst.State.EOS instead of Gst.State.NULL which results in a failed pipeline state. When the state is set to NULL, gstreamer automatically calls EOS. Manually setting the pipeline state to EOS results in the following error: Trying to dispose element sink, but it is in PLAYING instead of the NULL state. You need to explicitly set elements to the NULL state before dropping the final reference, to allow them to clean up. A refcounting bug may also cause this problem in the application or some element. In addition, the default timeout is set too low and would result in a test failure, this has been changed to 200 seconds. These issues are now properly fixed, and the sample script passes. Signed-off-by: Adam Duskett <Aduskett@gmail.com> [yann.morin.1998@free.fr: - meld the two patches together - add the print() in the on_demand callback ] Signed-off-by: Yann E. MORIN <yann.morin.1998@free.fr>
2020-03-24 18:38:53 +01:00
pipeline.set_state(Gst.State.NULL)
if __name__ == '__main__':
main()