gst-validate

gst-validate is the simplest gst-launch-like pipeline launcher running inside GstValidate monitoring infrastructure. Monitors are added to it to identify issues in the used elements. At the end it will print a report with some information about all the issues encountered during its run. To view issues as they are detected, set the environment variable GST_DEBUG=validate:2{.shell} and they will get printed in the GStreamer debug log. You can basically run any GstPipeline pipeline using this tool. If you are not familiar with gst-launch syntax, please refer to gst-launch's documentation.

Simple playback pipeline:

gst-validate-1.0 playbin uri=file:///path/to/some/media/file

Transcoding pipeline:

gst-validate-1.0 filesrc location=/media/file/location ! qtdemux name=d ! queue \
        ! x264enc ! h264parse ! mpegtsmux name=m ! progressreport \
        ! filesink location=/root/test.ts d. ! queue ! faac ! m.

It will list each issue that has been encountered during the execution of the specified pipeline in a human readable report like:

issue : buffer is out of the segment range Detected on theoradec0.srcpad at 0:00:00.096556426

Details : buffer is out of segment and shouldn't be pushed. Timestamp: 0:00:25.000 - duration: 0:00:00.040 Range: 0:00:00.000 - 0:00:04.520
Description : buffer being pushed is out of the current segment's start-stop  range. Meaning it is going to be discarded downstream without any use

The return code of the process will be 18 in case a CRITICAL issue has been found.

Invocation

gst-validate takes a mandatory description of the pipeline to launch, similar to gst-launch, and some extra options.

Options

  • --set-scenario: Let you set a scenario, it can be a full path to a scenario file or the name of the scenario (name of the file without the .scenario extension).
  • -l, --list-scenarios: List the avalaible scenarios that can be run.
  • --scenarios-defs-output-file: The output file to store scenarios details. Implies --list-scenario.
  • -t, --inspect-action-type: Inspect the avalaible action types with which to write scenarios if no parameter passed, it will list all avalaible action types otherwize will print the full description of the wanted types.
  • --set-media-info: Set a media_info XML file descriptor to share information about the media file that will be reproduced.
  • --set-configs: Let you set a config scenario. The scenario needs to be set as config. You can specify a list of scenarios separated by ":". It will override the GST_VALIDATE_SCENARIO environment variable.

The results of the search are