Commit 91e476eb authored by Kushal Pandya's avatar Kushal Pandya

Merge branch '213101-junit-report-times' into 'master'

Format test report times to adjust for ms

See merge request gitlab-org/gitlab!39644
parents 2b6d2bdd c855daec
<script> <script>
import { GlDeprecatedButton, GlProgressBar } from '@gitlab/ui'; import { GlDeprecatedButton, GlProgressBar } from '@gitlab/ui';
import { __ } from '~/locale'; import { __ } from '~/locale';
import { formatTime, secondsToMilliseconds } from '~/lib/utils/datetime_utility';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
import { formattedTime } from '../../stores/test_reports/utils';
export default { export default {
name: 'TestSummary', name: 'TestSummary',
...@@ -39,7 +39,7 @@ export default { ...@@ -39,7 +39,7 @@ export default {
return 0; return 0;
}, },
formattedDuration() { formattedDuration() {
return formatTime(secondsToMilliseconds(this.report.total_time)); return formattedTime(this.report.total_time);
}, },
progressBarVariant() { progressBarVariant() {
if (this.successPercentage < 33) { if (this.successPercentage < 33) {
......
import { TestStatus } from '~/pipelines/constants'; import { TestStatus } from '~/pipelines/constants';
import { formatTime, secondsToMilliseconds } from '~/lib/utils/datetime_utility'; import { __, sprintf } from '../../../locale';
export function iconForTestStatus(status) { export function iconForTestStatus(status) {
switch (status) { switch (status) {
...@@ -12,7 +12,13 @@ export function iconForTestStatus(status) { ...@@ -12,7 +12,13 @@ export function iconForTestStatus(status) {
} }
} }
export const formattedTime = timeInSeconds => formatTime(secondsToMilliseconds(timeInSeconds)); export const formattedTime = (seconds = 0) => {
if (seconds < 1) {
const milliseconds = seconds * 1000;
return sprintf(__('%{milliseconds}ms'), { milliseconds: milliseconds.toFixed(2) });
}
return sprintf(__('%{seconds}s'), { seconds: seconds.toFixed(2) });
};
export const addIconStatus = testCase => ({ export const addIconStatus = testCase => ({
...testCase, ...testCase,
......
---
title: Adjust format for JUnit report duration times
merge_request: 39644
author:
type: changed
...@@ -551,6 +551,9 @@ msgstr "" ...@@ -551,6 +551,9 @@ msgstr ""
msgid "%{milestone} (expired)" msgid "%{milestone} (expired)"
msgstr "" msgstr ""
msgid "%{milliseconds}ms"
msgstr ""
msgid "%{mrText}, this issue will be closed automatically." msgid "%{mrText}, this issue will be closed automatically."
msgstr "" msgstr ""
...@@ -663,6 +666,9 @@ msgstr "" ...@@ -663,6 +666,9 @@ msgstr ""
msgid "%{retryButtonStart}Try again%{retryButtonEnd} or %{newFileButtonStart}attach a new file%{newFileButtonEnd}" msgid "%{retryButtonStart}Try again%{retryButtonEnd} or %{newFileButtonStart}attach a new file%{newFileButtonEnd}"
msgstr "" msgstr ""
msgid "%{seconds}s"
msgstr ""
msgid "%{securityScanner} is not enabled for this project. %{linkStart}More information%{linkEnd}" msgid "%{securityScanner} is not enabled for this project. %{linkStart}More information%{linkEnd}"
msgid_plural "%{securityScanner} are not enabled for this project. %{linkStart}More information%{linkEnd}" msgid_plural "%{securityScanner} are not enabled for this project. %{linkStart}More information%{linkEnd}"
msgstr[0] "" msgstr[0] ""
......
import { getJSONFixture } from 'helpers/fixtures'; import { getJSONFixture } from 'helpers/fixtures';
import * as getters from '~/pipelines/stores/test_reports/getters'; import * as getters from '~/pipelines/stores/test_reports/getters';
import { iconForTestStatus } from '~/pipelines/stores/test_reports/utils'; import { iconForTestStatus, formattedTime } from '~/pipelines/stores/test_reports/utils';
describe('Getters TestReports Store', () => { describe('Getters TestReports Store', () => {
let state; let state;
...@@ -34,7 +34,7 @@ describe('Getters TestReports Store', () => { ...@@ -34,7 +34,7 @@ describe('Getters TestReports Store', () => {
const suites = getters.getTestSuites(state); const suites = getters.getTestSuites(state);
const expected = testReports.test_suites.map(x => ({ const expected = testReports.test_suites.map(x => ({
...x, ...x,
formattedTime: '00:00:00', formattedTime: formattedTime(x.total_time),
})); }));
expect(suites).toEqual(expected); expect(suites).toEqual(expected);
...@@ -65,7 +65,7 @@ describe('Getters TestReports Store', () => { ...@@ -65,7 +65,7 @@ describe('Getters TestReports Store', () => {
const cases = getters.getSuiteTests(state); const cases = getters.getSuiteTests(state);
const expected = testReports.test_suites[0].test_cases.map(x => ({ const expected = testReports.test_suites[0].test_cases.map(x => ({
...x, ...x,
formattedTime: '00:00:00', formattedTime: formattedTime(x.execution_time),
icon: iconForTestStatus(x.status), icon: iconForTestStatus(x.status),
})); }));
......
import { formattedTime } from '~/pipelines/stores/test_reports/utils';
describe('Test reports utils', () => {
describe('formattedTime', () => {
describe('when time is smaller than a second', () => {
it('should return time in milliseconds fixed to 2 decimals', () => {
const result = formattedTime(0.4815162342);
expect(result).toBe('481.52ms');
});
});
describe('when time is equal to a second', () => {
it('should return time in seconds fixed to 2 decimals', () => {
const result = formattedTime(1);
expect(result).toBe('1.00s');
});
});
describe('when time is greater than a second', () => {
it('should return time in seconds fixed to 2 decimals', () => {
const result = formattedTime(4.815162342);
expect(result).toBe('4.82s');
});
});
});
});
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import { getJSONFixture } from 'helpers/fixtures'; import { getJSONFixture } from 'helpers/fixtures';
import Summary from '~/pipelines/components/test_reports/test_summary.vue'; import Summary from '~/pipelines/components/test_reports/test_summary.vue';
import { formattedTime } from '~/pipelines/stores/test_reports/utils';
describe('Test reports summary', () => { describe('Test reports summary', () => {
let wrapper; let wrapper;
...@@ -76,7 +77,7 @@ describe('Test reports summary', () => { ...@@ -76,7 +77,7 @@ describe('Test reports summary', () => {
}); });
it('displays the correctly formatted duration', () => { it('displays the correctly formatted duration', () => {
expect(duration().text()).toBe('00:00:00'); expect(duration().text()).toBe(formattedTime(testSuite.total_time));
}); });
}); });
......
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