Browse Source

SONAR-12415 Fix Leak title in project overview

tags/8.0
Jeremy Davis 4 years ago
parent
commit
45f8d835ab

+ 5
- 1
server/sonar-web/src/main/js/app/types.d.ts View File

@@ -578,7 +578,7 @@ declare namespace T {
export interface Period {
date: string;
index: number;
mode: PeriodMode;
mode: PeriodMode | NewCodePeriodSettingType;
modeParam?: string;
parameter?: string;
}
@@ -589,6 +589,10 @@ declare namespace T {
value: string;
}

/*
* These are old baseline setting types, necessary for
* backward compatibility.
*/
export type PeriodMode =
| 'days'
| 'date'

+ 1
- 1
server/sonar-web/src/main/js/apps/component-measures/components/LeakPeriodLegend.tsx View File

@@ -64,7 +64,7 @@ export class LeakPeriodLegend extends React.PureComponent<Props & InjectedIntlPr
</div>
);

if (period.mode === 'days') {
if (period.mode === 'days' || period.mode === 'NUMBER_OF_DAYS') {
return label;
}


+ 7
- 2
server/sonar-web/src/main/js/apps/overview/components/LeakPeriodLegend.tsx View File

@@ -31,6 +31,11 @@ interface Props {
period: T.Period;
}

const MODE_INCLUDES_TIME: T.Dict<boolean> = {
manual_baseline: true,
SPECIFIC_ANALYSIS: true
};

export class LeakPeriodLegend extends React.PureComponent<Props & InjectedIntlProps> {
formatDate = (date: string) => {
return this.props.intl.formatDate(date, longFormatterOption);
@@ -44,13 +49,13 @@ export class LeakPeriodLegend extends React.PureComponent<Props & InjectedIntlPr
const { period } = this.props;
const leakPeriodLabel = getPeriodLabel(
period,
period.mode === 'manual_baseline' ? this.formatDateTime : this.formatDate
MODE_INCLUDES_TIME[period.mode] ? this.formatDateTime : this.formatDate
);
if (!leakPeriodLabel) {
return null;
}

if (period.mode === 'days') {
if (period.mode === 'days' || period.mode === 'NUMBER_OF_DAYS') {
return (
<div className="overview-legend overview-legend-spaced-line">
{translateWithParameters('overview.new_code_period_x', leakPeriodLabel)}

+ 1
- 1
server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/LeakPeriodLegend-test.tsx.snap View File

@@ -51,7 +51,7 @@ exports[`manual_baseline 2`] = `
<div
className="overview-legend"
>
overview.new_code_period_x.overview.period.previous_version.1.1.2
overview.new_code_period_x.overview.period.manual_baseline.1.1.2
<br />
<DateFromNow
date={2013-09-21T22:00:00.000Z}

+ 108
- 0
server/sonar-web/src/main/js/helpers/__tests__/periods-test.ts View File

@@ -0,0 +1,108 @@
/*
* 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);
});
});

+ 23
- 12
server/sonar-web/src/main/js/helpers/periods.ts View File

@@ -39,22 +39,33 @@ export function getPeriodLabel(
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 {

+ 9
- 0
server/sonar-web/src/main/js/helpers/testMocks.ts View File

@@ -523,6 +523,15 @@ export function mockOrganizationWithAlm(
});
}

export function mockPeriod(overrides: Partial<T.Period> = {}): T.Period {
return {
date: '2019-04-23T02:12:32+0100',
index: 0,
mode: 'previous_version',
...overrides
};
}

export function mockQualityGate(overrides: Partial<T.QualityGate> = {}): T.QualityGate {
return {
id: 1,

+ 6
- 0
sonar-core/src/main/resources/org/sonar/l10n/core.properties View File

@@ -2554,6 +2554,8 @@ overview.duplications_on=Duplications on
overview.duplications_on_X=Duplications on {count} New Lines

overview.period.previous_version=since {0}

# Old periods, necessary to display project that haven't been analyzed with new setting (MMF-1579)
overview.period.previous_version_only_date=since previous version
overview.period.previous_analysis=since previous analysis
overview.period.days=last {0} days
@@ -2561,6 +2563,10 @@ overview.period.version=since {0}
overview.period.date=after {0}
overview.period.manual_baseline=since {0}

# New periods (MMF-1579)
overview.period.number_of_days=from last {0} days
overview.period.specific_analysis=since analysis on {0}

overview.gate.ERROR=Failed
overview.gate.WARN=Warning
overview.gate.OK=Passed

Loading…
Cancel
Save