validate-report: Add the notion of master / shadow reports.

A master report is a report that has been detected by a monitor
to stem from the same issue. It thus contains a list of
"shadow reports" which it will browse when printing itself.
This commit is contained in:
Mathieu Duponchelle 2014-10-01 15:53:24 +02:00 committed by Mathieu Duponchelle
parent b8ac717297
commit 222a517384
2 changed files with 58 additions and 3 deletions

View file

@ -50,6 +50,16 @@ GST_DEBUG_CATEGORY_STATIC (gst_validate_report_debug);
#undef GST_CAT_DEFAULT #undef GST_CAT_DEFAULT
#define GST_CAT_DEFAULT gst_validate_report_debug #define GST_CAT_DEFAULT gst_validate_report_debug
#define GST_VALIDATE_REPORT_SHADOW_REPORTS_LOCK(r) \
G_STMT_START { \
(g_mutex_lock (&((GstValidateReport *) r)->shadow_reports_lock)); \
} G_STMT_END
#define GST_VALIDATE_REPORT_SHADOW_REPORTS_UNLOCK(r) \
G_STMT_START { \
(g_mutex_unlock (&((GstValidateReport *) r)->shadow_reports_lock)); \
} G_STMT_END
G_DEFINE_BOXED_TYPE (GstValidateReport, gst_validate_report, G_DEFINE_BOXED_TYPE (GstValidateReport, gst_validate_report,
(GBoxedCopyFunc) gst_validate_report_ref, (GBoxedCopyFunc) gst_validate_report_ref,
(GBoxedFreeFunc) gst_validate_report_unref); (GBoxedFreeFunc) gst_validate_report_unref);
@ -422,6 +432,7 @@ gst_validate_report_new (GstValidateIssue * issue,
report->issue = issue; report->issue = issue;
report->reporter = reporter; /* TODO should we ref? */ report->reporter = reporter; /* TODO should we ref? */
report->message = g_strdup (message); report->message = g_strdup (message);
g_mutex_init (&report->shadow_reports_lock);
report->timestamp = report->timestamp =
gst_util_get_timestamp () - _gst_validate_report_start_time; gst_util_get_timestamp () - _gst_validate_report_start_time;
report->level = issue->default_level; report->level = issue->default_level;
@ -436,7 +447,9 @@ gst_validate_report_unref (GstValidateReport * report)
if (G_UNLIKELY (g_atomic_int_dec_and_test (&report->refcount))) { if (G_UNLIKELY (g_atomic_int_dec_and_test (&report->refcount))) {
g_free (report->message); g_free (report->message);
g_list_free_full (report->shadow_reports, (GDestroyNotify) gst_validate_report_unref);
g_slice_free (GstValidateReport, report); g_slice_free (GstValidateReport, report);
g_mutex_clear (&report->shadow_reports_lock);
} }
} }
@ -605,17 +618,51 @@ gst_validate_printf_valist (gpointer source, const gchar * format, va_list args)
g_string_free (string, TRUE); g_string_free (string, TRUE);
} }
void
gst_validate_report_set_master_report (GstValidateReport * report,
GstValidateReport * master_report)
{
GList *tmp;
gboolean add_shadow_report = TRUE;
report->master_report = master_report;
GST_VALIDATE_REPORT_SHADOW_REPORTS_LOCK (master_report);
for (tmp = master_report->shadow_reports; tmp; tmp = tmp->next) {
GstValidateReport *shadow_report = (GstValidateReport *) tmp->data;
if (report->reporter == shadow_report->reporter) {
add_shadow_report = FALSE;
break;
}
}
if (add_shadow_report)
master_report->shadow_reports =
g_list_append (master_report->shadow_reports, gst_validate_report_ref (report));
GST_VALIDATE_REPORT_SHADOW_REPORTS_UNLOCK (master_report);
}
void void
gst_validate_report_printf (GstValidateReport * report) gst_validate_report_printf (GstValidateReport * report)
{ {
GList *tmp;
gst_validate_printf (NULL, "%10s : %s\n", gst_validate_printf (NULL, "%10s : %s\n",
gst_validate_report_level_get_name (report->level), gst_validate_report_level_get_name (report->level),
report->issue->summary); report->issue->summary);
gst_validate_printf (NULL, "%*s Detected on <%s> at %" GST_TIME_FORMAT "\n", gst_validate_printf (NULL, "%*s Detected on <%s",
12, "", gst_validate_reporter_get_name (report->reporter), 12, "", gst_validate_reporter_get_name (report->reporter));
GST_TIME_ARGS (report->timestamp));
for (tmp = report->shadow_reports; tmp; tmp = tmp->next) {
GstValidateReport *shadow_report = (GstValidateReport *) tmp->data;
gst_validate_printf (NULL, ", %s",
gst_validate_reporter_get_name (shadow_report->reporter));
}
gst_validate_printf (NULL, ">\n");
if (report->message) if (report->message)
gst_validate_printf (NULL, "%*s Details : %s\n", 12, "", report->message); gst_validate_printf (NULL, "%*s Details : %s\n", 12, "", report->message);
if (report->issue->description) if (report->issue->description)
gst_validate_printf (NULL, "%*s Description : %s\n", 12, "", gst_validate_printf (NULL, "%*s Description : %s\n", 12, "",
report->issue->description); report->issue->description);

View file

@ -169,6 +169,13 @@ struct _GstValidateReport {
/* message: issue-specific message. Gives more detail on the actual /* message: issue-specific message. Gives more detail on the actual
* issue. Can be NULL */ * issue. Can be NULL */
gchar *message; gchar *message;
/* When reporter->intercept_report returns KEEP, the report is not
* added to the runner. It can be added as a "shadow_report" to
* the upstream report, which is tracked by the runner. */
GMutex shadow_reports_lock;
GstValidateReport *master_report;
GList *shadow_reports;
}; };
#define GST_VALIDATE_ISSUE_FORMAT G_GUINTPTR_FORMAT " (%s) : %s(%" G_GUINTPTR_FORMAT "): %s" #define GST_VALIDATE_ISSUE_FORMAT G_GUINTPTR_FORMAT " (%s) : %s(%" G_GUINTPTR_FORMAT "): %s"
@ -212,6 +219,7 @@ void gst_validate_printf_valist (gpointer source,
const gchar * format, const gchar * format,
va_list args) G_GNUC_NO_INSTRUMENT; va_list args) G_GNUC_NO_INSTRUMENT;
gboolean gst_validate_report_should_print (GstValidateReport * report); gboolean gst_validate_report_should_print (GstValidateReport * report);
void gst_validate_report_set_master_report(GstValidateReport *report, GstValidateReport *master_report);
G_END_DECLS G_END_DECLS