mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 02:15:31 +00:00
validate: Enhance error reporting for errors in struct files
Get a sense of files and line numbers in the parsed GstStructure and take that information when reporting GstValidateAction errors by letting the user know where the action comes from in the messages. And accept non-literal string in printing formats.
This commit is contained in:
parent
cf6fb4a7f2
commit
d86fa2c44a
7 changed files with 277 additions and 157 deletions
|
@ -116,7 +116,6 @@ warning_flags = [
|
||||||
'-Wundef',
|
'-Wundef',
|
||||||
'-Wwrite-strings',
|
'-Wwrite-strings',
|
||||||
'-Wformat',
|
'-Wformat',
|
||||||
'-Wformat-nonliteral',
|
|
||||||
'-Wformat-security',
|
'-Wformat-security',
|
||||||
'-Winit-self',
|
'-Winit-self',
|
||||||
'-Wmissing-include-dirs',
|
'-Wmissing-include-dirs',
|
||||||
|
|
|
@ -145,6 +145,12 @@ typedef enum {
|
||||||
#define G_LOG_WARNING _QUARK("g-log::warning")
|
#define G_LOG_WARNING _QUARK("g-log::warning")
|
||||||
#define G_LOG_CRITICAL _QUARK("g-log::critical")
|
#define G_LOG_CRITICAL _QUARK("g-log::critical")
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GstValidateIssueFlags:
|
||||||
|
* GST_VALIDATE_ISSUE_FLAGS_NONE: No special flags for the issue type
|
||||||
|
* GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS: Always show all accurences of the issue in full details
|
||||||
|
* GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE: Do not generate backtrace for the issue type
|
||||||
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
GST_VALIDATE_ISSUE_FLAGS_NONE = 0,
|
GST_VALIDATE_ISSUE_FLAGS_NONE = 0,
|
||||||
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS = 1 << 0,
|
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS = 1 << 0,
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <math.h>
|
||||||
#include "gst-validate-internal.h"
|
#include "gst-validate-internal.h"
|
||||||
#include "gst-validate-reporter.h"
|
#include "gst-validate-reporter.h"
|
||||||
#include "gst-validate-report.h"
|
#include "gst-validate-report.h"
|
||||||
|
@ -308,8 +309,7 @@ gst_validate_reporter_g_log_func (const gchar * log_domain,
|
||||||
* format followed by the parameters.
|
* format followed by the parameters.
|
||||||
* @...: Substitution arguments for @format
|
* @...: Substitution arguments for @format
|
||||||
*
|
*
|
||||||
* Reports a new issue in the GstValidate reporting system with @m
|
* Reports a new issue in the GstValidate reporting system.
|
||||||
* as the source of that issue.
|
|
||||||
*
|
*
|
||||||
* You can also use #GST_VALIDATE_REPORT instead.
|
* You can also use #GST_VALIDATE_REPORT instead.
|
||||||
*/
|
*/
|
||||||
|
@ -324,6 +324,40 @@ gst_validate_report (GstValidateReporter * reporter,
|
||||||
va_end (var_args);
|
va_end (var_args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_validate_report_action:
|
||||||
|
* @reporter: The source of the new report
|
||||||
|
* @action: The action reporting the issue
|
||||||
|
* @issue_id: The #GstValidateIssueId of the issue
|
||||||
|
* @format: The format of the message describing the issue in a printf
|
||||||
|
* format followed by the parameters.
|
||||||
|
* @...: Substitution arguments for @format
|
||||||
|
*
|
||||||
|
* Reports a new issue in the GstValidate reporting system specifying @action
|
||||||
|
* as failling action .
|
||||||
|
*
|
||||||
|
* You can also use #GST_VALIDATE_REPORT instead.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
gst_validate_report_action (GstValidateReporter * reporter,
|
||||||
|
GstValidateAction * action, GstValidateIssueId issue_id,
|
||||||
|
const gchar * format, ...)
|
||||||
|
{
|
||||||
|
va_list var_args;
|
||||||
|
gchar *f = g_strdup_printf ("\n> %s:%d\n> %d | %s\n> %*c|\n",
|
||||||
|
GST_VALIDATE_ACTION_FILENAME (action),
|
||||||
|
GST_VALIDATE_ACTION_LINENO (action), GST_VALIDATE_ACTION_LINENO (action),
|
||||||
|
format,
|
||||||
|
(gint) floor (log10 (abs ((GST_VALIDATE_ACTION_LINENO (action))))) + 1,
|
||||||
|
' ');
|
||||||
|
|
||||||
|
va_start (var_args, format);
|
||||||
|
gst_validate_report_valist (reporter, issue_id, f, var_args);
|
||||||
|
va_end (var_args);
|
||||||
|
|
||||||
|
g_free (f);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gst_validate_reporter_report_simple (GstValidateReporter * reporter,
|
gst_validate_reporter_report_simple (GstValidateReporter * reporter,
|
||||||
GstValidateIssueId issue_id, const gchar * message)
|
GstValidateIssueId issue_id, const gchar * message)
|
||||||
|
|
|
@ -28,6 +28,7 @@ typedef struct _GstValidateReporterInterface GstValidateReporterInterface;
|
||||||
#include <gst/validate/gst-validate-report.h>
|
#include <gst/validate/gst-validate-report.h>
|
||||||
#include <gst/validate/gst-validate-runner.h>
|
#include <gst/validate/gst-validate-runner.h>
|
||||||
#include <gst/validate/gst-validate-enums.h>
|
#include <gst/validate/gst-validate-enums.h>
|
||||||
|
#include <gst/validate/gst-validate-scenario.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
@ -56,6 +57,13 @@ G_BEGIN_DECLS
|
||||||
__VA_ARGS__ ); \
|
__VA_ARGS__ ); \
|
||||||
} G_STMT_END
|
} G_STMT_END
|
||||||
|
|
||||||
|
#define GST_VALIDATE_REPORT_ACTION(m, a, issue_id, ...) \
|
||||||
|
G_STMT_START { \
|
||||||
|
gst_validate_report_action (GST_VALIDATE_REPORTER (m), a, \
|
||||||
|
issue_id, \
|
||||||
|
__VA_ARGS__ ); \
|
||||||
|
} G_STMT_END
|
||||||
|
|
||||||
#else /* G_HAVE_GNUC_VARARGS */
|
#else /* G_HAVE_GNUC_VARARGS */
|
||||||
#ifdef G_HAVE_GNUC_VARARGS
|
#ifdef G_HAVE_GNUC_VARARGS
|
||||||
#define GST_VALIDATE_REPORT(m, issue_id, args...) \
|
#define GST_VALIDATE_REPORT(m, issue_id, args...) \
|
||||||
|
@ -63,6 +71,11 @@ G_BEGIN_DECLS
|
||||||
gst_validate_report (GST_VALIDATE_REPORTER (m), \
|
gst_validate_report (GST_VALIDATE_REPORTER (m), \
|
||||||
issue_id, ##args ); \
|
issue_id, ##args ); \
|
||||||
} G_STMT_END
|
} G_STMT_END
|
||||||
|
#define GST_VALIDATE_REPORT_ACTION(m, a, issue_id, args...) \
|
||||||
|
G_STMT_START { \
|
||||||
|
gst_validate_report_action (GST_VALIDATE_REPORTER (m), a, \
|
||||||
|
issue_id, ##args ); \
|
||||||
|
} G_STMT_END
|
||||||
#endif /* G_HAVE_ISO_VARARGS */
|
#endif /* G_HAVE_ISO_VARARGS */
|
||||||
#endif /* G_HAVE_GNUC_VARARGS */
|
#endif /* G_HAVE_GNUC_VARARGS */
|
||||||
GST_VALIDATE_API
|
GST_VALIDATE_API
|
||||||
|
@ -107,7 +120,12 @@ GST_VALIDATE_API
|
||||||
void gst_validate_reporter_init (GstValidateReporter * reporter, const gchar *name);
|
void gst_validate_reporter_init (GstValidateReporter * reporter, const gchar *name);
|
||||||
GST_VALIDATE_API
|
GST_VALIDATE_API
|
||||||
void gst_validate_report (GstValidateReporter * reporter, GstValidateIssueId issue_id,
|
void gst_validate_report (GstValidateReporter * reporter, GstValidateIssueId issue_id,
|
||||||
const gchar * format, ...) G_GNUC_PRINTF (3, 4) G_GNUC_NO_INSTRUMENT;
|
const gchar * format, ...) G_GNUC_PRINTF (3, 4) G_GNUC_NO_INSTRUMENT;
|
||||||
|
GST_VALIDATE_API
|
||||||
|
void gst_validate_report_action (GstValidateReporter * reporter,
|
||||||
|
GstValidateAction *action,
|
||||||
|
GstValidateIssueId issue_id,
|
||||||
|
const gchar * format, ...) G_GNUC_PRINTF (4, 5) G_GNUC_NO_INSTRUMENT;
|
||||||
GST_VALIDATE_API
|
GST_VALIDATE_API
|
||||||
void gst_validate_report_valist (GstValidateReporter * reporter, GstValidateIssueId issue_id,
|
void gst_validate_report_valist (GstValidateReporter * reporter, GstValidateIssueId issue_id,
|
||||||
const gchar * format, va_list var_args) G_GNUC_PRINTF (3, 0);
|
const gchar * format, va_list var_args) G_GNUC_PRINTF (3, 0);
|
||||||
|
|
|
@ -79,7 +79,7 @@ GST_DEBUG_CATEGORY_STATIC (gst_validate_scenario_debug);
|
||||||
#define DECLARE_AND_GET_PIPELINE(s,a) \
|
#define DECLARE_AND_GET_PIPELINE(s,a) \
|
||||||
GstElement * pipeline = gst_validate_scenario_get_pipeline (s); \
|
GstElement * pipeline = gst_validate_scenario_get_pipeline (s); \
|
||||||
if (pipeline == NULL) { \
|
if (pipeline == NULL) { \
|
||||||
GST_VALIDATE_REPORT (s, SCENARIO_ACTION_EXECUTION_ERROR, \
|
GST_VALIDATE_REPORT_ACTION (s, a, SCENARIO_ACTION_EXECUTION_ERROR, \
|
||||||
"Can't execute a '%s' action after the pipeline " \
|
"Can't execute a '%s' action after the pipeline " \
|
||||||
"has been destroyed.", a->type); \
|
"has been destroyed.", a->type); \
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED; \
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED; \
|
||||||
|
@ -348,6 +348,9 @@ _action_copy (GstValidateAction * act)
|
||||||
copy->action_number = act->action_number;
|
copy->action_number = act->action_number;
|
||||||
copy->playback_time = act->playback_time;
|
copy->playback_time = act->playback_time;
|
||||||
copy->priv->timeout = act->priv->timeout;
|
copy->priv->timeout = act->priv->timeout;
|
||||||
|
GST_VALIDATE_ACTION_LINENO (copy) = GST_VALIDATE_ACTION_LINENO (act);
|
||||||
|
GST_VALIDATE_ACTION_FILENAME (copy) =
|
||||||
|
g_strdup (GST_VALIDATE_ACTION_FILENAME (act));
|
||||||
|
|
||||||
return copy;
|
return copy;
|
||||||
}
|
}
|
||||||
|
@ -362,6 +365,7 @@ _action_free (GstValidateAction * action)
|
||||||
gst_structure_free (action->priv->main_structure);
|
gst_structure_free (action->priv->main_structure);
|
||||||
|
|
||||||
g_weak_ref_clear (&action->priv->scenario);
|
g_weak_ref_clear (&action->priv->scenario);
|
||||||
|
g_free (GST_VALIDATE_ACTION_FILENAME (action));
|
||||||
|
|
||||||
g_slice_free (GstValidateActionPrivate, action->priv);
|
g_slice_free (GstValidateActionPrivate, action->priv);
|
||||||
g_slice_free (GstValidateAction, action);
|
g_slice_free (GstValidateAction, action);
|
||||||
|
@ -403,6 +407,11 @@ gst_validate_action_new (GstValidateScenario * scenario,
|
||||||
action->priv->timeout = GST_CLOCK_TIME_NONE;
|
action->priv->timeout = GST_CLOCK_TIME_NONE;
|
||||||
action->type = action_type->name;
|
action->type = action_type->name;
|
||||||
action->repeat = -1;
|
action->repeat = -1;
|
||||||
|
gst_structure_get (structure,
|
||||||
|
"__lineno__", G_TYPE_INT, &GST_VALIDATE_ACTION_LINENO (action),
|
||||||
|
"__filename__", G_TYPE_STRING, &GST_VALIDATE_ACTION_FILENAME (action),
|
||||||
|
NULL);
|
||||||
|
gst_structure_remove_fields (structure, "__lineno__", "__filename__", NULL);
|
||||||
|
|
||||||
g_weak_ref_set (&action->priv->scenario, scenario);
|
g_weak_ref_set (&action->priv->scenario, scenario);
|
||||||
if (structure)
|
if (structure)
|
||||||
|
@ -676,7 +685,8 @@ gst_validate_scenario_execute_seek (GstValidateScenario * scenario,
|
||||||
stop_type, stop);
|
stop_type, stop);
|
||||||
|
|
||||||
if (format != GST_FORMAT_TIME && format != GST_FORMAT_DEFAULT) {
|
if (format != GST_FORMAT_TIME && format != GST_FORMAT_DEFAULT) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Trying to seek in format %d, but not support yet!", format);
|
"Trying to seek in format %d, but not support yet!", format);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -689,7 +699,7 @@ gst_validate_scenario_execute_seek (GstValidateScenario * scenario,
|
||||||
} else {
|
} else {
|
||||||
switch (format) {
|
switch (format) {
|
||||||
case GST_FORMAT_TIME:
|
case GST_FORMAT_TIME:
|
||||||
GST_VALIDATE_REPORT (scenario, EVENT_SEEK_NOT_HANDLED,
|
GST_VALIDATE_REPORT_ACTION (scenario, action, EVENT_SEEK_NOT_HANDLED,
|
||||||
"Could not execute seek: '(position %" GST_TIME_FORMAT
|
"Could not execute seek: '(position %" GST_TIME_FORMAT
|
||||||
"), %s (num %u, missing repeat: %i), seeking to: %" GST_TIME_FORMAT
|
"), %s (num %u, missing repeat: %i), seeking to: %" GST_TIME_FORMAT
|
||||||
" stop: %" GST_TIME_FORMAT " Rate %lf'",
|
" stop: %" GST_TIME_FORMAT " Rate %lf'",
|
||||||
|
@ -701,7 +711,7 @@ gst_validate_scenario_execute_seek (GstValidateScenario * scenario,
|
||||||
{
|
{
|
||||||
gchar *format_str = g_enum_to_string (GST_TYPE_FORMAT, format);
|
gchar *format_str = g_enum_to_string (GST_TYPE_FORMAT, format);
|
||||||
|
|
||||||
GST_VALIDATE_REPORT (scenario, EVENT_SEEK_NOT_HANDLED,
|
GST_VALIDATE_REPORT_ACTION (scenario, action, EVENT_SEEK_NOT_HANDLED,
|
||||||
"Could not execute seek in format %s '(position %" GST_TIME_FORMAT
|
"Could not execute seek in format %s '(position %" GST_TIME_FORMAT
|
||||||
"), %s (num %u, missing repeat: %i), seeking to: %" G_GINT64_FORMAT
|
"), %s (num %u, missing repeat: %i), seeking to: %" G_GINT64_FORMAT
|
||||||
" stop: %" G_GINT64_FORMAT " Rate %lf'", format_str,
|
" stop: %" G_GINT64_FORMAT " Rate %lf'", format_str,
|
||||||
|
@ -825,7 +835,7 @@ _execute_set_state (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
ret = gst_element_set_state (pipeline, state);
|
ret = gst_element_set_state (pipeline, state);
|
||||||
if (ret == GST_STATE_CHANGE_FAILURE) {
|
if (ret == GST_STATE_CHANGE_FAILURE) {
|
||||||
scenario->priv->changing_state = FALSE;
|
scenario->priv->changing_state = FALSE;
|
||||||
GST_VALIDATE_REPORT (scenario, STATE_CHANGE_FAILURE,
|
GST_VALIDATE_REPORT_ACTION (scenario, action, STATE_CHANGE_FAILURE,
|
||||||
"Failed to set state to %s", str_state);
|
"Failed to set state to %s", str_state);
|
||||||
|
|
||||||
/* Nothing async on failure, action will be removed automatically */
|
/* Nothing async on failure, action will be removed automatically */
|
||||||
|
@ -1235,7 +1245,8 @@ execute_switch_track_pb (GstValidateScenario * scenario,
|
||||||
|
|
||||||
if (relative) { /* We are changing track relatively to current track */
|
if (relative) { /* We are changing track relatively to current track */
|
||||||
if (n == 0) {
|
if (n == 0) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Trying to execute a relative %s for %s track when there"
|
"Trying to execute a relative %s for %s track when there"
|
||||||
" is no track of this type available on current stream.",
|
" is no track of this type available on current stream.",
|
||||||
action->type, type);
|
action->type, type);
|
||||||
|
@ -1404,7 +1415,7 @@ execute_switch_track_pb3 (GstValidateScenario * scenario,
|
||||||
pipeline, "validate-monitor"));
|
pipeline, "validate-monitor"));
|
||||||
|
|
||||||
if (!monitor->stream_collection) {
|
if (!monitor->stream_collection) {
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR,
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"No stream collection message received on the bus, "
|
"No stream collection message received on the bus, "
|
||||||
"can not switch track.");
|
"can not switch track.");
|
||||||
|
@ -1413,7 +1424,7 @@ execute_switch_track_pb3 (GstValidateScenario * scenario,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!monitor->streams_selected) {
|
if (!monitor->streams_selected) {
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR,
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"No streams selected message received on the bus");
|
"No streams selected message received on the bus");
|
||||||
res = GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
res = GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
|
@ -1449,7 +1460,7 @@ execute_switch_track_pb3 (GstValidateScenario * scenario,
|
||||||
|
|
||||||
if (!gst_element_send_event (pipeline,
|
if (!gst_element_send_event (pipeline,
|
||||||
gst_event_new_select_streams (new_streams))) {
|
gst_event_new_select_streams (new_streams))) {
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR, "select-streams event not handled");
|
SCENARIO_ACTION_EXECUTION_ERROR, "select-streams event not handled");
|
||||||
res = GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
res = GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -1645,7 +1656,7 @@ _check_position (GstValidateScenario * scenario, GstValidateAction * act,
|
||||||
&& *position < start_with_tolerance
|
&& *position < start_with_tolerance
|
||||||
&& priv->seek_format == GST_FORMAT_TIME)) {
|
&& priv->seek_format == GST_FORMAT_TIME)) {
|
||||||
|
|
||||||
GST_VALIDATE_REPORT (scenario, QUERY_POSITION_OUT_OF_SEGMENT,
|
GST_VALIDATE_REPORT_ACTION (scenario, act, QUERY_POSITION_OUT_OF_SEGMENT,
|
||||||
"Current position %" GST_TIME_FORMAT " not in the expected range [%"
|
"Current position %" GST_TIME_FORMAT " not in the expected range [%"
|
||||||
GST_TIME_FORMAT " -- %" GST_TIME_FORMAT, GST_TIME_ARGS (*position),
|
GST_TIME_FORMAT " -- %" GST_TIME_FORMAT, GST_TIME_ARGS (*position),
|
||||||
GST_TIME_ARGS (start_with_tolerance),
|
GST_TIME_ARGS (start_with_tolerance),
|
||||||
|
@ -1671,7 +1682,8 @@ _check_position (GstValidateScenario * scenario, GstValidateAction * act,
|
||||||
&& (GstClockTime) ABS (GST_CLOCK_DIFF (*position,
|
&& (GstClockTime) ABS (GST_CLOCK_DIFF (*position,
|
||||||
priv->segment_start)) > priv->seek_pos_tol) {
|
priv->segment_start)) > priv->seek_pos_tol) {
|
||||||
priv->seeked_in_pause = FALSE;
|
priv->seeked_in_pause = FALSE;
|
||||||
GST_VALIDATE_REPORT (scenario, EVENT_SEEK_RESULT_POSITION_WRONG,
|
GST_VALIDATE_REPORT_ACTION (scenario, act,
|
||||||
|
EVENT_SEEK_RESULT_POSITION_WRONG,
|
||||||
"Reported position after accurate seek in PAUSED state should be exactly"
|
"Reported position after accurate seek in PAUSED state should be exactly"
|
||||||
" what the user asked for. Position %" GST_TIME_FORMAT
|
" what the user asked for. Position %" GST_TIME_FORMAT
|
||||||
" is not not the expected one: %" GST_TIME_FORMAT,
|
" is not not the expected one: %" GST_TIME_FORMAT,
|
||||||
|
@ -1708,19 +1720,21 @@ _should_execute_action (GstValidateScenario * scenario, GstValidateAction * act,
|
||||||
|
|
||||||
if (!(GST_VALIDATE_ACTION_GET_TYPE (act)->flags &
|
if (!(GST_VALIDATE_ACTION_GET_TYPE (act)->flags &
|
||||||
GST_VALIDATE_ACTION_TYPE_DOESNT_NEED_PIPELINE)) {
|
GST_VALIDATE_ACTION_TYPE_DOESNT_NEED_PIPELINE)) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, act,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Trying to execute an %s action after the pipeline has been destroyed"
|
"Trying to execute an %s action after the pipeline has been destroyed"
|
||||||
" but the type has not been marked as "
|
" but the type has not been marked as "
|
||||||
"GST_VALIDATE_ACTION_TYPE_DOESNT_NEED_PIPELINE", act->type);
|
"GST_VALIDATE_ACTION_TYPE_DOESNT_NEED_PIPELINE", act->type);
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
} else if (GST_CLOCK_TIME_IS_VALID (act->playback_time)) {
|
} else if (GST_CLOCK_TIME_IS_VALID (act->playback_time)) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, act,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Trying to execute action %s with playback time %" GST_TIME_FORMAT
|
"Trying to execute action %s with playback time %" GST_TIME_FORMAT
|
||||||
" after the pipeline has been destroyed. It is impossible"
|
" after the pipeline has been destroyed. It is impossible"
|
||||||
" to execute an action with a playback time specified"
|
" to execute an action with a playback time specified"
|
||||||
" after the pipeline has been destroyed",
|
" after the pipeline has been destroyed", act->type,
|
||||||
act->type, GST_TIME_ARGS (act->playback_time));
|
GST_TIME_ARGS (act->playback_time));
|
||||||
|
|
||||||
goto no;
|
goto no;
|
||||||
}
|
}
|
||||||
|
@ -1983,7 +1997,7 @@ _execute_sub_action_action (GstValidateAction * action)
|
||||||
subaction_struct = gst_structure_from_string (subaction_str, NULL);
|
subaction_struct = gst_structure_from_string (subaction_str, NULL);
|
||||||
|
|
||||||
if (subaction_struct == NULL) {
|
if (subaction_struct == NULL) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_FILE_MALFORMED,
|
GST_VALIDATE_REPORT_ACTION (scenario, action, SCENARIO_FILE_MALFORMED,
|
||||||
"Sub action %s could not be parsed", subaction_str);
|
"Sub action %s could not be parsed", subaction_str);
|
||||||
|
|
||||||
res = GST_VALIDATE_EXECUTE_ACTION_ERROR;
|
res = GST_VALIDATE_EXECUTE_ACTION_ERROR;
|
||||||
|
@ -2003,7 +2017,8 @@ _execute_sub_action_action (GstValidateAction * action)
|
||||||
|
|
||||||
res = _fill_action (scenario, action, subaction_struct, FALSE);
|
res = _fill_action (scenario, action, subaction_struct, FALSE);
|
||||||
if (res == GST_VALIDATE_EXECUTE_ACTION_ERROR) {
|
if (res == GST_VALIDATE_EXECUTE_ACTION_ERROR) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Sub action %" GST_PTR_FORMAT " could not be filled",
|
"Sub action %" GST_PTR_FORMAT " could not be filled",
|
||||||
subaction_struct);
|
subaction_struct);
|
||||||
|
|
||||||
|
@ -2099,7 +2114,7 @@ execute_next_action_full (GstValidateScenario * scenario, GstMessage * message)
|
||||||
if (etime > act->priv->timeout) {
|
if (etime > act->priv->timeout) {
|
||||||
gchar *str = gst_structure_to_string (act->structure);
|
gchar *str = gst_structure_to_string (act->structure);
|
||||||
|
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, act,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR,
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Action %s timed out after: %" GST_TIME_FORMAT, str,
|
"Action %s timed out after: %" GST_TIME_FORMAT, str,
|
||||||
GST_TIME_ARGS (etime));
|
GST_TIME_ARGS (etime));
|
||||||
|
@ -2142,7 +2157,7 @@ execute_next_action_full (GstValidateScenario * scenario, GstMessage * message)
|
||||||
if (act->priv->state == GST_VALIDATE_EXECUTE_ACTION_ERROR) {
|
if (act->priv->state == GST_VALIDATE_EXECUTE_ACTION_ERROR) {
|
||||||
gchar *str = gst_structure_to_string (act->structure);
|
gchar *str = gst_structure_to_string (act->structure);
|
||||||
|
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, act,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR, "Could not execute %s", str);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Could not execute %s", str);
|
||||||
|
|
||||||
g_free (str);
|
g_free (str);
|
||||||
|
@ -2560,7 +2575,8 @@ _execute_set_or_check_property (GstValidateScenario * scenario,
|
||||||
|
|
||||||
targets = _find_elements_defined_in_action (scenario, action);
|
targets = _find_elements_defined_in_action (scenario, action);
|
||||||
if (!targets) {
|
if (!targets) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"No element found for action: %" GST_PTR_FORMAT, action->structure);
|
"No element found for action: %" GST_PTR_FORMAT, action->structure);
|
||||||
|
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
|
@ -2590,7 +2606,8 @@ _execute_set_or_check_property (GstValidateScenario * scenario,
|
||||||
gchar *expected = gst_value_serialize (property_value), *observed =
|
gchar *expected = gst_value_serialize (property_value), *observed =
|
||||||
gst_value_serialize (&cvalue);
|
gst_value_serialize (&cvalue);
|
||||||
|
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"%s::%s expected value: '%s' different than observed: '%s'",
|
"%s::%s expected value: '%s' different than observed: '%s'",
|
||||||
GST_OBJECT_NAME (l->data), property, expected, observed);
|
GST_OBJECT_NAME (l->data), property, expected, observed);
|
||||||
|
|
||||||
|
@ -2778,8 +2795,9 @@ _execute_appsrc_push (GstValidateScenario * scenario,
|
||||||
target = _get_target_element (scenario, action);
|
target = _get_target_element (scenario, action);
|
||||||
if (target == NULL) {
|
if (target == NULL) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"No element found for action: %s", structure_string);
|
SCENARIO_ACTION_EXECUTION_ERROR, "No element found for action: %s",
|
||||||
|
structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
@ -2788,8 +2806,9 @@ _execute_appsrc_push (GstValidateScenario * scenario,
|
||||||
g_strdup (gst_structure_get_string (action->structure, "file-name"));
|
g_strdup (gst_structure_get_string (action->structure, "file-name"));
|
||||||
if (file_name == NULL) {
|
if (file_name == NULL) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"Missing file-name property: %s", structure_string);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Missing file-name property: %s",
|
||||||
|
structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
@ -2800,7 +2819,8 @@ _execute_appsrc_push (GstValidateScenario * scenario,
|
||||||
g_file_get_contents (file_name, &file_contents, &file_length, &error);
|
g_file_get_contents (file_name, &file_contents, &file_length, &error);
|
||||||
if (error != NULL) {
|
if (error != NULL) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Could not open file for action: %s. Error: %s", structure_string,
|
"Could not open file for action: %s. Error: %s", structure_string,
|
||||||
error->message);
|
error->message);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
|
@ -2823,8 +2843,9 @@ _execute_appsrc_push (GstValidateScenario * scenario,
|
||||||
GstPad *peer_pad = gst_pad_get_peer (appsrc_pad);
|
GstPad *peer_pad = gst_pad_get_peer (appsrc_pad);
|
||||||
if (!peer_pad) {
|
if (!peer_pad) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"Action failed, pad not linked: %s", structure_string);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Action failed, pad not linked: %s",
|
||||||
|
structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
@ -2841,7 +2862,8 @@ _execute_appsrc_push (GstValidateScenario * scenario,
|
||||||
g_signal_emit_by_name (target, "push-buffer", buffer, &push_buffer_ret);
|
g_signal_emit_by_name (target, "push-buffer", buffer, &push_buffer_ret);
|
||||||
if (push_buffer_ret != GST_FLOW_OK) {
|
if (push_buffer_ret != GST_FLOW_OK) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"push-buffer signal failed in action: %s", structure_string);
|
"push-buffer signal failed in action: %s", structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
|
@ -2868,8 +2890,9 @@ _execute_appsrc_eos (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
target = _get_target_element (scenario, action);
|
target = _get_target_element (scenario, action);
|
||||||
if (target == NULL) {
|
if (target == NULL) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"No element found for action: %s", structure_string);
|
SCENARIO_ACTION_EXECUTION_ERROR, "No element found for action: %s",
|
||||||
|
structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
@ -2877,7 +2900,8 @@ _execute_appsrc_eos (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
g_signal_emit_by_name (target, "end-of-stream", &eos_ret);
|
g_signal_emit_by_name (target, "end-of-stream", &eos_ret);
|
||||||
if (eos_ret != GST_FLOW_OK) {
|
if (eos_ret != GST_FLOW_OK) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Failed to emit end-of-stream signal for action: %s", structure_string);
|
"Failed to emit end-of-stream signal for action: %s", structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
|
@ -2897,8 +2921,9 @@ _execute_flush (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
target = _get_target_element (scenario, action);
|
target = _get_target_element (scenario, action);
|
||||||
if (target == NULL) {
|
if (target == NULL) {
|
||||||
gchar *structure_string = gst_structure_to_string (action->structure);
|
gchar *structure_string = gst_structure_to_string (action->structure);
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"No element found for action: %s", structure_string);
|
SCENARIO_ACTION_EXECUTION_ERROR, "No element found for action: %s",
|
||||||
|
structure_string);
|
||||||
g_free (structure_string);
|
g_free (structure_string);
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
@ -2907,15 +2932,15 @@ _execute_flush (GstValidateScenario * scenario, GstValidateAction * action)
|
||||||
|
|
||||||
event = gst_event_new_flush_start ();
|
event = gst_event_new_flush_start ();
|
||||||
if (!gst_element_send_event (target, event)) {
|
if (!gst_element_send_event (target, event)) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"FLUSH_START event was not handled");
|
SCENARIO_ACTION_EXECUTION_ERROR, "FLUSH_START event was not handled");
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
event = gst_event_new_flush_stop (reset_time);
|
event = gst_event_new_flush_stop (reset_time);
|
||||||
if (!gst_element_send_event (target, event)) {
|
if (!gst_element_send_event (target, event)) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"FLUSH_STOP event was not handled");
|
SCENARIO_ACTION_EXECUTION_ERROR, "FLUSH_STOP event was not handled");
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2934,8 +2959,9 @@ _execute_disable_plugin (GstValidateScenario * scenario,
|
||||||
plugin = gst_registry_find_plugin (gst_registry_get (), plugin_name);
|
plugin = gst_registry_find_plugin (gst_registry_get (), plugin_name);
|
||||||
|
|
||||||
if (plugin == NULL) {
|
if (plugin == NULL) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"Could not find plugin to disable: %s", plugin_name);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Could not find plugin to disable: %s",
|
||||||
|
plugin_name);
|
||||||
|
|
||||||
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
return GST_VALIDATE_EXECUTE_ACTION_ERROR_REPORTED;
|
||||||
}
|
}
|
||||||
|
@ -3324,7 +3350,8 @@ message_cb (GstBus * bus, GstMessage * message, GstValidateScenario * scenario)
|
||||||
(priv->pending_switch_track), ACTION_EXPECTED_STREAM_QUARK);
|
(priv->pending_switch_track), ACTION_EXPECTED_STREAM_QUARK);
|
||||||
|
|
||||||
if (g_list_length (expected) != g_list_length (streams_selected)) {
|
if (g_list_length (expected) != g_list_length (streams_selected)) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, priv->pending_switch_track,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Was expecting %d selected streams but got %d",
|
"Was expecting %d selected streams but got %d",
|
||||||
g_list_length (expected), g_list_length (streams_selected));
|
g_list_length (expected), g_list_length (streams_selected));
|
||||||
goto action_done;
|
goto action_done;
|
||||||
|
@ -3334,7 +3361,7 @@ message_cb (GstBus * bus, GstMessage * message, GstValidateScenario * scenario)
|
||||||
const gchar *stream_id = l->data;
|
const gchar *stream_id = l->data;
|
||||||
|
|
||||||
if (!streams_list_contain (streams_selected, stream_id)) {
|
if (!streams_list_contain (streams_selected, stream_id)) {
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, priv->pending_switch_track,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR,
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Stream %s has not be activated", stream_id);
|
"Stream %s has not be activated", stream_id);
|
||||||
goto action_done;
|
goto action_done;
|
||||||
|
@ -4043,6 +4070,7 @@ _parse_scenario (GFile * f, GKeyFile * kf)
|
||||||
GstValidateActionType *type =
|
GstValidateActionType *type =
|
||||||
_find_action_type (gst_structure_get_name (_struct));
|
_find_action_type (gst_structure_get_name (_struct));
|
||||||
|
|
||||||
|
gst_structure_remove_fields (_struct, "__lineno__", "__filename__", NULL);
|
||||||
if (!desc && gst_structure_has_name (_struct, "description"))
|
if (!desc && gst_structure_has_name (_struct, "description"))
|
||||||
desc = gst_structure_copy (_struct);
|
desc = gst_structure_copy (_struct);
|
||||||
else if (type && type->flags & GST_VALIDATE_ACTION_TYPE_NEEDS_CLOCK)
|
else if (type && type->flags & GST_VALIDATE_ACTION_TYPE_NEEDS_CLOCK)
|
||||||
|
@ -4207,7 +4235,8 @@ check_last_sample_internal (GstValidateScenario * scenario,
|
||||||
|
|
||||||
g_object_get (sink, "last-sample", &sample, NULL);
|
g_object_get (sink, "last-sample", &sample, NULL);
|
||||||
if (sample == NULL) {
|
if (sample == NULL) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Could not \"check-last-sample\" as %" GST_PTR_FORMAT
|
"Could not \"check-last-sample\" as %" GST_PTR_FORMAT
|
||||||
" 'last-sample' property is NULL"
|
" 'last-sample' property is NULL"
|
||||||
". MAKE SURE THE 'enable-last-sample' PROPERTY IS SET TO 'TRUE'!",
|
". MAKE SURE THE 'enable-last-sample' PROPERTY IS SET TO 'TRUE'!",
|
||||||
|
@ -4247,7 +4276,7 @@ sink_last_sample_notify_cb (GstElement * sink, GParamSpec * arg G_GNUC_UNUSED,
|
||||||
GstValidateScenario *scenario = gst_validate_action_get_scenario (action);
|
GstValidateScenario *scenario = gst_validate_action_get_scenario (action);
|
||||||
|
|
||||||
if (!scenario) {
|
if (!scenario) {
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR,
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"No pipeline anymore, can't check last sample");
|
"No pipeline anymore, can't check last sample");
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -4264,7 +4293,7 @@ done:
|
||||||
}
|
}
|
||||||
|
|
||||||
static GstValidateExecuteActionReturn
|
static GstValidateExecuteActionReturn
|
||||||
_check_last_sample_checksum (GstValidateScenario * scenario,
|
_check_last_sample_value (GstValidateScenario * scenario,
|
||||||
GstValidateAction * action, GstElement * sink)
|
GstValidateAction * action, GstElement * sink)
|
||||||
{
|
{
|
||||||
GstSample *sample;
|
GstSample *sample;
|
||||||
|
@ -4366,10 +4395,11 @@ _execute_check_last_sample (GstValidateScenario * scenario,
|
||||||
GST_OBJECT (sink))) {
|
GST_OBJECT (sink))) {
|
||||||
gchar *tmp = gst_structure_to_string (action->structure);
|
gchar *tmp = gst_structure_to_string (action->structure);
|
||||||
|
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Could not \"check-last-sample\" as several elements were found "
|
"Could not \"check-last-sample\" as several elements were found "
|
||||||
"from describing string: '%s' (%s and %s match)",
|
"from describing string: '%s' (%s and %s match)", tmp,
|
||||||
tmp, GST_OBJECT_NAME (sink), GST_OBJECT_NAME (tmpelement));
|
GST_OBJECT_NAME (sink), GST_OBJECT_NAME (tmpelement));
|
||||||
|
|
||||||
g_free (tmp);
|
g_free (tmp);
|
||||||
}
|
}
|
||||||
|
@ -4397,14 +4427,15 @@ _execute_check_last_sample (GstValidateScenario * scenario,
|
||||||
gst_caps_unref (caps);
|
gst_caps_unref (caps);
|
||||||
|
|
||||||
if (!sink) {
|
if (!sink) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Could not \"check-last-sample\" as no sink was found from description: '%"
|
"Could not \"check-last-sample\" as no sink was found from description: '%"
|
||||||
GST_PTR_FORMAT "'", action->structure);
|
GST_PTR_FORMAT "'", action->structure);
|
||||||
|
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
return _check_last_sample_checksum (scenario, action, sink);
|
return _check_last_sample_value (scenario, action, sink);
|
||||||
|
|
||||||
error:
|
error:
|
||||||
g_clear_object (&sink);
|
g_clear_object (&sink);
|
||||||
|
@ -4455,7 +4486,7 @@ _check_is_key_unit_cb (GstPad * pad, GstPadProbeInfo * info,
|
||||||
if (GST_BUFFER_FLAG_IS_SET (GST_PAD_PROBE_INFO_BUFFER (info),
|
if (GST_BUFFER_FLAG_IS_SET (GST_PAD_PROBE_INFO_BUFFER (info),
|
||||||
GST_BUFFER_FLAG_DELTA_UNIT)) {
|
GST_BUFFER_FLAG_DELTA_UNIT)) {
|
||||||
if (count_bufs >= NOT_KF_AFTER_FORCE_KF_EVT_TOLERANCE) {
|
if (count_bufs >= NOT_KF_AFTER_FORCE_KF_EVT_TOLERANCE) {
|
||||||
GST_VALIDATE_REPORT (scenario,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
SCENARIO_ACTION_EXECUTION_ERROR,
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Did not receive a key frame after requested one, "
|
"Did not receive a key frame after requested one, "
|
||||||
"at running_time %" GST_TIME_FORMAT " (with a %i "
|
"at running_time %" GST_TIME_FORMAT " (with a %i "
|
||||||
|
@ -4526,7 +4557,8 @@ _execute_request_key_unit (GstValidateScenario * scenario,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!targets) {
|
if (!targets) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"Could not find any element from action: %" GST_PTR_FORMAT,
|
"Could not find any element from action: %" GST_PTR_FORMAT,
|
||||||
action->structure);
|
action->structure);
|
||||||
goto fail;
|
goto fail;
|
||||||
|
@ -4547,8 +4579,9 @@ _execute_request_key_unit (GstValidateScenario * scenario,
|
||||||
video_encoder = tmp->data;
|
video_encoder = tmp->data;
|
||||||
encoder_srcpad = gst_element_get_static_pad (video_encoder, srcpad_name);
|
encoder_srcpad = gst_element_get_static_pad (video_encoder, srcpad_name);
|
||||||
if (!encoder_srcpad) {
|
if (!encoder_srcpad) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"Could not find pad %s", srcpad_name);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Could not find pad %s",
|
||||||
|
srcpad_name);
|
||||||
|
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
@ -4558,8 +4591,9 @@ _execute_request_key_unit (GstValidateScenario * scenario,
|
||||||
|
|
||||||
pad = gst_element_get_static_pad (video_encoder, srcpad_name);
|
pad = gst_element_get_static_pad (video_encoder, srcpad_name);
|
||||||
if (!pad) {
|
if (!pad) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"Could not find pad %s", srcpad_name);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Could not find pad %s",
|
||||||
|
srcpad_name);
|
||||||
|
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
@ -4578,8 +4612,8 @@ _execute_request_key_unit (GstValidateScenario * scenario,
|
||||||
|
|
||||||
pad = gst_element_get_static_pad (video_encoder, pad_name);
|
pad = gst_element_get_static_pad (video_encoder, pad_name);
|
||||||
if (!pad) {
|
if (!pad) {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
"Could not find pad %s", pad_name);
|
SCENARIO_ACTION_EXECUTION_ERROR, "Could not find pad %s", pad_name);
|
||||||
|
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
@ -4600,7 +4634,8 @@ _execute_request_key_unit (GstValidateScenario * scenario,
|
||||||
gst_validate_action_ref (action),
|
gst_validate_action_ref (action),
|
||||||
(GDestroyNotify) gst_validate_action_unref);
|
(GDestroyNotify) gst_validate_action_unref);
|
||||||
} else {
|
} else {
|
||||||
GST_VALIDATE_REPORT (scenario, SCENARIO_ACTION_EXECUTION_ERROR,
|
GST_VALIDATE_REPORT_ACTION (scenario, action,
|
||||||
|
SCENARIO_ACTION_EXECUTION_ERROR,
|
||||||
"request keyunit direction %s invalid (should be in"
|
"request keyunit direction %s invalid (should be in"
|
||||||
" [downstrean, upstream]", direction);
|
" [downstrean, upstream]", direction);
|
||||||
|
|
||||||
|
@ -5607,7 +5642,7 @@ init_scenarios (void)
|
||||||
},
|
},
|
||||||
{NULL}
|
{NULL}
|
||||||
}),
|
}),
|
||||||
"Checks the last-sample checksum on declared Sink element."
|
"Checks the last-sample checksum or embedded frame number on declared Sink element."
|
||||||
" This allows checking the checksum of a buffer after a 'seek' or after a GESTimeline 'commit'"
|
" This allows checking the checksum of a buffer after a 'seek' or after a GESTimeline 'commit'"
|
||||||
" for example",
|
" for example",
|
||||||
GST_VALIDATE_ACTION_TYPE_INTERLACED);
|
GST_VALIDATE_ACTION_TYPE_INTERLACED);
|
||||||
|
|
|
@ -89,6 +89,9 @@ typedef gboolean (*GstValidatePrepareAction) (GstValidateAction * action);
|
||||||
|
|
||||||
typedef struct _GstValidateActionPrivate GstValidateActionPrivate;
|
typedef struct _GstValidateActionPrivate GstValidateActionPrivate;
|
||||||
|
|
||||||
|
#define GST_VALIDATE_ACTION_LINENO(action) (action->ABI.abi.lineno)
|
||||||
|
#define GST_VALIDATE_ACTION_FILENAME(action) (action->ABI.abi.filename)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GstValidateAction:
|
* GstValidateAction:
|
||||||
* @type: The type of the #GstValidateAction, which is the name of the
|
* @type: The type of the #GstValidateAction, which is the name of the
|
||||||
|
@ -121,7 +124,13 @@ struct _GstValidateAction
|
||||||
|
|
||||||
GstValidateActionPrivate *priv;
|
GstValidateActionPrivate *priv;
|
||||||
|
|
||||||
gpointer _gst_reserved[GST_PADDING_LARGE - 1]; /* ->priv */
|
union {
|
||||||
|
gpointer _gst_reserved[GST_PADDING_LARGE - 1]; /* ->priv */
|
||||||
|
struct {
|
||||||
|
gint lineno;
|
||||||
|
gchar *filename;
|
||||||
|
} abi;
|
||||||
|
} ABI;
|
||||||
};
|
};
|
||||||
|
|
||||||
GST_VALIDATE_API
|
GST_VALIDATE_API
|
||||||
|
|
|
@ -45,8 +45,6 @@
|
||||||
#define PARSER_MAX_TOKEN_SIZE 256
|
#define PARSER_MAX_TOKEN_SIZE 256
|
||||||
#define PARSER_MAX_ARGUMENT_COUNT 10
|
#define PARSER_MAX_ARGUMENT_COUNT 10
|
||||||
|
|
||||||
static GRegex *_clean_structs_lines = NULL;
|
|
||||||
static GRegex *_line_breaking_char = NULL;
|
|
||||||
static GRegex *_variables_regex = NULL;
|
static GRegex *_variables_regex = NULL;
|
||||||
static GstStructure *global_vars = NULL;
|
static GstStructure *global_vars = NULL;
|
||||||
|
|
||||||
|
@ -544,19 +542,33 @@ gst_validate_utils_enum_from_str (GType type, const gchar * str_enum,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static gchar *
|
||||||
|
skip_spaces (gchar * c)
|
||||||
|
{
|
||||||
|
/* For some reason newlines are considered as space, we do not want that! */
|
||||||
|
while (g_ascii_isspace (*c) && *c != '\n')
|
||||||
|
c++;
|
||||||
|
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
/* Parse file that contains a list of GStructures */
|
/* Parse file that contains a list of GStructures */
|
||||||
static gchar **
|
static GList *
|
||||||
_file_get_lines (GFile * file)
|
_file_get_structures (GFile * file, gchar ** err)
|
||||||
{
|
{
|
||||||
gsize size;
|
gsize size;
|
||||||
|
|
||||||
GError *err = NULL;
|
GError *error = NULL;
|
||||||
gchar *content = NULL, *escaped_content = NULL, **lines = NULL, *tmp;
|
gchar *content = NULL, *tmp;
|
||||||
|
gchar *filename = NULL;
|
||||||
|
gint lineno = 1, current_lineno;
|
||||||
|
GList *structures = NULL;
|
||||||
|
|
||||||
/* TODO Handle GCancellable */
|
/* TODO Handle GCancellable */
|
||||||
if (!g_file_load_contents (file, NULL, &content, &size, NULL, &err)) {
|
if (!g_file_load_contents (file, NULL, &content, &size, NULL, &error)) {
|
||||||
GST_WARNING ("Failed to load contents: %d %s", err->code, err->message);
|
GST_WARNING ("Failed to load contents: %d %s", error->code, error->message);
|
||||||
g_error_free (err);
|
g_error_free (error);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (g_strcmp0 (content, "") == 0) {
|
if (g_strcmp0 (content, "") == 0) {
|
||||||
|
@ -564,87 +576,83 @@ _file_get_lines (GFile * file)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_clean_structs_lines == NULL) {
|
filename = g_file_get_path (file);
|
||||||
_clean_structs_lines =
|
tmp = content;
|
||||||
g_regex_new ("\\\\\n|#.*\n", G_REGEX_CASELESS, 0, NULL);
|
while (*tmp) {
|
||||||
_line_breaking_char = g_regex_new (",\\n", G_REGEX_CASELESS, 0, NULL);
|
GString *l;
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
escaped_content =
|
|
||||||
g_regex_replace (_clean_structs_lines, content, -1, 0, "", 0, NULL);
|
|
||||||
tmp =
|
|
||||||
g_regex_replace (_line_breaking_char, escaped_content, -1, 0, ",", 0,
|
|
||||||
NULL);
|
|
||||||
g_free (escaped_content);
|
|
||||||
escaped_content = tmp;
|
|
||||||
|
|
||||||
lines = g_strsplit (escaped_content, "\n", 0);
|
|
||||||
g_free (escaped_content);
|
|
||||||
g_free (content);
|
|
||||||
|
|
||||||
return lines;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gchar **
|
|
||||||
_get_lines (const gchar * scenario_file, gchar ** file_path)
|
|
||||||
{
|
|
||||||
GFile *file = NULL;
|
|
||||||
gchar **lines = NULL;
|
|
||||||
|
|
||||||
GST_DEBUG ("Trying to load %s", scenario_file);
|
|
||||||
if ((file = g_file_new_for_path (scenario_file)) == NULL) {
|
|
||||||
GST_WARNING ("%s wrong uri", scenario_file);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (file_path)
|
|
||||||
*file_path = g_file_get_path (file);
|
|
||||||
|
|
||||||
lines = _file_get_lines (file);
|
|
||||||
|
|
||||||
g_object_unref (file);
|
|
||||||
|
|
||||||
return lines;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Returns: (transfer full): a #GList of #GstStructure */
|
|
||||||
static GList *
|
|
||||||
_lines_get_structures (gchar ** lines, gchar ** err)
|
|
||||||
{
|
|
||||||
gint i;
|
|
||||||
GList *structures = NULL;
|
|
||||||
|
|
||||||
if (lines == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
for (i = 0; lines[i]; i++) {
|
|
||||||
GstStructure *structure;
|
GstStructure *structure;
|
||||||
|
|
||||||
if (g_strcmp0 (lines[i], "") == 0)
|
tmp = skip_spaces (tmp);
|
||||||
continue;
|
|
||||||
|
|
||||||
structure = gst_structure_from_string (lines[i], NULL);
|
if (*tmp == '\n') {
|
||||||
|
tmp++;
|
||||||
|
lineno++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*tmp == '#') {
|
||||||
|
while (*tmp && *tmp != '\n')
|
||||||
|
tmp++;
|
||||||
|
if (*tmp)
|
||||||
|
tmp++;
|
||||||
|
lineno++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
l = g_string_new (NULL);
|
||||||
|
current_lineno = lineno;
|
||||||
|
while (*tmp != '\n' && *tmp) {
|
||||||
|
gchar next = *(tmp + 1);
|
||||||
|
|
||||||
|
/* ',' and '\\' are line continuation indicators */
|
||||||
|
if (next && next == '\n' && (*tmp == ',' || *tmp == '\\')) {
|
||||||
|
if (*tmp == ',')
|
||||||
|
g_string_append_c (l, *tmp);
|
||||||
|
|
||||||
|
tmp += 2;
|
||||||
|
lineno++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_string_append_c (l, *tmp);
|
||||||
|
tmp += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Blank lines at EOF */
|
||||||
|
if (!*l->str) {
|
||||||
|
g_string_free (l, TRUE);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
structure = gst_structure_from_string (l->str, NULL);
|
||||||
if (structure == NULL) {
|
if (structure == NULL) {
|
||||||
GST_ERROR ("Could not parse structure %s", lines[i]);
|
GST_ERROR ("Could not parse structure at %s:%d\n %s", filename,
|
||||||
|
current_lineno, l->str);
|
||||||
if (err) {
|
if (err) {
|
||||||
gchar *tmp = *err;
|
gchar *tmp = *err;
|
||||||
*err =
|
*err =
|
||||||
g_strdup_printf ("%s\n -Invalid structure: `%s`", tmp ? tmp : "",
|
g_strdup_printf ("%s\n%s:%d: Invalid structure\n %d | %s\n %*c|",
|
||||||
lines[i]);
|
tmp ? tmp : "", filename, current_lineno, current_lineno, l->str,
|
||||||
|
(gint) floor (log10 (abs ((current_lineno)))) + 1, ' ');
|
||||||
g_free (tmp);
|
g_free (tmp);
|
||||||
continue;
|
|
||||||
} else {
|
} else {
|
||||||
|
g_string_free (l, TRUE);
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
g_string_free (l, TRUE);
|
||||||
|
|
||||||
|
gst_structure_set (structure,
|
||||||
|
"__lineno__", G_TYPE_INT, current_lineno,
|
||||||
|
"__filename__", G_TYPE_STRING, filename, NULL);
|
||||||
structures = g_list_append (structures, structure);
|
structures = g_list_append (structures, structure);
|
||||||
|
lineno++;
|
||||||
|
if (*tmp)
|
||||||
|
tmp++;
|
||||||
}
|
}
|
||||||
|
|
||||||
done:
|
done:
|
||||||
g_strfreev (lines);
|
g_free (filename);
|
||||||
|
|
||||||
return structures;
|
return structures;
|
||||||
|
|
||||||
failed:
|
failed:
|
||||||
|
@ -655,6 +663,30 @@ failed:
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GList *
|
||||||
|
_get_structures (const gchar * scenario_file, gchar ** file_path, gchar ** err)
|
||||||
|
{
|
||||||
|
GFile *file = NULL;
|
||||||
|
GList *structs = NULL;
|
||||||
|
|
||||||
|
GST_DEBUG ("Trying to load %s", scenario_file);
|
||||||
|
if ((file = g_file_new_for_path (scenario_file)) == NULL) {
|
||||||
|
GST_WARNING ("%s wrong uri", scenario_file);
|
||||||
|
if (err)
|
||||||
|
*err = g_strdup_printf ("%s wrong uri", scenario_file);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (file_path)
|
||||||
|
*file_path = g_file_get_path (file);
|
||||||
|
|
||||||
|
structs = _file_get_structures (file, err);
|
||||||
|
|
||||||
|
g_object_unref (file);
|
||||||
|
|
||||||
|
return structs;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gst_validate_utils_structs_parse_from_filename: (skip):
|
* gst_validate_utils_structs_parse_from_filename: (skip):
|
||||||
*/
|
*/
|
||||||
|
@ -663,19 +695,12 @@ gst_validate_utils_structs_parse_from_filename (const gchar * scenario_file,
|
||||||
gchar ** file_path)
|
gchar ** file_path)
|
||||||
{
|
{
|
||||||
GList *res;
|
GList *res;
|
||||||
gchar **lines, *err = NULL;
|
gchar *err = NULL;
|
||||||
|
|
||||||
lines = _get_lines (scenario_file, file_path);
|
res = _get_structures (scenario_file, file_path, &err);
|
||||||
|
|
||||||
if (lines == NULL) {
|
|
||||||
GST_DEBUG ("Got no line for file: %s", scenario_file);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
res = _lines_get_structures (lines, &err);
|
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
g_error ("Could not get structures from %s: %s", scenario_file, err);
|
g_error ("Could not get structures from %s:\n%s\n", scenario_file, err);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -686,18 +711,12 @@ gst_validate_utils_structs_parse_from_filename (const gchar * scenario_file,
|
||||||
GList *
|
GList *
|
||||||
gst_validate_structs_parse_from_gfile (GFile * scenario_file)
|
gst_validate_structs_parse_from_gfile (GFile * scenario_file)
|
||||||
{
|
{
|
||||||
gchar **lines, *err = NULL;
|
gchar *err = NULL;
|
||||||
GList *res;
|
GList *res;
|
||||||
|
|
||||||
lines = _file_get_lines (scenario_file);
|
res = _file_get_structures (scenario_file, &err);
|
||||||
|
|
||||||
if (lines == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
res = _lines_get_structures (lines, &err);
|
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
g_error ("Could not get structures from %s: %s",
|
g_error ("Could not get structures from %s:\n%s\n",
|
||||||
g_file_get_uri (scenario_file), err);
|
g_file_get_uri (scenario_file), err);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
|
|
Loading…
Reference in a new issue