aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStas Vilchik <stas.vilchik@sonarsource.com>2018-08-22 13:47:56 +0200
committerSonarTech <sonartech@sonarsource.com>2018-08-24 20:21:20 +0200
commitfae8b544d6c105606bb8a6c584bbe24ee2d94834 (patch)
treeb7ac8b6a6759c7cc404bde744bf83cfa32aa8a5e
parentfe5472dfe520e0681034fbd9996ccd030627b09b (diff)
downloadsonarqube-fae8b544d6c105606bb8a6c584bbe24ee2d94834.tar.gz
sonarqube-fae8b544d6c105606bb8a6c584bbe24ee2d94834.zip
introduce IssueType and RuleType enums
-rw-r--r--server/sonar-web/src/main/js/app/types.ts23
-rw-r--r--server/sonar-web/src/main/js/apps/about/components/AboutApp.js8
-rw-r--r--server/sonar-web/src/main/js/apps/about/components/EntryIssueTypes.js15
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/CustomRuleFormModal.tsx10
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/RuleDetailsIssues.tsx6
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/TypeFacet.tsx3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsDescription-test.tsx7
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsIssues-test.tsx7
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsMeta-test.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleListItem-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/apps/issues/components/BulkChangeModal.tsx4
-rw-r--r--server/sonar-web/src/main/js/apps/issues/components/__tests__/BulkChangeModal-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/ConciseIssue-test.tsx3
-rw-r--r--server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/__snapshots__/ConciseIssue-test.tsx.snap2
-rw-r--r--server/sonar-web/src/main/js/apps/issues/sidebar/TypeFacet.tsx6
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx11
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/qualityGate/QualityGateCondition.js19
-rw-r--r--server/sonar-web/src/main/js/apps/quality-profiles/details/ProfileRules.tsx3
-rw-r--r--server/sonar-web/src/main/js/apps/quality-profiles/details/__tests__/ProfileRules-test.tsx17
-rwxr-xr-xserver/sonar-web/src/main/js/apps/securityReports/components/App.tsx4
-rwxr-xr-xserver/sonar-web/src/main/js/apps/securityReports/components/VulnerabilityList.tsx14
-rw-r--r--server/sonar-web/src/main/js/apps/securityReports/components/__tests__/__snapshots__/App-test.tsx.snap10
-rw-r--r--server/sonar-web/src/main/js/components/SourceViewer/components/MeasuresOverlay.tsx16
-rw-r--r--server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineCode-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesIndicator-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesList-test.tsx4
-rw-r--r--server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineCode-test.tsx.snap4
-rw-r--r--server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineIssuesList-test.tsx.snap4
-rw-r--r--server/sonar-web/src/main/js/components/issue/components/IssueActionsBar.js5
-rw-r--r--server/sonar-web/src/main/js/components/issue/components/IssueTitleBar.js3
-rw-r--r--server/sonar-web/src/main/js/components/issue/popups/SetTypePopup.js3
-rw-r--r--server/sonar-web/src/main/js/components/issue/popups/__tests__/SetTypePopup-test.js3
-rw-r--r--server/sonar-web/src/main/js/components/shared/DrilldownLink.tsx8
-rw-r--r--server/sonar-web/src/main/js/components/shared/TypeHelper.tsx3
-rw-r--r--server/sonar-web/src/main/js/helpers/constants.ts14
36 files changed, 167 insertions, 101 deletions
diff --git a/server/sonar-web/src/main/js/app/types.ts b/server/sonar-web/src/main/js/app/types.ts
index 476f2c07d28..b39b6e62427 100644
--- a/server/sonar-web/src/main/js/app/types.ts
+++ b/server/sonar-web/src/main/js/app/types.ts
@@ -188,9 +188,9 @@ export interface Extension {
name: string;
}
-export interface FacetValue {
+export interface FacetValue<T = string> {
count: number;
- val: string;
+ val: T;
}
export interface FlowLocation {
@@ -310,7 +310,7 @@ export interface Issue {
tags?: string[];
textRange?: TextRange;
transitions?: string[];
- type: string;
+ type: IssueType;
}
export interface IssueComment {
@@ -326,6 +326,13 @@ export interface IssueComment {
updatable: boolean;
}
+export enum IssueType {
+ Bug = 'BUG',
+ Vulnerability = 'VULNERABILITY',
+ CodeSmell = 'CODE_SMELL',
+ Hotspot = 'SECURITY_HOTSPOT'
+}
+
export interface LightComponent {
key: string;
organization: string;
@@ -530,7 +537,7 @@ export interface Rule {
status: string;
sysTags?: string[];
tags?: string[];
- type: string;
+ type: RuleType;
}
export interface RuleActivation {
@@ -587,6 +594,14 @@ export enum RuleScope {
All = 'ALL'
}
+export enum RuleType {
+ Bug = 'BUG',
+ Vulnerability = 'VULNERABILITY',
+ CodeSmell = 'CODE_SMELL',
+ Hotspot = 'SECURITY_HOTSPOT',
+ Unknown = 'UNKNOWN'
+}
+
export interface ShortLivingBranch extends Branch {
isMain: false;
isOrphan?: true;
diff --git a/server/sonar-web/src/main/js/apps/about/components/AboutApp.js b/server/sonar-web/src/main/js/apps/about/components/AboutApp.js
index c1d319015f1..941db10c50b 100644
--- a/server/sonar-web/src/main/js/apps/about/components/AboutApp.js
+++ b/server/sonar-web/src/main/js/apps/about/components/AboutApp.js
@@ -38,6 +38,7 @@ import { getAppState, getCurrentUser, getGlobalSettingValue } from '../../../sto
import { translate } from '../../../helpers/l10n';
import { fetchAboutPageSettings } from '../actions';
import { isSonarCloud } from '../../../helpers/system';
+import { IssueType } from '../../../app/types';
import '../styles.css';
/*::
@@ -138,9 +139,10 @@ class AboutApp extends React.PureComponent {
let vulnerabilities;
let codeSmells;
if (!loading && issueTypes) {
- bugs = issueTypes['BUG'] && issueTypes['BUG'].count;
- vulnerabilities = issueTypes['VULNERABILITY'] && issueTypes['VULNERABILITY'].count;
- codeSmells = issueTypes['CODE_SMELL'] && issueTypes['CODE_SMELL'].count;
+ bugs = issueTypes[IssueType.Bug] && issueTypes[IssueType.Bug].count;
+ vulnerabilities =
+ issueTypes[IssueType.Vulnerability] && issueTypes[IssueType.Vulnerability].count;
+ codeSmells = issueTypes[IssueType.CodeSmell] && issueTypes[IssueType.CodeSmell].count;
}
return (
diff --git a/server/sonar-web/src/main/js/apps/about/components/EntryIssueTypes.js b/server/sonar-web/src/main/js/apps/about/components/EntryIssueTypes.js
index 499df6ce3a2..b6584777311 100644
--- a/server/sonar-web/src/main/js/apps/about/components/EntryIssueTypes.js
+++ b/server/sonar-web/src/main/js/apps/about/components/EntryIssueTypes.js
@@ -26,6 +26,7 @@ import { getIssuesUrl } from '../../../helpers/urls';
import BugIcon from '../../../components/icons-components/BugIcon';
import VulnerabilityIcon from '../../../components/icons-components/VulnerabilityIcon';
import CodeSmellIcon from '../../../components/icons-components/CodeSmellIcon';
+import { IssueType } from '../../../app/types';
/*::
type Props = {
@@ -49,7 +50,11 @@ export default function EntryIssueTypes(
<td className="about-page-issue-type-number">
<Link
className="about-page-issue-type-link"
- to={getIssuesUrl({ resolved: 'false', types: 'BUG', s: 'CREATION_DATE' })}>
+ to={getIssuesUrl({
+ resolved: 'false',
+ types: IssueType.Bug,
+ s: 'CREATION_DATE'
+ })}>
{formatMeasure(bugs, 'SHORT_INT')}
</Link>
</td>
@@ -66,7 +71,7 @@ export default function EntryIssueTypes(
className="about-page-issue-type-link"
to={getIssuesUrl({
resolved: 'false',
- types: 'VULNERABILITY',
+ types: IssueType.Vulnerability,
s: 'CREATION_DATE'
})}>
{formatMeasure(vulnerabilities, 'SHORT_INT')}
@@ -83,7 +88,11 @@ export default function EntryIssueTypes(
<td className="about-page-issue-type-number">
<Link
className="about-page-issue-type-link"
- to={getIssuesUrl({ resolved: 'false', types: 'CODE_SMELL', s: 'CREATION_DATE' })}>
+ to={getIssuesUrl({
+ resolved: 'false',
+ types: IssueType.CodeSmell,
+ s: 'CREATION_DATE'
+ })}>
{formatMeasure(codeSmells, 'SHORT_INT')}
</Link>
</td>
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/CustomRuleFormModal.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/CustomRuleFormModal.tsx
index 309e99dcf1d..19dc50eb809 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/CustomRuleFormModal.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/CustomRuleFormModal.tsx
@@ -18,11 +18,11 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import * as React from 'react';
-import { RuleDetails, RuleParameter } from '../../../app/types';
+import { RuleDetails, RuleParameter, RuleType } from '../../../app/types';
import Modal from '../../../components/controls/Modal';
import { translate } from '../../../helpers/l10n';
import MarkdownTips from '../../../components/common/MarkdownTips';
-import { SEVERITIES, TYPES, RULE_STATUSES } from '../../../helpers/constants';
+import { SEVERITIES, RULE_TYPES, RULE_STATUSES } from '../../../helpers/constants';
import latinize from '../../../helpers/latinize';
import Select from '../../../components/controls/Select';
import TypeHelper from '../../../components/shared/TypeHelper';
@@ -227,7 +227,9 @@ export default class CustomRuleFormModal extends React.PureComponent<Props, Stat
</tr>
);
- renderTypeOption = ({ value }: { value: string }) => <TypeHelper type={value} />;
+ renderTypeOption = ({ value }: { value: RuleType }) => {
+ return <TypeHelper type={value} />;
+ };
renderTypeField = () => (
<tr className="property">
@@ -241,7 +243,7 @@ export default class CustomRuleFormModal extends React.PureComponent<Props, Stat
disabled={this.state.submitting}
onChange={this.handleTypeChange}
optionRenderer={this.renderTypeOption}
- options={TYPES.map(type => ({
+ options={RULE_TYPES.map(type => ({
label: translate('issue.type', type),
value: type
}))}
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/RuleDetailsIssues.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/RuleDetailsIssues.tsx
index 4925b83ccce..9bcca9b529a 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/RuleDetailsIssues.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/RuleDetailsIssues.tsx
@@ -23,7 +23,7 @@ import { Link } from 'react-router';
import DeferredSpinner from '../../../components/common/DeferredSpinner';
import Tooltip from '../../../components/controls/Tooltip';
import { getFacet } from '../../../api/issues';
-import { RuleDetails } from '../../../app/types';
+import { RuleDetails, RuleType } from '../../../app/types';
import { getIssuesUrl } from '../../../helpers/urls';
import { formatMeasure } from '../../../helpers/measures';
import { translate } from '../../../helpers/l10n';
@@ -73,8 +73,8 @@ export default class RuleDetailsIssues extends React.PureComponent<Props, State>
resolved: 'false',
rules: this.props.ruleDetails.key,
types:
- this.props.ruleDetails.type === 'SECURITY_HOTSPOT'
- ? 'VULNERABILITY,SECURITY_HOTSPOT'
+ this.props.ruleDetails.type === RuleType.Hotspot
+ ? [RuleType.Vulnerability, RuleType.Hotspot].join()
: undefined
});
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/TypeFacet.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/TypeFacet.tsx
index ff2accac97f..0a08bf5587f 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/TypeFacet.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/TypeFacet.tsx
@@ -21,6 +21,7 @@ import * as React from 'react';
import Facet, { BasicProps } from './Facet';
import IssueTypeIcon from '../../../components/ui/IssueTypeIcon';
import { translate } from '../../../helpers/l10n';
+import { RuleType } from '../../../app/types';
export default class TypeFacet extends React.PureComponent<BasicProps> {
renderName = (type: string) => (
@@ -33,7 +34,7 @@ export default class TypeFacet extends React.PureComponent<BasicProps> {
renderTextName = (type: string) => translate('issue.type', type);
render() {
- const options = ['BUG', 'VULNERABILITY', 'CODE_SMELL', 'SECURITY_HOTSPOT'];
+ const options = [RuleType.Bug, RuleType.Vulnerability, RuleType.CodeSmell, RuleType.Hotspot];
return (
<Facet
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsDescription-test.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsDescription-test.tsx
index 10179121078..03c58dbe12d 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsDescription-test.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsDescription-test.tsx
@@ -21,6 +21,7 @@ import * as React from 'react';
import { shallow } from 'enzyme';
import RuleDetailsDescription from '../RuleDetailsDescription';
import { click, change, waitAndUpdate } from '../../../../helpers/testUtils';
+import { RuleType } from '../../../../app/types';
jest.mock('../../../../api/rules', () => ({
updateRule: jest.fn().mockResolvedValue('updatedrule')
@@ -37,7 +38,7 @@ const RULE = {
status: 'READY',
lang: 'java',
langName: 'Java',
- type: 'CODE_SMELL'
+ type: RuleType.CodeSmell
};
const EXTERNAL_RULE = {
@@ -46,7 +47,7 @@ const EXTERNAL_RULE = {
name: 'xoo:OneExternalIssuePerLine',
status: 'READY',
isExternal: true,
- type: 'UNKNOWN'
+ type: RuleType.Unknown
};
const EXTERNAL_RULE_WITH_DATA = {
@@ -57,7 +58,7 @@ const EXTERNAL_RULE_WITH_DATA = {
htmlDesc: '<p>Html Description</p>',
status: 'READY',
isExternal: true,
- type: 'BUG'
+ type: RuleType.Bug
};
it('should display correctly', () => {
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsIssues-test.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsIssues-test.tsx
index fb79d0585ed..cbd77073ed2 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsIssues-test.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsIssues-test.tsx
@@ -22,6 +22,7 @@ import { shallow } from 'enzyme';
import RuleDetailsIssues from '../RuleDetailsIssues';
import { waitAndUpdate } from '../../../../helpers/testUtils';
import { getFacet } from '../../../../api/issues';
+import { RuleType } from '../../../../app/types';
jest.mock('../../../../api/issues', () => ({
getFacet: jest.fn().mockResolvedValue({
@@ -38,14 +39,14 @@ beforeEach(() => {
});
it('should fetch issues and render', async () => {
- await check('BUG', undefined);
+ await check(RuleType.Bug, undefined);
});
it('should handle hotspot rules', async () => {
- await check('SECURITY_HOTSPOT', ['VULNERABILITY', 'SECURITY_HOTSPOT']);
+ await check(RuleType.Hotspot, [RuleType.Vulnerability, RuleType.Hotspot]);
});
-async function check(ruleType: string, requestedTypes: string[] | undefined) {
+async function check(ruleType: RuleType, requestedTypes: RuleType[] | undefined) {
const wrapper = shallow(
<RuleDetailsIssues organization="org" ruleDetails={{ key: 'foo', type: ruleType }} />
);
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsMeta-test.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsMeta-test.tsx
index 1380e6c0bfc..137e8b91a1a 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsMeta-test.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleDetailsMeta-test.tsx
@@ -20,7 +20,7 @@
import * as React from 'react';
import { shallow } from 'enzyme';
import RuleDetailsMeta from '../RuleDetailsMeta';
-import { RuleScope } from '../../../../app/types';
+import { RuleScope, RuleType } from '../../../../app/types';
import RuleDetailsTagsPopup from '../RuleDetailsTagsPopup';
const RULE = {
@@ -33,7 +33,7 @@ const RULE = {
lang: 'java',
langName: 'Java',
scope: RuleScope.Main,
- type: 'CODE_SMELL'
+ type: RuleType.CodeSmell
};
const EXTERNAL_RULE = {
@@ -44,7 +44,7 @@ const EXTERNAL_RULE = {
status: 'READY',
scope: RuleScope.All,
isExternal: true,
- type: 'UNKNOWN'
+ type: RuleType.Unknown
};
const EXTERNAL_RULE_WITH_DATA = {
@@ -59,7 +59,7 @@ const EXTERNAL_RULE_WITH_DATA = {
langName: 'Xoo',
scope: RuleScope.All,
isExternal: true,
- type: 'BUG'
+ type: RuleType.Bug
};
it('should display right meta info', () => {
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleListItem-test.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleListItem-test.tsx
index 6da05329f1b..0772c6afe30 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleListItem-test.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/__tests__/RuleListItem-test.tsx
@@ -20,7 +20,7 @@
import * as React from 'react';
import { shallow } from 'enzyme';
import RuleListItem from '../RuleListItem';
-import { Rule } from '../../../../app/types';
+import { Rule, RuleType } from '../../../../app/types';
import { mockEvent } from '../../../../helpers/testUtils';
const rule: Rule = {
@@ -32,7 +32,7 @@ const rule: Rule = {
status: 'READY',
sysTags: ['a', 'b'],
tags: ['x'],
- type: 'CODE_SMELL'
+ type: RuleType.CodeSmell
};
it('should render', () => {
diff --git a/server/sonar-web/src/main/js/apps/issues/components/BulkChangeModal.tsx b/server/sonar-web/src/main/js/apps/issues/components/BulkChangeModal.tsx
index 43c03a88fdb..64e770d506f 100644
--- a/server/sonar-web/src/main/js/apps/issues/components/BulkChangeModal.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/components/BulkChangeModal.tsx
@@ -21,7 +21,7 @@ import * as React from 'react';
import { pickBy, sortBy } from 'lodash';
import { searchAssignees } from '../utils';
import { searchIssueTags, bulkChangeIssues } from '../../../api/issues';
-import { Component, CurrentUser, Issue, Paging, isLoggedIn } from '../../../app/types';
+import { Component, CurrentUser, Issue, Paging, isLoggedIn, IssueType } from '../../../app/types';
import throwGlobalError from '../../../app/utils/throwGlobalError';
import MarkdownTips from '../../../components/common/MarkdownTips';
import SearchSelect from '../../../components/controls/SearchSelect';
@@ -332,7 +332,7 @@ export default class BulkChangeModal extends React.PureComponent<Props, State> {
return null;
}
- const types = ['BUG', 'VULNERABILITY', 'CODE_SMELL'];
+ const types = [IssueType.Bug, IssueType.Vulnerability, IssueType.CodeSmell];
const options = types.map(type => ({ label: translate('issue.type', type), value: type }));
const optionRenderer = (option: { label: string; value: string }) => (
diff --git a/server/sonar-web/src/main/js/apps/issues/components/__tests__/BulkChangeModal-test.tsx b/server/sonar-web/src/main/js/apps/issues/components/__tests__/BulkChangeModal-test.tsx
index f0bcd9eaa55..d6fbe8a5d2d 100644
--- a/server/sonar-web/src/main/js/apps/issues/components/__tests__/BulkChangeModal-test.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/components/__tests__/BulkChangeModal-test.tsx
@@ -21,7 +21,7 @@ import * as React from 'react';
import { shallow } from 'enzyme';
import BulkChangeModal from '../BulkChangeModal';
import { waitAndUpdate } from '../../../../helpers/testUtils';
-import { Issue } from '../../../../app/types';
+import { Issue, IssueType } from '../../../../app/types';
jest.mock('../../../../api/issues', () => ({
searchIssueTags: () => Promise.resolve([undefined, []])
@@ -55,7 +55,7 @@ it('should display form when issues are present', async () => {
secondaryLocations: [],
severity: 'foo',
status: 'foo',
- type: 'foo'
+ type: IssueType.Bug
}
]);
await waitAndUpdate(wrapper);
diff --git a/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/ConciseIssue-test.tsx b/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/ConciseIssue-test.tsx
index 2658e5ee0e0..7677f2c8b90 100644
--- a/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/ConciseIssue-test.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/ConciseIssue-test.tsx
@@ -20,6 +20,7 @@
import * as React from 'react';
import { shallow } from 'enzyme';
import ConciseIssue from '../ConciseIssue';
+import { IssueType } from '../../../../app/types';
const issue = {
component: '',
@@ -38,7 +39,7 @@ const issue = {
ruleName: '',
severity: '',
status: '',
- type: '',
+ type: IssueType.Bug,
secondaryLocations: [],
flows: [],
fromHotspot: false
diff --git a/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/__snapshots__/ConciseIssue-test.tsx.snap b/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/__snapshots__/ConciseIssue-test.tsx.snap
index 5a50fbad489..3041bcc6b35 100644
--- a/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/__snapshots__/ConciseIssue-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/__snapshots__/ConciseIssue-test.tsx.snap
@@ -27,7 +27,7 @@ exports[`should render 1`] = `
"secondaryLocations": Array [],
"severity": "",
"status": "",
- "type": "",
+ "type": "BUG",
}
}
onClick={[MockFunction]}
diff --git a/server/sonar-web/src/main/js/apps/issues/sidebar/TypeFacet.tsx b/server/sonar-web/src/main/js/apps/issues/sidebar/TypeFacet.tsx
index 6dced6ed39c..e246dc28202 100644
--- a/server/sonar-web/src/main/js/apps/issues/sidebar/TypeFacet.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/sidebar/TypeFacet.tsx
@@ -28,6 +28,7 @@ import IssueTypeIcon from '../../../components/ui/IssueTypeIcon';
import { translate } from '../../../helpers/l10n';
import DeferredSpinner from '../../../components/common/DeferredSpinner';
import MultipleSelectionHint from '../../../components/facet/MultipleSelectionHint';
+import { IssueType } from '../../../app/types';
interface Props {
fetching: boolean;
@@ -38,7 +39,7 @@ interface Props {
types: string[];
}
-const TYPES = ['BUG', 'VULNERABILITY', 'CODE_SMELL', 'SECURITY_HOTSPOT'];
+const TYPES = [IssueType.Bug, IssueType.Vulnerability, IssueType.CodeSmell, IssueType.Hotspot];
export default class TypeFacet extends React.PureComponent<Props> {
property = 'types';
@@ -80,7 +81,8 @@ export default class TypeFacet extends React.PureComponent<Props> {
// type is selected explicitly
types.includes(type) ||
// bugs, vulnerabilities and code smells are selected implicitly by default
- (types.length === 0 && ['BUG', 'VULNERABILITY', 'CODE_SMELL'].includes(type))
+ (types.length === 0 &&
+ [IssueType.Bug, IssueType.Vulnerability, IssueType.CodeSmell].includes(type as IssueType))
);
}
diff --git a/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx b/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx
index 4715c66a2ff..36b6061b3c6 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx
+++ b/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx
@@ -29,6 +29,7 @@ import { getMetricName } from '../helpers/metrics';
import { getComponentDrilldownUrl } from '../../../helpers/urls';
import { translate } from '../../../helpers/l10n';
import { isLongLivingBranch } from '../../../helpers/branches';
+import { IssueType } from '../../../app/types';
export class BugsAndVulnerabilities extends React.PureComponent<ComposedProps> {
renderHeader() {
@@ -81,7 +82,9 @@ export class BugsAndVulnerabilities extends React.PureComponent<ComposedProps> {
<div className="overview-domain-measures">
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">
- <span style={{ marginLeft: 30 }}>{this.props.renderIssues('new_bugs', 'BUG')}</span>
+ <span style={{ marginLeft: 30 }}>
+ {this.props.renderIssues('new_bugs', IssueType.Bug)}
+ </span>
{this.props.renderRating('new_reliability_rating')}
</div>
<div className="overview-domain-measure-label">
@@ -92,7 +95,7 @@ export class BugsAndVulnerabilities extends React.PureComponent<ComposedProps> {
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">
<span style={{ marginLeft: 30 }}>
- {this.props.renderIssues('new_vulnerabilities', 'VULNERABILITY')}
+ {this.props.renderIssues('new_vulnerabilities', IssueType.Vulnerability)}
</span>
{this.props.renderRating('new_security_rating')}
</div>
@@ -112,7 +115,7 @@ export class BugsAndVulnerabilities extends React.PureComponent<ComposedProps> {
<div className="overview-domain-measures">
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">
- {this.props.renderIssues('bugs', 'BUG')}
+ {this.props.renderIssues('bugs', IssueType.Bug)}
{this.props.renderRating('reliability_rating')}
</div>
<div className="overview-domain-measure-label">
@@ -123,7 +126,7 @@ export class BugsAndVulnerabilities extends React.PureComponent<ComposedProps> {
</div>
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">
- {this.props.renderIssues('vulnerabilities', 'VULNERABILITY')}
+ {this.props.renderIssues('vulnerabilities', IssueType.Vulnerability)}
{this.props.renderRating('security_rating')}
</div>
<div className="overview-domain-measure-label">
diff --git a/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx b/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx
index f180e484cd2..d4cf0cd784b 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx
+++ b/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx
@@ -25,6 +25,7 @@ import { translate, translateWithParameters } from '../../../helpers/l10n';
import { formatMeasure } from '../../../helpers/measures';
import CodeSmellIcon from '../../../components/icons-components/CodeSmellIcon';
import DrilldownLink from '../../../components/shared/DrilldownLink';
+import { IssueType } from '../../../app/types';
export class CodeSmells extends React.PureComponent<ComposedProps> {
renderHeader() {
@@ -84,7 +85,7 @@ export class CodeSmells extends React.PureComponent<ComposedProps> {
</div>
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">
- {this.props.renderIssues('new_code_smells', 'CODE_SMELL')}
+ {this.props.renderIssues('new_code_smells', IssueType.CodeSmell)}
</div>
<div className="overview-domain-measure-label">
<CodeSmellIcon className="little-spacer-right" />
@@ -114,7 +115,7 @@ export class CodeSmells extends React.PureComponent<ComposedProps> {
</div>
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">
- {this.props.renderIssues('code_smells', 'CODE_SMELL')}
+ {this.props.renderIssues('code_smells', IssueType.CodeSmell)}
</div>
<div className="overview-domain-measure-label offset-left">
<CodeSmellIcon className="little-spacer-right " />
diff --git a/server/sonar-web/src/main/js/apps/overview/qualityGate/QualityGateCondition.js b/server/sonar-web/src/main/js/apps/overview/qualityGate/QualityGateCondition.js
index 7e2d6d3772e..8e0f66767ef 100644
--- a/server/sonar-web/src/main/js/apps/overview/qualityGate/QualityGateCondition.js
+++ b/server/sonar-web/src/main/js/apps/overview/qualityGate/QualityGateCondition.js
@@ -28,6 +28,7 @@ import { getPeriodValue, isDiffMetric, formatMeasure } from '../../../helpers/me
import { translate } from '../../../helpers/l10n';
import { getComponentIssuesUrl } from '../../../helpers/urls';
import { getBranchLikeQuery } from '../../../helpers/branches';
+import { IssueType } from '../../../app/types';
/*:: import type { Component } from '../types'; */
/*:: import type { MeasureEnhanced } from '../../../components/measure/types'; */
@@ -67,7 +68,7 @@ export default class QualityGateCondition extends React.PureComponent {
};
getUrlForCodeSmells(sinceLeakPeriod /*: boolean */) {
- return this.getIssuesUrl(sinceLeakPeriod, { types: 'CODE_SMELL' });
+ return this.getIssuesUrl(sinceLeakPeriod, { types: IssueType.CodeSmell });
}
getUrlForBugsOrVulnerabilities(type /*: string */, sinceLeakPeriod /*: boolean */) {
@@ -88,7 +89,7 @@ export default class QualityGateCondition extends React.PureComponent {
}
getUrlForType(type /*: string */, sinceLeakPeriod /*: boolean */) {
- return type === 'CODE_SMELL'
+ return type === IssueType.CodeSmell
? this.getUrlForCodeSmells(sinceLeakPeriod)
: this.getUrlForBugsOrVulnerabilities(type, sinceLeakPeriod);
}
@@ -104,14 +105,16 @@ export default class QualityGateCondition extends React.PureComponent {
const metricKey = condition.measure.metric.key;
+ /* eslint-disable camelcase */
const RATING_METRICS_MAPPING = {
- reliability_rating: ['BUG', false],
- new_reliability_rating: ['BUG', true],
- security_rating: ['VULNERABILITY', false],
- new_security_rating: ['VULNERABILITY', true],
- sqale_rating: ['CODE_SMELL', false],
- new_maintainability_rating: ['CODE_SMELL', true]
+ reliability_rating: [IssueType.Bug, false],
+ new_reliability_rating: [IssueType.Bug, true],
+ security_rating: [IssueType.Vulnerability, false],
+ new_security_rating: [IssueType.Vulnerability, true],
+ sqale_rating: [IssueType.CodeSmell, false],
+ new_maintainability_rating: [IssueType.CodeSmell, true]
};
+ /* eslint-enable camelcase */
return RATING_METRICS_MAPPING[metricKey] ? (
<Link className={className} to={this.getUrlForType(...RATING_METRICS_MAPPING[metricKey])}>
diff --git a/server/sonar-web/src/main/js/apps/quality-profiles/details/ProfileRules.tsx b/server/sonar-web/src/main/js/apps/quality-profiles/details/ProfileRules.tsx
index a5866f1cc8a..880002c8914 100644
--- a/server/sonar-web/src/main/js/apps/quality-profiles/details/ProfileRules.tsx
+++ b/server/sonar-web/src/main/js/apps/quality-profiles/details/ProfileRules.tsx
@@ -29,8 +29,9 @@ import { getQualityProfile } from '../../../api/quality-profiles';
import { getRulesUrl } from '../../../helpers/urls';
import { translate } from '../../../helpers/l10n';
import { Profile } from '../types';
+import { RuleType } from '../../../app/types';
-const TYPES = ['BUG', 'VULNERABILITY', 'CODE_SMELL', 'SECURITY_HOTSPOT'];
+const TYPES = [RuleType.Bug, RuleType.Vulnerability, RuleType.CodeSmell, RuleType.Hotspot]
interface Props {
organization: string | null;
diff --git a/server/sonar-web/src/main/js/apps/quality-profiles/details/__tests__/ProfileRules-test.tsx b/server/sonar-web/src/main/js/apps/quality-profiles/details/__tests__/ProfileRules-test.tsx
index 2a313ccb6d8..ccb699c48fd 100644
--- a/server/sonar-web/src/main/js/apps/quality-profiles/details/__tests__/ProfileRules-test.tsx
+++ b/server/sonar-web/src/main/js/apps/quality-profiles/details/__tests__/ProfileRules-test.tsx
@@ -23,6 +23,7 @@ import ProfileRules from '../ProfileRules';
import * as apiRules from '../../../../api/rules';
import * as apiQP from '../../../../api/quality-profiles';
import { waitAndUpdate } from '../../../../helpers/testUtils';
+import { RuleType } from '../../../../app/types';
const PROFILE = {
activeRuleCount: 68,
@@ -48,10 +49,10 @@ const apiResponseAll = {
{
property: 'types',
values: [
- { val: 'CODE_SMELL', count: 168 },
- { val: 'BUG', count: 68 },
- { val: 'VULNERABILITY', count: 7 },
- { val: 'SECURITY_HOTSPOT', count: 10 }
+ { val: RuleType.CodeSmell, count: 168 },
+ { val: RuleType.Bug, count: 68 },
+ { val: RuleType.Vulnerability, count: 7 },
+ { val: RuleType.Hotspot, count: 10 }
]
}
]
@@ -63,10 +64,10 @@ const apiResponseActive = {
{
property: 'types',
values: [
- { val: 'BUG', count: 68 },
- { val: 'CODE_SMELL', count: 0 },
- { val: 'VULNERABILITY', count: 0 },
- { val: 'SECURITY_HOTSPOT', count: 0 }
+ { val: RuleType.Bug, count: 68 },
+ { val: RuleType.CodeSmell, count: 0 },
+ { val: RuleType.Vulnerability, count: 0 },
+ { val: RuleType.Hotspot, count: 0 }
]
}
]
diff --git a/server/sonar-web/src/main/js/apps/securityReports/components/App.tsx b/server/sonar-web/src/main/js/apps/securityReports/components/App.tsx
index def1019b4b4..01b31f1e820 100755
--- a/server/sonar-web/src/main/js/apps/securityReports/components/App.tsx
+++ b/server/sonar-web/src/main/js/apps/securityReports/components/App.tsx
@@ -25,7 +25,7 @@ import { FormattedMessage } from 'react-intl';
import VulnerabilityList from './VulnerabilityList';
import Suggestions from '../../../app/components/embed-docs-modal/Suggestions';
import { translate } from '../../../helpers/l10n';
-import { Component, BranchLike, SecurityHotspot } from '../../../app/types';
+import { Component, BranchLike, SecurityHotspot, RuleType } from '../../../app/types';
import DeferredSpinner from '../../../components/common/DeferredSpinner';
import Checkbox from '../../../components/controls/Checkbox';
import { RawQuery } from '../../../helpers/query';
@@ -154,7 +154,7 @@ export default class App extends React.PureComponent<Props, State> {
link: (
<Link
to={getRulesUrl(
- { types: 'SECURITY_HOTSPOT,VULNERABILITY' },
+ { types: [RuleType.Vulnerability, RuleType.Hotspot].join() },
isSonarCloud() ? component.organization : undefined
)}>
{translate('security_reports.info.link')}
diff --git a/server/sonar-web/src/main/js/apps/securityReports/components/VulnerabilityList.tsx b/server/sonar-web/src/main/js/apps/securityReports/components/VulnerabilityList.tsx
index a764647e5db..f4efc4acd65 100755
--- a/server/sonar-web/src/main/js/apps/securityReports/components/VulnerabilityList.tsx
+++ b/server/sonar-web/src/main/js/apps/securityReports/components/VulnerabilityList.tsx
@@ -21,7 +21,7 @@ import * as React from 'react';
import * as classNames from 'classnames';
import { Link } from 'react-router';
import { translate } from '../../../helpers/l10n';
-import { SecurityHotspot, Component, BranchLike } from '../../../app/types';
+import { SecurityHotspot, Component, BranchLike, IssueType } from '../../../app/types';
import Rating from '../../../components/ui/Rating';
import { getComponentIssuesUrl } from '../../../helpers/urls';
import { getBranchLikeQuery } from '../../../helpers/branches';
@@ -125,7 +125,7 @@ export default class VulnerabilityList extends React.PureComponent<Props, State>
const { branchLike, component, type } = this.props;
const params: { [name: string]: string | undefined } = {
...getBranchLikeQuery(branchLike),
- types: 'SECURITY_HOTSPOT'
+ types: IssueType.Hotspot
};
if (isCWE && parent) {
params['cwe'] = finding.cwe;
@@ -151,7 +151,7 @@ export default class VulnerabilityList extends React.PureComponent<Props, State>
<Link
to={getComponentIssuesUrl(component.key, {
...params,
- types: 'VULNERABILITY',
+ types: IssueType.Vulnerability,
resolved: 'false'
})}>
{finding.vulnerabilities}
@@ -161,7 +161,7 @@ export default class VulnerabilityList extends React.PureComponent<Props, State>
className="link-no-underline spacer-left"
to={getComponentIssuesUrl(component.key, {
...params,
- types: 'VULNERABILITY',
+ types: IssueType.Vulnerability,
resolved: 'false'
})}>
<Rating value={finding.vulnerabilityRating || 1} />
@@ -173,7 +173,7 @@ export default class VulnerabilityList extends React.PureComponent<Props, State>
<Link
to={getComponentIssuesUrl(component.key, {
...params,
- types: 'SECURITY_HOTSPOT',
+ types: IssueType.Hotspot,
resolved: 'false',
statuses: 'OPEN,REOPENED'
})}>
@@ -184,7 +184,7 @@ export default class VulnerabilityList extends React.PureComponent<Props, State>
<Link
to={getComponentIssuesUrl(component.key, {
...params,
- types: 'SECURITY_HOTSPOT',
+ types: IssueType.Hotspot,
resolutions: 'FIXED',
statuses: 'RESOLVED'
})}>
@@ -195,7 +195,7 @@ export default class VulnerabilityList extends React.PureComponent<Props, State>
<Link
to={getComponentIssuesUrl(component.key, {
...params,
- types: 'SECURITY_HOTSPOT',
+ types: IssueType.Hotspot,
resolutions: 'WONTFIX',
statuses: 'RESOLVED'
})}>
diff --git a/server/sonar-web/src/main/js/apps/securityReports/components/__tests__/__snapshots__/App-test.tsx.snap b/server/sonar-web/src/main/js/apps/securityReports/components/__tests__/__snapshots__/App-test.tsx.snap
index 86b8d8c2b57..2ab1a498552 100644
--- a/server/sonar-web/src/main/js/apps/securityReports/components/__tests__/__snapshots__/App-test.tsx.snap
+++ b/server/sonar-web/src/main/js/apps/securityReports/components/__tests__/__snapshots__/App-test.tsx.snap
@@ -54,7 +54,7 @@ exports[`handle checkbox for cwe display 1`] = `
Object {
"pathname": "/coding_rules",
"query": Object {
- "types": "SECURITY_HOTSPOT,VULNERABILITY",
+ "types": "VULNERABILITY,SECURITY_HOTSPOT",
},
}
}
@@ -164,7 +164,7 @@ exports[`handle checkbox for cwe display 2`] = `
Object {
"pathname": "/coding_rules",
"query": Object {
- "types": "SECURITY_HOTSPOT,VULNERABILITY",
+ "types": "VULNERABILITY,SECURITY_HOTSPOT",
},
}
}
@@ -317,7 +317,7 @@ exports[`renders owaspTop10 1`] = `
Object {
"pathname": "/coding_rules",
"query": Object {
- "types": "SECURITY_HOTSPOT,VULNERABILITY",
+ "types": "VULNERABILITY,SECURITY_HOTSPOT",
},
}
}
@@ -427,7 +427,7 @@ exports[`renders sansTop25 1`] = `
Object {
"pathname": "/coding_rules",
"query": Object {
- "types": "SECURITY_HOTSPOT,VULNERABILITY",
+ "types": "VULNERABILITY,SECURITY_HOTSPOT",
},
}
}
@@ -537,7 +537,7 @@ exports[`renders with cwe 1`] = `
Object {
"pathname": "/coding_rules",
"query": Object {
- "types": "SECURITY_HOTSPOT,VULNERABILITY",
+ "types": "VULNERABILITY,SECURITY_HOTSPOT",
},
}
}
diff --git a/server/sonar-web/src/main/js/components/SourceViewer/components/MeasuresOverlay.tsx b/server/sonar-web/src/main/js/components/SourceViewer/components/MeasuresOverlay.tsx
index cf25dc909b5..a21e366ae91 100644
--- a/server/sonar-web/src/main/js/components/SourceViewer/components/MeasuresOverlay.tsx
+++ b/server/sonar-web/src/main/js/components/SourceViewer/components/MeasuresOverlay.tsx
@@ -26,7 +26,13 @@ import { Button } from '../../ui/buttons';
import { getFacets } from '../../../api/issues';
import { getMeasures } from '../../../api/measures';
import { getAllMetrics } from '../../../api/metrics';
-import { FacetValue, SourceViewerFile, BranchLike, MeasureEnhanced } from '../../../app/types';
+import {
+ FacetValue,
+ SourceViewerFile,
+ BranchLike,
+ MeasureEnhanced,
+ IssueType
+} from '../../../app/types';
import Modal from '../../controls/Modal';
import Measure from '../../measure/Measure';
import QualifierIcon from '../../icons-components/QualifierIcon';
@@ -34,7 +40,7 @@ import SeverityHelper from '../../shared/SeverityHelper';
import CoverageRating from '../../ui/CoverageRating';
import DuplicationsRating from '../../ui/DuplicationsRating';
import IssueTypeIcon from '../../ui/IssueTypeIcon';
-import { SEVERITIES, TYPES } from '../../../helpers/constants';
+import { SEVERITIES, ISSUE_TYPES } from '../../../helpers/constants';
import { translate, getLocalizedMetricName } from '../../../helpers/l10n';
import {
formatMeasure,
@@ -61,7 +67,7 @@ interface State {
severitiesFacet?: FacetValue[];
showAllMeasures: boolean;
tagsFacet?: FacetValue[];
- typesFacet?: FacetValue[];
+ typesFacet?: FacetValue<IssueType>[];
}
export default class MeasuresOverlay extends React.PureComponent<Props, State> {
@@ -125,7 +131,7 @@ export default class MeasuresOverlay extends React.PureComponent<Props, State> {
return {
severitiesFacet: severitiesFacet && severitiesFacet.values,
tagsFacet: tagsFacet && tagsFacet.values,
- typesFacet: typesFacet && typesFacet.values
+ typesFacet: typesFacet && (typesFacet.values as FacetValue<IssueType>[])
};
});
};
@@ -197,7 +203,7 @@ export default class MeasuresOverlay extends React.PureComponent<Props, State> {
{typesFacet && (
<div className="measures">
<div className="measures-list">
- {sortBy(typesFacet, f => TYPES.indexOf(f.val)).map(f => (
+ {sortBy(typesFacet, f => ISSUE_TYPES.indexOf(f.val)).map(f => (
<div className="measure measure-one-line" key={f.val}>
<span className="measure-name">
<IssueTypeIcon className="little-spacer-right" query={f.val} />
diff --git a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineCode-test.tsx b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineCode-test.tsx
index 771faf4ac35..9ba8c1ecc56 100644
--- a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineCode-test.tsx
+++ b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineCode-test.tsx
@@ -20,7 +20,7 @@
import * as React from 'react';
import { shallow } from 'enzyme';
import LineCode from '../LineCode';
-import { BranchType, Issue, ShortLivingBranch } from '../../../../app/types';
+import { BranchType, Issue, ShortLivingBranch, IssueType } from '../../../../app/types';
const issueBase: Issue = {
component: '',
@@ -42,7 +42,7 @@ const issueBase: Issue = {
secondaryLocations: [],
severity: '',
status: '',
- type: ''
+ type: IssueType.Bug
};
it('render code', () => {
diff --git a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesIndicator-test.tsx b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesIndicator-test.tsx
index d19db5dbf15..03551c9c82c 100644
--- a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesIndicator-test.tsx
+++ b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesIndicator-test.tsx
@@ -21,7 +21,7 @@ import * as React from 'react';
import { shallow } from 'enzyme';
import { click } from '../../../../helpers/testUtils';
import LineIssuesIndicator from '../LineIssuesIndicator';
-import { Issue } from '../../../../app/types';
+import { Issue, IssueType } from '../../../../app/types';
const issueBase: Issue = {
component: '',
@@ -43,7 +43,7 @@ const issueBase: Issue = {
secondaryLocations: [],
severity: '',
status: '',
- type: ''
+ type: IssueType.Bug
};
it('render highest severity', () => {
diff --git a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesList-test.tsx b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesList-test.tsx
index a76ebb1c1fc..3e1f834af24 100644
--- a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesList-test.tsx
+++ b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/LineIssuesList-test.tsx
@@ -20,7 +20,7 @@
import * as React from 'react';
import { shallow } from 'enzyme';
import LineIssuesList from '../LineIssuesList';
-import { Issue } from '../../../../app/types';
+import { Issue, IssueType } from '../../../../app/types';
const issueBase: Issue = {
component: '',
@@ -42,7 +42,7 @@ const issueBase: Issue = {
secondaryLocations: [],
severity: '',
status: '',
- type: ''
+ type: IssueType.Bug
};
it('render issues list', () => {
diff --git a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineCode-test.tsx.snap b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineCode-test.tsx.snap
index 948fb8dcee4..0e31b6b8405 100644
--- a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineCode-test.tsx.snap
+++ b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineCode-test.tsx.snap
@@ -66,7 +66,7 @@ exports[`render code 1`] = `
"secondaryLocations": Array [],
"severity": "",
"status": "",
- "type": "",
+ "type": "BUG",
},
Object {
"component": "",
@@ -88,7 +88,7 @@ exports[`render code 1`] = `
"secondaryLocations": Array [],
"severity": "",
"status": "",
- "type": "",
+ "type": "BUG",
},
]
}
diff --git a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineIssuesList-test.tsx.snap b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineIssuesList-test.tsx.snap
index 0678ee9ec9e..8a7ac40bb32 100644
--- a/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineIssuesList-test.tsx.snap
+++ b/server/sonar-web/src/main/js/components/SourceViewer/components/__tests__/__snapshots__/LineIssuesList-test.tsx.snap
@@ -28,7 +28,7 @@ exports[`render issues list 1`] = `
"secondaryLocations": Array [],
"severity": "",
"status": "",
- "type": "",
+ "type": "BUG",
}
}
key="foo"
@@ -61,7 +61,7 @@ exports[`render issues list 1`] = `
"secondaryLocations": Array [],
"severity": "",
"status": "",
- "type": "",
+ "type": "BUG",
}
}
key="bar"
diff --git a/server/sonar-web/src/main/js/components/issue/components/IssueActionsBar.js b/server/sonar-web/src/main/js/components/issue/components/IssueActionsBar.js
index f46c484ec4e..0f12bf3a226 100644
--- a/server/sonar-web/src/main/js/components/issue/components/IssueActionsBar.js
+++ b/server/sonar-web/src/main/js/components/issue/components/IssueActionsBar.js
@@ -26,6 +26,7 @@ import IssueTags from './IssueTags';
import IssueTransition from './IssueTransition';
import IssueType from './IssueType';
import { updateIssue } from '../actions';
+import { IssueType as IssueTypes } from '../../../app/types';
import { translate, translateWithParameters } from '../../../helpers/l10n';
/*:: import type { Issue } from '../types'; */
@@ -81,7 +82,7 @@ export default class IssueActionsBar extends React.PureComponent {
this.props.onChange(issue);
if (
issue.resolution === 'FALSE-POSITIVE' ||
- (issue.resolution === 'WONTFIX' && issue.type !== 'SECURITY_HOTSPOT')
+ (issue.resolution === 'WONTFIX' && issue.type !== IssueTypes.Hotspot)
) {
this.toggleComment(true, translate('issue.comment.tell_why'));
}
@@ -95,7 +96,7 @@ export default class IssueActionsBar extends React.PureComponent {
const canSetType = issue.actions.includes('set_type');
const canSetTags = issue.actions.includes('set_tags');
const hasTransitions = issue.transitions && issue.transitions.length > 0;
- const isSecurityHotspot = issue.type === 'SECURITY_HOTSPOT';
+ const isSecurityHotspot = issue.type === IssueTypes.Hotspot;
return (
<div className="issue-actions">
diff --git a/server/sonar-web/src/main/js/components/issue/components/IssueTitleBar.js b/server/sonar-web/src/main/js/components/issue/components/IssueTitleBar.js
index 080113085e6..6c7ab58887a 100644
--- a/server/sonar-web/src/main/js/components/issue/components/IssueTitleBar.js
+++ b/server/sonar-web/src/main/js/components/issue/components/IssueTitleBar.js
@@ -30,6 +30,7 @@ import { getBranchLikeQuery } from '../../../helpers/branches';
import { getComponentIssuesUrl } from '../../../helpers/urls';
import { formatMeasure } from '../../../helpers/measures';
import { translate, translateWithParameters } from '../../../helpers/l10n';
+import { IssueType } from '../../../app/types';
/*:: import type { Issue } from '../types'; */
/*::
@@ -75,7 +76,7 @@ export default function IssueTitleBar(props /*: Props */) {
<div className="issue-row">
<IssueMessage
engine={issue.externalRuleEngine}
- manualVulnerability={issue.fromHotspot && issue.type === 'VULNERABILITY'}
+ manualVulnerability={issue.fromHotspot && issue.type === IssueType.Vulnerability}
message={issue.message}
organization={issue.organization}
rule={issue.rule}
diff --git a/server/sonar-web/src/main/js/components/issue/popups/SetTypePopup.js b/server/sonar-web/src/main/js/components/issue/popups/SetTypePopup.js
index 4c2fadc9f0c..cb65a1018c0 100644
--- a/server/sonar-web/src/main/js/components/issue/popups/SetTypePopup.js
+++ b/server/sonar-web/src/main/js/components/issue/popups/SetTypePopup.js
@@ -24,6 +24,7 @@ import IssueTypeIcon from '../../ui/IssueTypeIcon';
import SelectList from '../../common/SelectList';
import SelectListItem from '../../common/SelectListItem';
import { DropdownOverlay } from '../../controls/Dropdown';
+import { IssueType } from '../../../app/types';
/*:: import type { Issue } from '../types'; */
/*::
@@ -33,7 +34,7 @@ type Props = {
};
*/
-const TYPES = ['BUG', 'VULNERABILITY', 'CODE_SMELL'];
+const TYPES = [IssueType.Bug, IssueType.Vulnerability, IssueType.CodeSmell];
export default class SetTypePopup extends React.PureComponent {
/*:: props: Props; */
diff --git a/server/sonar-web/src/main/js/components/issue/popups/__tests__/SetTypePopup-test.js b/server/sonar-web/src/main/js/components/issue/popups/__tests__/SetTypePopup-test.js
index 0844eeacc56..79a8a292eed 100644
--- a/server/sonar-web/src/main/js/components/issue/popups/__tests__/SetTypePopup-test.js
+++ b/server/sonar-web/src/main/js/components/issue/popups/__tests__/SetTypePopup-test.js
@@ -20,8 +20,9 @@
import { shallow } from 'enzyme';
import React from 'react';
import SetTypePopup from '../SetTypePopup';
+import { IssueType } from '../../../../app/types';
it('should render tags popup correctly', () => {
- const element = shallow(<SetTypePopup issue={{ type: 'BUG' }} onSelect={jest.fn()} />);
+ const element = shallow(<SetTypePopup issue={{ type: IssueType.Bug }} onSelect={jest.fn()} />);
expect(element).toMatchSnapshot();
});
diff --git a/server/sonar-web/src/main/js/components/shared/DrilldownLink.tsx b/server/sonar-web/src/main/js/components/shared/DrilldownLink.tsx
index 8081a2c76d3..b711cdb4783 100644
--- a/server/sonar-web/src/main/js/components/shared/DrilldownLink.tsx
+++ b/server/sonar-web/src/main/js/components/shared/DrilldownLink.tsx
@@ -20,7 +20,7 @@
import * as React from 'react';
import { Link } from 'react-router';
import { getComponentDrilldownUrl, getComponentIssuesUrl } from '../../helpers/urls';
-import { BranchLike } from '../../app/types';
+import { BranchLike, IssueType } from '../../app/types';
import { getBranchLikeQuery } from '../../helpers/branches';
const ISSUE_MEASURES = [
@@ -104,15 +104,15 @@ export default class DrilldownLink extends React.PureComponent<Props> {
break;
case 'code_smells':
case 'new_code_smells':
- Object.assign(params, { resolved: 'false', types: 'CODE_SMELL' });
+ Object.assign(params, { resolved: 'false', types: IssueType.CodeSmell });
break;
case 'bugs':
case 'new_bugs':
- Object.assign(params, { resolved: 'false', types: 'BUG' });
+ Object.assign(params, { resolved: 'false', types: IssueType.Bug });
break;
case 'vulnerabilities':
case 'new_vulnerabilities':
- Object.assign(params, { resolved: 'false', types: 'VULNERABILITY' });
+ Object.assign(params, { resolved: 'false', types: IssueType.Vulnerability });
break;
default:
Object.assign(params, { resolved: 'false' });
diff --git a/server/sonar-web/src/main/js/components/shared/TypeHelper.tsx b/server/sonar-web/src/main/js/components/shared/TypeHelper.tsx
index 1229bf38a88..f397063230e 100644
--- a/server/sonar-web/src/main/js/components/shared/TypeHelper.tsx
+++ b/server/sonar-web/src/main/js/components/shared/TypeHelper.tsx
@@ -20,10 +20,11 @@
import * as React from 'react';
import IssueTypeIcon from '../ui/IssueTypeIcon';
import { translate } from '../../helpers/l10n';
+import { RuleType, IssueType } from '../../app/types';
interface Props {
className?: string;
- type: string;
+ type: IssueType | RuleType;
}
export default function TypeHelper(props: Props) {
diff --git a/server/sonar-web/src/main/js/helpers/constants.ts b/server/sonar-web/src/main/js/helpers/constants.ts
index 0857573b85f..44cf06ffd8f 100644
--- a/server/sonar-web/src/main/js/helpers/constants.ts
+++ b/server/sonar-web/src/main/js/helpers/constants.ts
@@ -18,10 +18,22 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import * as theme from '../app/theme';
+import { RuleType, IssueType } from '../app/types';
export const SEVERITIES = ['BLOCKER', 'CRITICAL', 'MAJOR', 'MINOR', 'INFO'];
export const STATUSES = ['OPEN', 'REOPENED', 'CONFIRMED', 'RESOLVED', 'CLOSED'];
-export const TYPES = ['BUG', 'VULNERABILITY', 'CODE_SMELL', 'SECURITY_HOTSPOT'];
+export const ISSUE_TYPES = [
+ IssueType.Bug,
+ IssueType.Vulnerability,
+ IssueType.CodeSmell,
+ IssueType.Hotspot
+];
+export const RULE_TYPES = [
+ RuleType.Bug,
+ RuleType.Vulnerability,
+ RuleType.CodeSmell,
+ RuleType.Hotspot
+];
export const RULE_STATUSES = ['READY', 'BETA', 'DEPRECATED'];
export const CHART_COLORS_RANGE_PERCENT = [