diff options
author | Mathieu Suen <mathieu.suen@sonarsource.com> | 2021-04-16 17:01:01 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2021-04-20 20:03:47 +0000 |
commit | f617133c4fa984b762256d266db3e78625f12a98 (patch) | |
tree | 4eed7f61424f4edf84e611a3ac055fb08f552673 | |
parent | 1e9b380ea92c0255a8ec8a0d805fcc77a824cb03 (diff) | |
download | sonarqube-f617133c4fa984b762256d266db3e78625f12a98.tar.gz sonarqube-f617133c4fa984b762256d266db3e78625f12a98.zip |
SONAR-14715 Avoid calling issue search when indexing
4 files changed, 231 insertions, 145 deletions
diff --git a/server/sonar-web/src/main/js/app/utils/startReactApp.tsx b/server/sonar-web/src/main/js/app/utils/startReactApp.tsx index 6bf4a7bacbc..041b1707fa4 100644 --- a/server/sonar-web/src/main/js/app/utils/startReactApp.tsx +++ b/server/sonar-web/src/main/js/app/utils/startReactApp.tsx @@ -287,9 +287,9 @@ export default function startReactApp( <IndexRoute component={lazyLoadComponent(() => import('../components/Landing'))} /> - <RouteWithChildRoutes path="about" childRoutes={aboutRoutes} /> <Route component={GlobalContainer}> + <RouteWithChildRoutes path="about" childRoutes={aboutRoutes} /> <RouteWithChildRoutes path="account" childRoutes={accountRoutes} /> <RouteWithChildRoutes path="coding_rules" childRoutes={codingRulesRoutes} /> <RouteWithChildRoutes path="documentation" childRoutes={documentationRoutes} /> diff --git a/server/sonar-web/src/main/js/apps/about/components/AboutApp.tsx b/server/sonar-web/src/main/js/apps/about/components/AboutApp.tsx index 6e1b637b652..b7d899a1f0f 100644 --- a/server/sonar-web/src/main/js/apps/about/components/AboutApp.tsx +++ b/server/sonar-web/src/main/js/apps/about/components/AboutApp.tsx @@ -28,7 +28,9 @@ import { addWhitePageClass, removeWhitePageClass } from 'sonar-ui-common/helpers import { searchProjects } from '../../../api/components'; import { getFacet } from '../../../api/issues'; import A11ySkipTarget from '../../../app/components/a11y/A11ySkipTarget'; -import GlobalContainer from '../../../app/components/GlobalContainer'; +import withIndexationContext, { + WithIndexationContextProps +} from '../../../components/hoc/withIndexationContext'; import { getAppState, getCurrentUser, @@ -47,7 +49,7 @@ import AboutScanners from './AboutScanners'; import AboutStandards from './AboutStandards'; import EntryIssueTypes from './EntryIssueTypes'; -interface Props { +interface Props extends WithIndexationContextProps { currentUser: T.CurrentUser; customText?: string; fetchAboutPageSettings: () => Promise<void>; @@ -94,7 +96,9 @@ export class AboutApp extends React.PureComponent<Props, State> { loadData() { Promise.all([ this.loadProjects(), - this.loadIssues().catch(() => undefined), + this.props.indexationContext.status.isCompleted + ? this.loadIssues().catch(() => undefined) + : Promise.resolve(undefined), this.loadCustomText() ]).then( responses => { @@ -126,69 +130,67 @@ export class AboutApp extends React.PureComponent<Props, State> { } return ( - <GlobalContainer location={this.props.location}> - <div className="page page-limited about-page" id="about-page"> - <A11ySkipTarget anchor="about_main" /> - - <div className="about-page-entry"> - <div className="about-page-intro"> - <h1 className="big-spacer-bottom">{translate('layout.sonar.slogan')}</h1> - {!this.props.currentUser.isLoggedIn && ( - <Link className="button button-active big-spacer-right" to="/sessions/new"> - {translate('layout.login')} - </Link> - )} - <Link className="button" to="/documentation"> - {translate('about_page.read_documentation')} + <div className="page page-limited about-page" id="about-page"> + <A11ySkipTarget anchor="about_main" /> + + <div className="about-page-entry"> + <div className="about-page-intro"> + <h1 className="big-spacer-bottom">{translate('layout.sonar.slogan')}</h1> + {!this.props.currentUser.isLoggedIn && ( + <Link className="button button-active big-spacer-right" to="/sessions/new"> + {translate('layout.login')} </Link> - </div> - - <div className="about-page-instance"> - <AboutProjects count={projectsCount} loading={loading} /> - {issueTypes && ( - <EntryIssueTypes - bugs={bugs} - codeSmells={codeSmells} - loading={loading} - vulnerabilities={vulnerabilities} - /> - )} - </div> + )} + <Link className="button" to="/documentation"> + {translate('about_page.read_documentation')} + </Link> </div> - {customText && ( - <div - className="about-page-section" - // eslint-disable-next-line react/no-danger - dangerouslySetInnerHTML={{ __html: sanitize(customText) }} - /> - )} - - <AboutLanguages /> - - <AboutQualityModel /> - - <div className="flex-columns"> - <div className="flex-column flex-column-half about-page-group-boxes"> - <AboutCleanCode /> - </div> - <div className="flex-column flex-column-half about-page-group-boxes"> - <AboutLeakPeriod /> - </div> + <div className="about-page-instance"> + <AboutProjects count={projectsCount} loading={loading} /> + {issueTypes && ( + <EntryIssueTypes + bugs={bugs} + codeSmells={codeSmells} + loading={loading} + vulnerabilities={vulnerabilities} + /> + )} </div> + </div> + + {customText && ( + <div + className="about-page-section" + // eslint-disable-next-line react/no-danger + dangerouslySetInnerHTML={{ __html: sanitize(customText) }} + /> + )} + + <AboutLanguages /> - <div className="flex-columns"> - <div className="flex-column flex-column-half about-page-group-boxes"> - <AboutQualityGates /> - </div> - <div className="flex-column flex-column-half about-page-group-boxes"> - <AboutStandards /> - </div> + <AboutQualityModel /> + + <div className="flex-columns"> + <div className="flex-column flex-column-half about-page-group-boxes"> + <AboutCleanCode /> + </div> + <div className="flex-column flex-column-half about-page-group-boxes"> + <AboutLeakPeriod /> </div> + </div> - <AboutScanners /> + <div className="flex-columns"> + <div className="flex-column flex-column-half about-page-group-boxes"> + <AboutQualityGates /> + </div> + <div className="flex-column flex-column-half about-page-group-boxes"> + <AboutStandards /> + </div> </div> - </GlobalContainer> + + <AboutScanners /> + </div> ); } } @@ -204,4 +206,4 @@ const mapStateToProps = (state: Store) => { const mapDispatchToProps = { fetchAboutPageSettings } as any; -export default connect(mapStateToProps, mapDispatchToProps)(AboutApp); +export default withIndexationContext(connect(mapStateToProps, mapDispatchToProps)(AboutApp)); diff --git a/server/sonar-web/src/main/js/apps/about/components/__tests__/AboutApp-test.tsx b/server/sonar-web/src/main/js/apps/about/components/__tests__/AboutApp-test.tsx index 760f864f08f..a562dc129d4 100644 --- a/server/sonar-web/src/main/js/apps/about/components/__tests__/AboutApp-test.tsx +++ b/server/sonar-web/src/main/js/apps/about/components/__tests__/AboutApp-test.tsx @@ -65,6 +65,14 @@ it('should render correctly', async () => { wrapper.unmount(); expect(removeWhitePageClass).toBeCalled(); + + expect( + shallowRender({ + indexationContext: { + status: { isCompleted: false, percentCompleted: 10, hasFailures: false } + } + }) + ).toMatchSnapshot('when indexation not complete'); }); it('should load issues, projects, and custom text upon shallowing', () => { @@ -92,6 +100,9 @@ function shallowRender(props: Partial<AboutApp['props']> = {}) { customText="Lorem ipsum" fetchAboutPageSettings={jest.fn().mockResolvedValue('')} location={mockLocation()} + indexationContext={{ + status: { isCompleted: true, percentCompleted: 100, hasFailures: false } + }} {...props} /> ); diff --git a/server/sonar-web/src/main/js/apps/about/components/__tests__/__snapshots__/AboutApp-test.tsx.snap b/server/sonar-web/src/main/js/apps/about/components/__tests__/__snapshots__/AboutApp-test.tsx.snap index 4ca36d39504..881203c89cd 100644 --- a/server/sonar-web/src/main/js/apps/about/components/__tests__/__snapshots__/AboutApp-test.tsx.snap +++ b/server/sonar-web/src/main/js/apps/about/components/__tests__/__snapshots__/AboutApp-test.tsx.snap @@ -1,108 +1,181 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`should render correctly 1`] = ` -<GlobalContainer - location={ - Object { - "action": "PUSH", - "hash": "", - "key": "key", - "pathname": "/path", - "query": Object {}, - "search": "", - "state": Object {}, - } - } +<div + className="page page-limited about-page" + id="about-page" > + <A11ySkipTarget + anchor="about_main" + /> <div - className="page page-limited about-page" - id="about-page" + className="about-page-entry" > - <A11ySkipTarget - anchor="about_main" - /> <div - className="about-page-entry" + className="about-page-intro" > - <div - className="about-page-intro" + <h1 + className="big-spacer-bottom" + > + layout.sonar.slogan + </h1> + <Link + className="button button-active big-spacer-right" + onlyActiveOnIndex={false} + style={Object {}} + to="/sessions/new" > - <h1 - className="big-spacer-bottom" - > - layout.sonar.slogan - </h1> - <Link - className="button button-active big-spacer-right" - onlyActiveOnIndex={false} - style={Object {}} - to="/sessions/new" - > - layout.login - </Link> - <Link - className="button" - onlyActiveOnIndex={false} - style={Object {}} - to="/documentation" - > - about_page.read_documentation - </Link> - </div> - <div - className="about-page-instance" + layout.login + </Link> + <Link + className="button" + onlyActiveOnIndex={false} + style={Object {}} + to="/documentation" > - <AboutProjects - count={5} - loading={false} - /> - <EntryIssueTypes - bugs={10} - codeSmells={5} - loading={false} - vulnerabilities={0} - /> - </div> + about_page.read_documentation + </Link> </div> <div - className="about-page-section" - dangerouslySetInnerHTML={ - Object { - "__html": "Lorem ipsum", - } + className="about-page-instance" + > + <AboutProjects + count={5} + loading={false} + /> + <EntryIssueTypes + bugs={10} + codeSmells={5} + loading={false} + vulnerabilities={0} + /> + </div> + </div> + <div + className="about-page-section" + dangerouslySetInnerHTML={ + Object { + "__html": "Lorem ipsum", } - /> - <AboutLanguages /> - <AboutQualityModel /> + } + /> + <AboutLanguages /> + <AboutQualityModel /> + <div + className="flex-columns" + > <div - className="flex-columns" + className="flex-column flex-column-half about-page-group-boxes" > - <div - className="flex-column flex-column-half about-page-group-boxes" - > - <AboutCleanCode /> - </div> - <div - className="flex-column flex-column-half about-page-group-boxes" - > - <AboutLeakPeriod /> - </div> + <AboutCleanCode /> + </div> + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutLeakPeriod /> </div> + </div> + <div + className="flex-columns" + > + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutQualityGates /> + </div> + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutStandards /> + </div> + </div> + <AboutScanners /> +</div> +`; + +exports[`should render correctly: when indexation not complete 1`] = ` +<div + className="page page-limited about-page" + id="about-page" +> + <A11ySkipTarget + anchor="about_main" + /> + <div + className="about-page-entry" + > <div - className="flex-columns" + className="about-page-intro" > - <div - className="flex-column flex-column-half about-page-group-boxes" + <h1 + className="big-spacer-bottom" > - <AboutQualityGates /> - </div> - <div - className="flex-column flex-column-half about-page-group-boxes" + layout.sonar.slogan + </h1> + <Link + className="button button-active big-spacer-right" + onlyActiveOnIndex={false} + style={Object {}} + to="/sessions/new" > - <AboutStandards /> - </div> + layout.login + </Link> + <Link + className="button" + onlyActiveOnIndex={false} + style={Object {}} + to="/documentation" + > + about_page.read_documentation + </Link> + </div> + <div + className="about-page-instance" + > + <AboutProjects + count={0} + loading={true} + /> + </div> + </div> + <div + className="about-page-section" + dangerouslySetInnerHTML={ + Object { + "__html": "Lorem ipsum", + } + } + /> + <AboutLanguages /> + <AboutQualityModel /> + <div + className="flex-columns" + > + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutCleanCode /> + </div> + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutLeakPeriod /> + </div> + </div> + <div + className="flex-columns" + > + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutQualityGates /> + </div> + <div + className="flex-column flex-column-half about-page-group-boxes" + > + <AboutStandards /> </div> - <AboutScanners /> </div> -</GlobalContainer> + <AboutScanners /> +</div> `; |