aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-web/src/main/js/apps')
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/RuleDetailsIssues.tsx14
-rw-r--r--server/sonar-web/src/main/js/apps/issues/components/App.tsx20
-rw-r--r--server/sonar-web/src/main/js/apps/issues/components/ListItem.tsx2
-rw-r--r--server/sonar-web/src/main/js/apps/issues/components/__tests__/App-test.tsx8
-rw-r--r--server/sonar-web/src/main/js/apps/issues/components/__tests__/BulkChangeModal-test.tsx2
-rw-r--r--server/sonar-web/src/main/js/apps/issues/conciseIssuesList/__tests__/ConciseIssue-test.tsx2
-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/FileFacet.tsx6
-rw-r--r--server/sonar-web/src/main/js/apps/issues/sidebar/ProjectFacet.tsx10
-rw-r--r--server/sonar-web/src/main/js/apps/issues/sidebar/Sidebar.tsx9
-rw-r--r--server/sonar-web/src/main/js/apps/issues/sidebar/__tests__/Sidebar-test.tsx3
-rw-r--r--server/sonar-web/src/main/js/apps/issues/utils.ts13
12 files changed, 49 insertions, 42 deletions
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 9eebdbf7771..3bb6e1839eb 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
@@ -34,7 +34,6 @@ interface Props {
interface Project {
count: number;
- id: string;
key: string;
name: string;
}
@@ -73,21 +72,16 @@ export default class RuleDetailsIssues extends React.PureComponent<Props, State>
this.setState({ loading: true });
getFacet(
{ organization: this.props.organization, rules: this.props.ruleKey, resolved: false },
- 'projectUuids'
+ 'projects'
).then(
({ facet, response }) => {
if (this.mounted) {
const { components = [], paging } = response;
const projects = [];
for (const item of facet) {
- const project = components.find(component => component.uuid === item.val);
+ const project = components.find(component => component.key === item.val);
if (project) {
- projects.push({
- count: item.count,
- id: item.val,
- key: project.key,
- name: project.name
- });
+ projects.push({ count: item.count, key: project.key, name: project.name });
}
}
this.setState({ projects, loading: false, total: paging.total });
@@ -130,7 +124,7 @@ export default class RuleDetailsIssues extends React.PureComponent<Props, State>
renderProject = (project: Project) => {
const path = getIssuesUrl(
- { projectUuids: project.id, resolved: 'false', rules: this.props.ruleKey },
+ { projects: project.key, resolved: 'false', rules: this.props.ruleKey },
this.props.organization
);
return (
diff --git a/server/sonar-web/src/main/js/apps/issues/components/App.tsx b/server/sonar-web/src/main/js/apps/issues/components/App.tsx
index 8e32c0e0691..355614151ee 100644
--- a/server/sonar-web/src/main/js/apps/issues/components/App.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/components/App.tsx
@@ -126,7 +126,8 @@ export interface State {
openPopup?: { issue: string; name: string };
paging?: Paging;
query: Query;
- referencedComponents: { [componentKey: string]: ReferencedComponent };
+ referencedComponentsById: { [id: string]: ReferencedComponent };
+ referencedComponentsByKey: { [key: string]: ReferencedComponent };
referencedLanguages: { [languageKey: string]: ReferencedLanguage };
referencedRules: { [ruleKey: string]: ReferencedRule };
referencedUsers: { [login: string]: ReferencedUser };
@@ -157,7 +158,8 @@ export default class App extends React.PureComponent<Props, State> {
myIssues: props.myIssues || areMyIssuesSelected(props.location.query),
openFacets: { severities: true, types: true },
query: parseQuery(props.location.query),
- referencedComponents: {},
+ referencedComponentsById: {},
+ referencedComponentsByKey: {},
referencedLanguages: {},
referencedRules: {},
referencedUsers: {},
@@ -477,7 +479,8 @@ export default class App extends React.PureComponent<Props, State> {
issues,
openIssue,
paging,
- referencedComponents: keyBy(other.components, 'uuid'),
+ referencedComponentsById: keyBy(other.components, 'uuid'),
+ referencedComponentsByKey: keyBy(other.components, 'key'),
referencedLanguages: keyBy(other.languages, 'key'),
referencedRules: keyBy(other.rules, 'key'),
referencedUsers: keyBy(other.users, 'login'),
@@ -602,10 +605,14 @@ export default class App extends React.PureComponent<Props, State> {
this.setState(state => ({
facets: { ...state.facets, ...parseFacets(facets) },
loadingFacets: omit(state.loadingFacets, facet),
- referencedComponents: {
- ...state.referencedComponents,
+ referencedComponentsById: {
+ ...state.referencedComponentsById,
...keyBy(other.components, 'uuid')
},
+ referencedComponentsByKey: {
+ ...state.referencedComponentsByKey,
+ ...keyBy(other.components, 'key')
+ },
referencedLanguages: {
...state.referencedLanguages,
...keyBy(other.languages, 'key')
@@ -945,7 +952,8 @@ export default class App extends React.PureComponent<Props, State> {
openFacets={this.state.openFacets}
organization={this.props.organization}
query={query}
- referencedComponents={this.state.referencedComponents}
+ referencedComponentsById={this.state.referencedComponentsById}
+ referencedComponentsByKey={this.state.referencedComponentsByKey}
referencedLanguages={this.state.referencedLanguages}
referencedRules={this.state.referencedRules}
referencedUsers={this.state.referencedUsers}
diff --git a/server/sonar-web/src/main/js/apps/issues/components/ListItem.tsx b/server/sonar-web/src/main/js/apps/issues/components/ListItem.tsx
index 588bcc38efe..a93601a5176 100644
--- a/server/sonar-web/src/main/js/apps/issues/components/ListItem.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/components/ListItem.tsx
@@ -83,7 +83,7 @@ export default class ListItem extends React.PureComponent<Props, State> {
onFilterChange({ ...issuesReset, rules: [issue.rule] });
break;
case 'project':
- onFilterChange({ ...issuesReset, projects: [issue.projectUuid] });
+ onFilterChange({ ...issuesReset, projects: [issue.projectKey] });
break;
case 'module':
if (issue.subProjectUuid) {
diff --git a/server/sonar-web/src/main/js/apps/issues/components/__tests__/App-test.tsx b/server/sonar-web/src/main/js/apps/issues/components/__tests__/App-test.tsx
index 2108d640fda..75a749bffd3 100644
--- a/server/sonar-web/src/main/js/apps/issues/components/__tests__/App-test.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/components/__tests__/App-test.tsx
@@ -18,6 +18,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import * as React from 'react';
+import { ShallowWrapper } from 'enzyme';
import App from '../App';
import { shallowWithIntl, waitAndUpdate } from '../../../../helpers/testUtils';
import { Issue } from '../../../../app/types';
@@ -35,6 +36,7 @@ const paging = { pageIndex: 1, pageSize: 100, total: 4 };
const eventNoShiftKey = { shiftKey: false } as MouseEvent;
const eventWithShiftKey = { shiftKey: true } as MouseEvent;
+const referencedComponent = { key: 'foo-key', name: 'bar', organization: 'John', uuid: 'foo-uuid' };
const PROPS = {
branch: { isMain: true, name: 'master' },
currentUser: {
@@ -48,7 +50,7 @@ const PROPS = {
location: { pathname: '/issues', query: {} },
fetchIssues: () =>
Promise.resolve({
- components: [],
+ components: [referencedComponent],
effortTotal: 1,
facets,
issues,
@@ -64,12 +66,14 @@ const PROPS = {
};
it('should render a list of issue', async () => {
- const wrapper = shallowWithIntl(<App {...PROPS} />, {
+ const wrapper: ShallowWrapper<App['props'], App['state']> = shallowWithIntl(<App {...PROPS} />, {
context: { router: { replace } }
});
await waitAndUpdate(wrapper);
expect(wrapper.state().issues.length).toBe(4);
+ expect(wrapper.state().referencedComponentsById).toEqual({ 'foo-uuid': referencedComponent });
+ expect(wrapper.state().referencedComponentsByKey).toEqual({ 'foo-key': referencedComponent });
});
it('should be able to check/uncheck a group of issues with the Shift key', async () => {
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 3895cc0053a..f0bcd9eaa55 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
@@ -49,7 +49,7 @@ it('should display form when issues are present', async () => {
project: 'foo',
projectName: 'foo',
projectOrganization: 'foo',
- projectUuid: 'foo',
+ projectKey: 'foo',
rule: 'foo',
ruleName: 'foo',
secondaryLocations: [],
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 549928cb0ea..2658e5ee0e0 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
@@ -33,7 +33,7 @@ const issue = {
project: '',
projectName: '',
projectOrganization: '',
- projectUuid: '',
+ projectKey: '',
rule: '',
ruleName: '',
severity: '',
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 744a5418ee6..5a50fbad489 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
@@ -19,9 +19,9 @@ exports[`should render 1`] = `
"message": "",
"organization": "",
"project": "",
+ "projectKey": "",
"projectName": "",
"projectOrganization": "",
- "projectUuid": "",
"rule": "",
"ruleName": "",
"secondaryLocations": Array [],
diff --git a/server/sonar-web/src/main/js/apps/issues/sidebar/FileFacet.tsx b/server/sonar-web/src/main/js/apps/issues/sidebar/FileFacet.tsx
index b04c72cf2af..32d22268dce 100644
--- a/server/sonar-web/src/main/js/apps/issues/sidebar/FileFacet.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/sidebar/FileFacet.tsx
@@ -43,12 +43,14 @@ interface Props {
export default class FileFacet extends React.PureComponent<Props> {
getFile = (file: string) => {
const { referencedComponents } = this.props;
- return referencedComponents[file] ? collapsePath(referencedComponents[file].path, 15) : file;
+ return referencedComponents[file]
+ ? collapsePath(referencedComponents[file].path || '', 15)
+ : file;
};
getFacetItemText = (file: string) => {
const { referencedComponents } = this.props;
- return referencedComponents[file] ? referencedComponents[file].path : file;
+ return referencedComponents[file] ? referencedComponents[file].path || '' : file;
};
getSearchResultKey = (file: TreeComponent) => {
diff --git a/server/sonar-web/src/main/js/apps/issues/sidebar/ProjectFacet.tsx b/server/sonar-web/src/main/js/apps/issues/sidebar/ProjectFacet.tsx
index 399977dcd90..a88080345c5 100644
--- a/server/sonar-web/src/main/js/apps/issues/sidebar/ProjectFacet.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/sidebar/ProjectFacet.tsx
@@ -43,7 +43,7 @@ interface Props {
}
interface SearchedProject {
- id: string;
+ key: string;
name: string;
organization: string;
}
@@ -64,8 +64,7 @@ export default class ProjectFacet extends React.PureComponent<Props> {
}).then(({ components, paging }) => ({
paging,
results: components.map(component => ({
- id: component.refId || component.id,
- key: component.key,
+ key: component.refKey || component.key,
name: component.name,
organization: component.organization
}))
@@ -80,7 +79,6 @@ export default class ProjectFacet extends React.PureComponent<Props> {
}).then(({ components, paging }) => ({
paging,
results: components.map(component => ({
- id: component.id,
key: component.key,
name: component.name,
organization: component.organization
@@ -95,7 +93,7 @@ export default class ProjectFacet extends React.PureComponent<Props> {
loadSearchResultCount = (projects: SearchedProject[]) => {
return this.props.loadSearchResultCount('projects', {
- projects: projects.map(project => project.id)
+ projects: projects.map(project => project.key)
});
};
@@ -137,7 +135,7 @@ export default class ProjectFacet extends React.PureComponent<Props> {
facetHeader={translate('issues.facet.projects')}
fetching={this.props.fetching}
getFacetItemText={this.getProjectName}
- getSearchResultKey={project => project.id}
+ getSearchResultKey={project => project.key}
getSearchResultText={project => project.name}
loadSearchResultCount={this.loadSearchResultCount}
onChange={this.props.onChange}
diff --git a/server/sonar-web/src/main/js/apps/issues/sidebar/Sidebar.tsx b/server/sonar-web/src/main/js/apps/issues/sidebar/Sidebar.tsx
index ca83e63f750..1e37378bab5 100644
--- a/server/sonar-web/src/main/js/apps/issues/sidebar/Sidebar.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/sidebar/Sidebar.tsx
@@ -56,7 +56,8 @@ export interface Props {
openFacets: { [facet: string]: boolean };
organization: { key: string } | undefined;
query: Query;
- referencedComponents: { [componentKey: string]: ReferencedComponent };
+ referencedComponentsById: { [id: string]: ReferencedComponent };
+ referencedComponentsByKey: { [key: string]: ReferencedComponent };
referencedLanguages: { [languageKey: string]: ReferencedLanguage };
referencedRules: { [ruleKey: string]: ReferencedRule };
referencedUsers: { [login: string]: ReferencedUser };
@@ -82,7 +83,7 @@ export default class Sidebar extends React.PureComponent<Props> {
fetching={loadingFacets.modules === true}
modules={query.modules}
open={!!openFacets.modules}
- referencedComponents={this.props.referencedComponents}
+ referencedComponents={this.props.referencedComponentsById}
stats={facets.modules}
{...commonProps}
/>
@@ -100,7 +101,7 @@ export default class Sidebar extends React.PureComponent<Props> {
fetching={loadingFacets.files === true}
files={query.files}
open={!!openFacets.files}
- referencedComponents={this.props.referencedComponents}
+ referencedComponents={this.props.referencedComponentsById}
stats={facets.files}
{...commonProps}
/>
@@ -233,7 +234,7 @@ export default class Sidebar extends React.PureComponent<Props> {
organization={this.props.organization}
projects={query.projects}
query={query}
- referencedComponents={this.props.referencedComponents}
+ referencedComponents={this.props.referencedComponentsByKey}
stats={facets.projects}
/>
)}
diff --git a/server/sonar-web/src/main/js/apps/issues/sidebar/__tests__/Sidebar-test.tsx b/server/sonar-web/src/main/js/apps/issues/sidebar/__tests__/Sidebar-test.tsx
index 85bdcd358f4..82c486fa438 100644
--- a/server/sonar-web/src/main/js/apps/issues/sidebar/__tests__/Sidebar-test.tsx
+++ b/server/sonar-web/src/main/js/apps/issues/sidebar/__tests__/Sidebar-test.tsx
@@ -40,7 +40,8 @@ const renderSidebar = (props?: Partial<Props>) => {
openFacets={{}}
organization={undefined}
query={{} as Query}
- referencedComponents={{}}
+ referencedComponentsById={{}}
+ referencedComponentsByKey={{}}
referencedLanguages={{}}
referencedRules={{}}
referencedUsers={{}}
diff --git a/server/sonar-web/src/main/js/apps/issues/utils.ts b/server/sonar-web/src/main/js/apps/issues/utils.ts
index bf7898e8747..ee1412f78f8 100644
--- a/server/sonar-web/src/main/js/apps/issues/utils.ts
+++ b/server/sonar-web/src/main/js/apps/issues/utils.ts
@@ -85,7 +85,7 @@ export function parseQuery(query: RawQuery): Query {
languages: parseAsArray(query.languages, parseAsString),
modules: parseAsArray(query.moduleUuids, parseAsString),
owaspTop10: parseAsArray(query.owaspTop10, parseAsString),
- projects: parseAsArray(query.projectUuids, parseAsString),
+ projects: parseAsArray(query.projects, parseAsString),
resolutions: parseAsArray(query.resolutions, parseAsString),
resolved: parseAsBoolean(query.resolved),
rules: parseAsArray(query.rules, parseAsString),
@@ -121,7 +121,7 @@ export function serializeQuery(query: Query): RawQuery {
languages: serializeStringArray(query.languages),
moduleUuids: serializeStringArray(query.modules),
owaspTop10: serializeStringArray(query.owaspTop10),
- projectUuids: serializeStringArray(query.projects),
+ projects: serializeStringArray(query.projects),
resolutions: serializeStringArray(query.resolutions),
resolved: query.resolved ? undefined : 'false',
rules: serializeStringArray(query.rules),
@@ -151,8 +151,7 @@ export interface Facet {
export function mapFacet(facet: string) {
const propertyMapping: { [x: string]: string } = {
files: 'fileUuids',
- modules: 'moduleUuids',
- projects: 'projectUuids'
+ modules: 'moduleUuids'
};
return propertyMapping[facet] || facet;
}
@@ -165,8 +164,7 @@ export function parseFacets(facets: RawFacet[]): { [x: string]: Facet } {
// for readability purpose
const propertyMapping: { [x: string]: string } = {
fileUuids: 'files',
- moduleUuids: 'modules',
- projectUuids: 'projects'
+ moduleUuids: 'modules'
};
const result: { [x: string]: Facet } = {};
@@ -189,7 +187,8 @@ export interface ReferencedComponent {
key: string;
name: string;
organization: string;
- path: string;
+ path?: string;
+ uuid: string;
}
export interface ReferencedUser {