aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/about/sonarcloud/BranchAnalysis.tsx
blob: d5bcb2932a837486a0fdd92a5ca29d4316608be3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
 * SonarQube
 * Copyright (C) 2009-2018 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 * as React from 'react';
import Helmet from 'react-helmet';
import SQPageContainer from './components/SQPageContainer';
import SQStartUsing from './components/SQStartUsing';
import SQTopNav from './components/SQTopNav';
import { isLoggedIn } from '../../../helpers/users';
import { getBaseUrl } from '../../../helpers/urls';
import './style.css';

export default function BranchAnalysis() {
  return (
    <SQPageContainer>
      {({ currentUser }) => (
        <div className="page page-limited sc-page">
          <Helmet title="Pull requests analysis in Github, BitBucket and Azure DevOps | SonarCloud">
            <meta
              content="SonarCloud automatically analyzes branches and decorates pull requests with Github, BitBucket and Azure DevOps."
              name="description"
            />
          </Helmet>
          <SQTopNav />

          <div className="sc-child-header">
            <img alt="" height="34" src={`${getBaseUrl()}/images/sonarcloud/branch-analysis.svg`} />
            <h1 className="sc-child-title">
              Branch analysis & <br />
              pull request decoration
            </h1>
            <p className="sc-child-lead">
              SonarCloud comes with a built-in feature to automatically analyze <br />
              project branches and pull requests as soon as they get created.
            </p>
          </div>

          <ul className="sc-features-list sc-branch-features-list">
            <li className="sc-feature sc-branch-feature">
              <img
                alt=""
                className="sc-branch-feature-right"
                height="270"
                src={`${getBaseUrl()}/images/sonarcloud/branch-01.png`}
                srcSet={`${getBaseUrl()}/images/sonarcloud/branch-01.png 1x, ${getBaseUrl()}/images/sonarcloud/branch-01@2x.png 2x`}
                width="463"
              />
              <div>
                <h3 className="sc-feature-title">Analyze branches and pull requests</h3>
                <p className="sc-feature-description">
                  For all project branches (main, maintenance, version, feature, etc.), you get the
                  full experience in the project space, with a specific focus on that branch.
                </p>
                <p className="sc-feature-description">
                  When analyzing pull requests (PRs), a Quality Gate will be generated along with
                  the list of issues created in the PR.
                </p>
                <p className="sc-feature-description">
                  To save time and insure consistency, the analysis configuration is reused across
                  all branches of a project.
                </p>
              </div>
            </li>
            <li className="sc-feature sc-branch-feature">
              <div>
                <h3 className="sc-feature-title">Decorate PRs on Azure DevOps and GitHub</h3>
                <p className="sc-feature-description">
                  Pull requests get decorated directly on Azure DevOps and GitHub. The result of the
                  PR analysis is available directly in the pull request itself, complementing nicely
                  manual reviews made by peers and enabling to make a more educated decision for
                  merging.
                </p>
              </div>
              <img
                alt=""
                className="sc-branch-feature-left"
                height="390"
                src={`${getBaseUrl()}/images/sonarcloud/branch-02.png`}
                srcSet={`${getBaseUrl()}/images/sonarcloud/branch-02.png 1x, ${getBaseUrl()}/images/sonarcloud/branch-02@2x.png 2x`}
                width="471"
              />
            </li>
            <li className="sc-feature sc-branch-feature">
              <img
                alt=""
                className="sc-branch-feature-right"
                height="169"
                src={`${getBaseUrl()}/images/sonarcloud/branch-03.png`}
                srcSet={`${getBaseUrl()}/images/sonarcloud/branch-03.png 1x, ${getBaseUrl()}/images/sonarcloud/branch-03@2x.png 2x`}
                width="460"
              />
              <div>
                <h3 className="sc-feature-title">Add a check in GitHub</h3>
                <p className="sc-feature-description">
                  Finally, a check can be added to the PR to provide the Quality Gate status of the
                  PR, check that can optionally block the merge.
                </p>
              </div>
            </li>
          </ul>

          <div className="sc-branch-bottom">
            There is no longer an excuse for pushing issues to the master.
          </div>

          {!isLoggedIn(currentUser) && <SQStartUsing />}
        </div>
      )}
    </SQPageContainer>
  );
}