Commit e2face65 authored by Scott Hampton's avatar Scott Hampton

Merge branch 'mf-test-report-parsing-errors-frontend' into 'master'

Display parsing errors in test reports MR widget

See merge request gitlab-org/gitlab!55037
parents 36bbe8d6 9ef2e274
<script> <script>
import { GlButton } from '@gitlab/ui'; import { GlButton, GlIcon } from '@gitlab/ui';
import { once } from 'lodash'; import { once } from 'lodash';
import { mapActions, mapGetters, mapState } from 'vuex'; import { mapActions, mapGetters, mapState } from 'vuex';
import { sprintf, s__ } from '~/locale'; import { sprintf, s__ } from '~/locale';
...@@ -26,6 +26,7 @@ export default { ...@@ -26,6 +26,7 @@ export default {
IssuesList, IssuesList,
Modal, Modal,
GlButton, GlButton,
GlIcon,
}, },
mixins: [Tracking.mixin()], mixins: [Tracking.mixin()],
props: { props: {
...@@ -159,6 +160,18 @@ export default { ...@@ -159,6 +160,18 @@ export default {
<template #summary> <template #summary>
<div class="gl-display-inline-flex gl-flex-direction-column"> <div class="gl-display-inline-flex gl-flex-direction-column">
<div>{{ reportText(report) }}</div> <div>{{ reportText(report) }}</div>
<div v-if="report.suite_errors">
<div v-if="report.suite_errors.head">
<gl-icon name="warning" class="gl-mx-2 gl-text-orange-500" />
{{ s__('Reports|Head report parsing error:') }}
{{ report.suite_errors.head }}
</div>
<div v-if="report.suite_errors.base">
<gl-icon name="warning" class="gl-mx-2 gl-text-orange-500" />
{{ s__('Reports|Base report parsing error:') }}
{{ report.suite_errors.base }}
</div>
</div>
<div v-if="hasRecentFailures(report.summary)"> <div v-if="hasRecentFailures(report.summary)">
{{ recentFailuresText(report.summary) }} {{ recentFailuresText(report.summary) }}
</div> </div>
......
---
title: Display parsing errors in test reports MR widget
merge_request: 55037
author:
type: added
...@@ -25333,6 +25333,9 @@ msgstr "" ...@@ -25333,6 +25333,9 @@ msgstr ""
msgid "Reports|An error occurred while loading report" msgid "Reports|An error occurred while loading report"
msgstr "" msgstr ""
msgid "Reports|Base report parsing error:"
msgstr ""
msgid "Reports|Class" msgid "Reports|Class"
msgstr "" msgstr ""
...@@ -25355,6 +25358,9 @@ msgstr[1] "" ...@@ -25355,6 +25358,9 @@ msgstr[1] ""
msgid "Reports|Failure" msgid "Reports|Failure"
msgstr "" msgstr ""
msgid "Reports|Head report parsing error:"
msgstr ""
msgid "Reports|Identifier" msgid "Reports|Identifier"
msgstr "" msgstr ""
......
...@@ -295,6 +295,27 @@ describe('Grouped test reports app', () => { ...@@ -295,6 +295,27 @@ describe('Grouped test reports app', () => {
}); });
}); });
describe('with a report parsing errors', () => {
beforeEach(() => {
const reports = failedReport;
reports.suites[0].suite_errors = {
head: 'JUnit XML parsing failed: 2:24: FATAL: attributes construct error',
base: 'JUnit data parsing failed: string not matched',
};
setReports(reports);
mountComponent();
});
it('renders the error messages', () => {
expect(findSummaryDescription().text()).toContain(
'JUnit XML parsing failed: 2:24: FATAL: attributes construct error',
);
expect(findSummaryDescription().text()).toContain(
'JUnit data parsing failed: string not matched',
);
});
});
describe('with error', () => { describe('with error', () => {
beforeEach(() => { beforeEach(() => {
mockStore.state.isLoading = false; mockStore.state.isLoading = false;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment