--- /dev/null
+/*
+ * SonarQube
+ * Copyright (C) 2009-2019 SonarSource SA
+ * mailto:info AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+import { getPeriodLabel } from '../periods';
+import { mockPeriod } from '../testMocks';
+
+const formatter = jest.fn(v => v);
+
+beforeEach(() => {
+ formatter.mockClear();
+});
+
+describe('getPeriodLabel', () => {
+ it('should handle missing value', () => {
+ expect(getPeriodLabel(undefined, formatter)).toBeUndefined();
+ });
+
+ it('should handle date', () => {
+ expect(getPeriodLabel(mockPeriod({ mode: 'date' }), formatter)).toBe('overview.period.date.');
+ expect(
+ getPeriodLabel(mockPeriod({ mode: 'date', parameter: '2019-02-21T01:11:21+0100' }), formatter)
+ ).toBe('overview.period.date.2019-02-21T01:11:21+0100');
+ expect(formatter).toBeCalledTimes(1);
+ });
+
+ it('should handle days', () => {
+ expect(getPeriodLabel(mockPeriod({ mode: 'days', modeParam: '12' }), formatter)).toBe(
+ 'overview.period.days.12'
+ );
+ expect(formatter).not.toBeCalled();
+ });
+
+ it('should handle previous analysis', () => {
+ expect(
+ getPeriodLabel(mockPeriod({ mode: 'previous_analysis', parameter: 'param' }), formatter)
+ ).toBe('overview.period.previous_analysis.param');
+ expect(formatter).not.toBeCalled();
+ });
+
+ it('should handle previous version', () => {
+ expect(getPeriodLabel(mockPeriod({ mode: 'previous_version' }), formatter)).toBe(
+ 'overview.period.previous_version_only_date'
+ );
+ expect(
+ getPeriodLabel(mockPeriod({ mode: 'previous_version', parameter: '7.9' }), formatter)
+ ).toBe('overview.period.previous_version.7.9');
+ expect(formatter).not.toBeCalled();
+ });
+
+ it('should handle version', () => {
+ expect(getPeriodLabel(mockPeriod({ mode: 'version', modeParam: '7.2' }), formatter)).toBe(
+ 'overview.period.version.7.2'
+ );
+ expect(
+ getPeriodLabel(mockPeriod({ mode: 'previous_version', parameter: '7.9' }), formatter)
+ ).toBe('overview.period.previous_version.7.9');
+ expect(formatter).not.toBeCalled();
+ });
+
+ it('should handle manual baseline', () => {
+ expect(
+ getPeriodLabel(mockPeriod({ mode: 'manual_baseline', modeParam: 'A658678DE' }), formatter)
+ ).toBe('overview.period.manual_baseline.A658678DE');
+ expect(getPeriodLabel(mockPeriod({ mode: 'manual_baseline' }), formatter)).toBe(
+ 'overview.period.manual_baseline.2019-04-23T02:12:32+0100'
+ );
+ expect(formatter).toBeCalledTimes(1);
+ });
+
+ it('should handle SPECIFIC_ANALYSIS', () => {
+ expect(
+ getPeriodLabel(
+ mockPeriod({
+ mode: 'SPECIFIC_ANALYSIS',
+ parameter: 'should be overriden'
+ }),
+ formatter
+ )
+ ).toBe('overview.period.specific_analysis.2019-04-23T02:12:32+0100');
+ expect(formatter).toBeCalled();
+ });
+
+ it('should handle PREVIOUS_VERSION', () => {
+ expect(
+ getPeriodLabel(mockPeriod({ mode: 'PREVIOUS_VERSION', parameter: 'A658678DE' }), formatter)
+ ).toBe('overview.period.previous_version.A658678DE');
+ expect(getPeriodLabel(mockPeriod({ mode: 'PREVIOUS_VERSION' }), formatter)).toBe(
+ 'overview.period.previous_version.2019-04-23T02:12:32+0100'
+ );
+ expect(formatter).toBeCalledTimes(1);
+ });
+});
return undefined;
}
- let parameter = period.modeParam || period.parameter;
- if (period.mode === 'previous_version' && !parameter) {
- return translate('overview.period.previous_version_only_date');
- }
+ let parameter = period.modeParam || period.parameter || '';
- if (period.mode === 'date' && parameter) {
- parameter = dateFormatter(parameter);
- } else if (period.mode === 'manual_baseline') {
- if (!parameter) {
+ switch (period.mode) {
+ case 'SPECIFIC_ANALYSIS':
parameter = dateFormatter(period.date);
- } else {
- return translateWithParameters('overview.period.previous_version', parameter);
- }
+ break;
+ case 'PREVIOUS_VERSION':
+ parameter = parameter || dateFormatter(period.date);
+ break;
+ /*
+ * Handle legacy period modes, that predate MMF-1579
+ */
+ case 'previous_version':
+ if (!parameter) {
+ return translate('overview.period.previous_version_only_date');
+ }
+ break;
+ case 'date':
+ parameter = parameter && dateFormatter(parameter);
+ break;
+ case 'manual_baseline':
+ parameter = parameter || dateFormatter(period.date);
+ break;
+ default: // No change in the parameter
}
- return translateWithParameters(`overview.period.${period.mode}`, parameter || '');
+ return translateWithParameters(`overview.period.${period.mode.toLowerCase()}`, parameter);
}
export function getPeriodDate(period?: { date?: string }): Date | undefined {