diff options
author | michaelbirnstiehl <michael.birnstiehl@sonarsource.com> | 2020-05-20 07:43:16 -0500 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2020-06-11 20:04:56 +0000 |
commit | 23c1490a10795c082bdb1f91e125498c0a8f139e (patch) | |
tree | 1b15e6cf051e1fad5e56c4b5ff266679e35f9f81 /server | |
parent | 31f4bf37272da9cbb703c5c104ad5412239fe39b (diff) | |
download | sonarqube-23c1490a10795c082bdb1f91e125498c0a8f139e.tar.gz sonarqube-23c1490a10795c082bdb1f91e125498c0a8f139e.zip |
SONAR-13409 Update New Code Period Wording
Diffstat (limited to 'server')
9 files changed, 53 insertions, 48 deletions
diff --git a/server/sonar-docs/src/EmbedDocsSuggestions.json b/server/sonar-docs/src/EmbedDocsSuggestions.json index a1f10d7b4cd..e1b09cb379b 100644 --- a/server/sonar-docs/src/EmbedDocsSuggestions.json +++ b/server/sonar-docs/src/EmbedDocsSuggestions.json @@ -111,7 +111,7 @@ "project_baseline": [ { "link": "/documentation/project-administration/new-code-period/", - "text": "New Code Period" + "text": "Defining New Code" } ], "project_quality_gate": [ diff --git a/server/sonar-docs/src/pages/branches/overview.md b/server/sonar-docs/src/pages/branches/overview.md index 85f7304b3f6..63f3e164938 100644 --- a/server/sonar-docs/src/pages/branches/overview.md +++ b/server/sonar-docs/src/pages/branches/overview.md @@ -17,9 +17,9 @@ This is the default branch and typically corresponds to what's being developed f Branch settings and quality profiles are the same as those set for the master branch, and by design, it's not possible to configure other values. The New Code Period is the only exception to this as it can be set on a branch-by-branch basis. -### New Code Period +### New Code -You can set a New Code Period for each branch. This is especially helpful if you are likely to develop and release multiple versions from the branch. See the [New Code Period](/project-administration/new-code-period/) documentation for more information on setting a New Code Period. +You can set a New Code definition for each branch. This is especially helpful if you are likely to develop and release multiple versions from the branch. See the [Defining New Code](/project-administration/new-code-period/) documentation for more information. ### Quality Gate diff --git a/server/sonar-docs/src/pages/extend/adding-scm.md b/server/sonar-docs/src/pages/extend/adding-scm.md index 4004ba2f567..970d7ebae8b 100644 --- a/server/sonar-docs/src/pages/extend/adding-scm.md +++ b/server/sonar-docs/src/pages/extend/adding-scm.md @@ -5,7 +5,7 @@ url: /extend/adding-scm/ SonarQube Scanner uses information from the project's SCM, if available, to: * Assign a new issue to the person who introduced it. The last committer on the related line of code is considered to be the author of the issue. -* Estimate the coverage on new code, including added and changed code, on the new code period. +* Estimate the coverage on New Code, including added and changed code since in your New Code. * Display the most recent commit on each line the code viewer. ![Commit info is available from the margin of the code viewer](/images/commit-info-in-code-viewer.png) diff --git a/server/sonar-docs/src/pages/project-administration/new-code-period.md b/server/sonar-docs/src/pages/project-administration/new-code-period.md index 8cd9090e407..904cfc918f3 100644 --- a/server/sonar-docs/src/pages/project-administration/new-code-period.md +++ b/server/sonar-docs/src/pages/project-administration/new-code-period.md @@ -1,36 +1,41 @@ --- -title: Setting Your New Code Period +title: Defining New Code url: /project-administration/new-code-period/ --- -By focusing on code that's been added or changed in your New Code Period, you can set consistent quality requirements and expectations on all new code. With this focus, your new code will be issue-free and you'll clean up the code you encounter along the way. For more information on the New Code Period, see the [Clean as You Code](/user-guide/clean-as-you-code/) page. -You can set a New Code Period at the global, project, or branch level. +Defining what is considered New Code is an important part of SonarQube's Clean as You Code approach to code quality and safety. By focusing on code that's been added or changed since your New Code definition, you can set consistent quality requirements and expectations. Your New Code will be issue free and you'll clean up the code you encounter along the way. For more information on New Code and why it's important, check out [Clean as You Code](/user-guide/clean-as-you-code/). -## Setting a global New Code Period -Your global New Code Period will be the default for your projects. You can set the global New Code Period at [**Administration > Configuration > General Settings > New Code Period**](/#sonarqube-admin#/admin/settings?category=new_code_period/). +## Setting your New Code definition -You can set the global New Code Period to the following: +You can define New Code at the global, project, or branch level. -* **Previous Version** – The New Code Period defaults to **Previous version** which shows any changes made in your project's current version. This works well for projects with regular versions or releases. -* **Number of days** – You can specify a number of days for a floating New Code Period. For example, setting **Number of Days** to 30 creates a floating New Code Period beginning 30 days from the current date. +- **Global level** + You can set a global New Code definition at [**Administration > Configuration > General Settings > New Code**](/#sonarqube-admin#/admin/settings?category=new_code_period/). What you define as New Code at the global level will be the default for your projects. -## Setting a project-level New Code Period -You can override the global New Code Period by setting a project-level New Code Period from the project page at **Project Settings > New Code Period**. Starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html), this will be the default New Code Period for all of the project's branches. +- **Project level** + You can set a New Code definition for your project at **Project Settings > New Code**. What you define as New Code at the project level will be the default for the project's branches if you're using an edition that supports multiple branches (starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html)). -You can set a project's New Code Period to the following: +- **Branch level** + You can define New Code for each branch from the **Actions** column of the branches table on the project's **New Code** settings page if you're using an edition that supports multiple branches (starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html)). -* **Previous Version** – Set the New Code Period to show any changes made in your project's current version. This works well for projects with regular versions or releases. -* **Number of days** – Specify a number of days for a floating New Code Period. For example, setting **Number of Days** to 30 creates a floating New Code Period beginning 30 days from the current date. -* **Specific analysis** – Choose a previous analysis as your New Code Period. The New Code Period will show any changes made since that analysis. +## New Code definitions - **Note:** For Community Edition, you can set the New Code Period to a specific past analysis at the project-level because Community Edition doesn't support multiple branches. Starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html), you can set the New Code Period to a specific analysis at the branch level. Each branch can be set to one of the branch's specific past analyses. See the following section for information on setting a branch-level New Code Period. +You can define New Code as changes from a previous version, a specific analysis, a reference branch, or within a specific period (number of days): -### Setting a branch-level New Code Period -_Branch analysis is available starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html)._ -For projects with multiple branches, you can set a New Code Period for each branch from the **Actions** column of the branches table on the project's **New Code Period** settings page. +- **Previous Version** – Define New Code as any changes made in your project's current version. This works well for projects with regular versions or releases. -You can set a branch's New Code Period to the following: + Available at the global, project, and branch level. -* **Previous Version** – Set the New Code Period to show any changes made in your branch's current version. This works well for branches with regular versions. -* **Number of days** – Specify a number of days for a floating New Code Period. For example, setting **Number of Days** to 30 creates a floating New Code Period beginning 30 days from the current date. -* **Specific analysis** – Choose a specific past analysis of the branch as the New Code Period. The New Code Period will show any changes made since that analysis. +- **Specific analysis** – Choose a previous analysis as your New Code definition. Any changes made since that analysis are considered New Code. + + Available at the branch level starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html) and the project level for community edition. + +[[info]] +| For Community Edition, past analysis is available at the project-level because Community Edition doesn't support multiple branches. Starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html), you can do this at the branch level, and each branch can be set to one of the branch's specific past analyses. + +- **Reference Branch** – Choose a specific branch to define your New Code. Any changes made from your reference branch are considered New Code. + + Available at the project and branch level. + +- **Number of days** – Specify a number of days for a floating New Code period. For example, setting **Number of Days** to 30 creates a floating New Code period beginning 30 days from the current date. + Available at the global, project, and branch level. diff --git a/server/sonar-docs/src/pages/user-guide/clean-as-you-code.md b/server/sonar-docs/src/pages/user-guide/clean-as-you-code.md index 6b0e617ed68..f5060e7bd8e 100644 --- a/server/sonar-docs/src/pages/user-guide/clean-as-you-code.md +++ b/server/sonar-docs/src/pages/user-guide/clean-as-you-code.md @@ -9,11 +9,11 @@ Clean as You Code is an approach to Code Quality that eliminates a lot of the ch ## Focus on New Code -With Clean as You Code, your focus is always on New Code (code that has been added or changed in your New Code Period) and making sure the code you write today is clean and safe. +With Clean as You Code, your focus is always on New Code (code that has been added or changed according to your New Code definition) and making sure the code you write today is clean and safe. -The New Code Period can be set at different levels (global, project, and starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html) at the branch level). Depending on the level at which your New Code Period is set, you can change the starting point of your New Code Period to fit your situation. +The New Code definition can be set at different levels (global, project, and starting in [Developer Edition](https://redirect.sonarsource.com/editions/developer.html) at the branch level). Depending on the level at which your New Code definition is set, you can change the starting point to fit your situation. -For more information on the New Code Period and setting it, check out [Setting Your New Code Period](/project-administration/new-code-period/). +For more information on setting your New Code definition, check out [Defining New Code](/project-administration/new-code-period/). ## Personal Responsibility @@ -25,13 +25,13 @@ For more information on issues and how they are assigned, check out the [Issues] Your Quality Gate is a set of conditions that tells you whether or not your project is ready for release. With the Clean as You Code approach, your Quality Gate should: -* **Focus on New Code metrics** – When your Quality Gate is set to focus on New Code metrics (like the built-in Sonar way Quality Gate), new features will be delivered cleanly. As long as your Quality gate is green, your releases will continue to improve. -* **Set and enforce high standards** – When standards are set and enforced on New Code, you aren't worried about having to meet those standards in old code and having to clean up someone else's code. You can take pride in meeting high standards on _your_ code. If a project doesn't meet these high standards, it won't pass the Quality Gate, and it's obviously not ready to be released. +- **Focus on New Code metrics** – When your Quality Gate is set to focus on New Code metrics (like the built-in Sonar way Quality Gate), new features will be delivered cleanly. As long as your Quality gate is green, your releases will continue to improve. +- **Set and enforce high standards** – When standards are set and enforced on New Code, you aren't worried about having to meet those standards in old code and having to clean up someone else's code. You can take pride in meeting high standards on _your_ code. If a project doesn't meet these high standards, it won't pass the Quality Gate, and it's obviously not ready to be released. For more information on Quality Gates and making sure your Quality Gate is enforcing your standards, check out the [Quality Gates](/user-guide/quality-gates/) documentation. ## Pull Request Analysis -You can use Pull Request analysis and decoration to make sure your code is meeting your standards before you merge. Pull Request analysis lets you see your Pull Request's Quality Gate in the SonarQube UI. You can then decorate your Pull Requests with SonarQube issues directly in your ALM's interface. +You can use Pull Request analysis and decoration to make sure your code is meeting your standards before you merge. Pull Request analysis lets you see your Pull Request's Quality Gate in the SonarQube UI. You can then decorate your Pull Requests with SonarQube issues directly in your ALM's interface. -For more information on setting up Pull Request analysis and decoration, see the [Pull Request](/analysis/pull-request/) documentation.
\ No newline at end of file +For more information on setting up Pull Request analysis and decoration, see the [Pull Request](/analysis/pull-request/) documentation. diff --git a/server/sonar-docs/src/pages/user-guide/concepts.md b/server/sonar-docs/src/pages/user-guide/concepts.md index 0aa26242393..a04d5735b13 100644 --- a/server/sonar-docs/src/pages/user-guide/concepts.md +++ b/server/sonar-docs/src/pages/user-guide/concepts.md @@ -25,7 +25,7 @@ See also the [SonarQube Platform Overview](/architecture/architecture-integratio | Issue | When a piece of code does not comply with a rule, an issue is logged on the **snapshot**. An issue can be logged on a source file or a unit test file. There are 3 types of issue: **Bugs**, **Code Smells** and **Vulnerabilities** | | Measure | The value of a **metric** for a given file or project at a given time. For example, 125 lines of code on class MyClass or density of duplicated lines of 30.5% on project myProject | | Metric | A type of measurement. Metrics can have varying values, or **measures**, over time. Examples: number of lines of code, complexity, etc. A metric may be either _qualitative_ (gives a quality indication on the component, E.G. density of duplicated lines, line coverage by tests, etc.) or _quantitative_ (does not give a quality indication on the component, E.G. number of lines of code, complexity, etc.) | -| New Code Period | The period for which you're keeping a close watch on the introduction of new problems in the code. Ideally this is since the `previous_version`, but if you don't use a Maven-like versioning scheme you may need to set a relatively arbitrary time period such as 21 days or since a specific date. | +| New Code definition | A changeset or period that you're keeping a close watch on for the introduction of new problems in the code. Ideally this is since the `previous_version`, but if you don't use a Maven-like versioning scheme you may need to set a time period such as 21 days, since a specific anaylsis, or use a reference branch. | | Quality Profile | A set of **rules**. Each **snapshot** is based on a single quality profile. See also [Quality Profiles](/instance-administration/quality-profiles/) | | Rule | A coding standard or practice which should be followed. Not complying with coding rules leads to **Bugs**, **Vulnerabilities**, **Security Hotspots**, and **Code Smells**. Rules can check quality on code files or unit tests. | | Remediation Cost | The estimated time required to fix Vulnerability and Reliability Issues. | diff --git a/server/sonar-docs/src/pages/user-guide/issues.md b/server/sonar-docs/src/pages/user-guide/issues.md index b268ddd3ec3..87da00d6927 100644 --- a/server/sonar-docs/src/pages/user-guide/issues.md +++ b/server/sonar-docs/src/pages/user-guide/issues.md @@ -87,7 +87,7 @@ Once an issue has been determied to be "new", as described above, the next quest * When the analyzer has just been upgraded (because rule implementations could be smarter now) * When the rule is external -As a consequence, it is possible that backdating will keep newly raised issues out of the New Code Period. +As a consequence, it is possible that backdating will keep newly raised issues out of New Code. ## Automatic Issue Assignment diff --git a/server/sonar-docs/src/pages/user-guide/metric-definitions.md b/server/sonar-docs/src/pages/user-guide/metric-definitions.md index eb3fbc3d027..35fe7328d6b 100644 --- a/server/sonar-docs/src/pages/user-guide/metric-definitions.md +++ b/server/sonar-docs/src/pages/user-guide/metric-definitions.md @@ -55,10 +55,10 @@ Number of lines involved in duplications. --- ## Issues **New issues** (`new_violations`) -Number of issues raised for the first time in the New Code period. +Number of issues raised for the first time on New Code. **New xxx issues** (`new_xxx_violations`) -Number of issues of the specified severity raised for the first time in the New Code period, where xxx is one of: `blocker`, `critical`, `major`, `minor`, `info`. +Number of issues of the specified severity raised for the first time on New Code, where xxx is one of: `blocker`, `critical`, `major`, `minor`, `info`. **Issues** (`violations`) Total count of issues in all states. @@ -84,7 +84,7 @@ Total count of issues in the Reopened state Total count of Code Smell issues. **New Code Smells** (`new_code_smells`) -Total count of Code Smell issues raised for the first time in the New Code period. +Total count of Code Smell issues raised for the first time on New Code. **Maintainability Rating** (`sqale_rating`) (Formerly the SQALE rating.) @@ -104,7 +104,7 @@ The Maintainability Rating scale can be alternately stated by saying that if the Effort to fix all Code Smells. The measure is stored in minutes in the database. An 8-hour day is assumed when values are shown in days. **Technical Debt on New Code** (`new_technical_debt`) -Effort to fix all Code Smells raised for the first time in the New Code period. +Effort to fix all Code Smells raised for the first time on New Code. **Technical Debt Ratio** (`sqale_debt_ratio`) Ratio between the cost to develop the software and the cost to fix it. The Technical Debt Ratio formula is: @@ -114,7 +114,7 @@ Which can be restated as: The value of the cost to develop a line of code is 0.06 days. **Technical Debt Ratio on New Code** (`new_sqale_debt_ratio`) -Ratio between the cost to develop the code changed in the New Code period and the cost of the issues linked to it. +Ratio between the cost to develop the code changed on New Code and the cost of the issues linked to it. --- ## Quality Gates @@ -144,7 +144,7 @@ E = at least 1 Blocker Bug Effort to fix all bug issues. The measure is stored in minutes in the DB. An 8-hour day is assumed when values are shown in days. **Reliability remediation effort on new code** (`new_reliability_remediation_effort`) -Same as _Reliability remediation effort_ but on the code changed in the New Code period. +Same as _Reliability remediation effort_ but on the code changed on New Code. --- ## Security @@ -165,13 +165,13 @@ E = at least 1 Blocker Vulnerability Effort to fix all vulnerability issues. The measure is stored in minutes in the DB. An 8-hour day is assumed when values are shown in days. **Security remediation effort on new code** (`new_security_remediation_effort`) -Same as _Security remediation effort_ but on the code changed in the New Code period. +Same as _Security remediation effort_ but on the code changed on New Code. **Security Hotspots** (`security_hotspots`) Number of Security Hotspots **Security Hotspots on new code** (`new_security_hotspots`) -Number of new Security Hotspots in the New Code Period. +Number of new Security Hotspots on New Code. **Security Review Rating** (`security_review_rating`) @@ -185,7 +185,7 @@ E = < 30% **Security Review Rating on new code** (`new_security_review_rating`) -Security Review Rating for the New Code Period. +Security Review Rating for New Code. **Security Hotspots Reviewed** (`security_hotspots_reviewed`) @@ -196,7 +196,7 @@ Ratio Formula: **New Security Hotspots Reviewed** -Percentage of Reviewed Security Hotspots (Fixed or Safe) for the New Code Period. +Percentage of Reviewed Security Hotspots (Fixed or Safe) on New Code. --- ## Size diff --git a/server/sonar-docs/src/pages/user-guide/project-page.md b/server/sonar-docs/src/pages/user-guide/project-page.md index 24d2149b421..a083a91f3ac 100644 --- a/server/sonar-docs/src/pages/user-guide/project-page.md +++ b/server/sonar-docs/src/pages/user-guide/project-page.md @@ -7,7 +7,7 @@ url: /user-guide/project-page/ The Project Hompepage is the entry point of any project showing: * the releasability status of the project * the current state of its quality -* the quality of what has been produced since the beginning of its [New Code Period](/user-guide/clean-as-you-code/). +* the quality of what has been produced since the start of the [New Code](/user-guide/clean-as-you-code/). The Project Page answers two questions: @@ -21,7 +21,7 @@ Since the [Quality Gate](/user-guide/quality-gates/) is your most powerful tool If not, details and drill-downs are immediately available to quickly identify what went wrong, with a section for each error condition showing what the current project value is and what it should be. As usual, you'll be able to click through on current values to get to drilldowns. ## What should I fix first? -Because the best way to improve a project's quality is to catch and fix new problems before they become entrenched, the first view of a project is centered around the New Code Period, which is highlighted in yellow on the right of the project homepage. The project space page shows a high-level summary of critical metrics, both current values and their New Code Period values. +Because the best way to improve a project's quality is to catch and fix new problems before they become entrenched, the first view of a project is centered around New Code, which is highlighted in yellow on the right of the project homepage. The project space page shows a high-level summary of critical metrics, both current values and their New Code values. Just below the Quality Gate information, you have the numbers of old and new Issues in the Reliability and Security domains and then the Maintainability domain. Clicking on any figure on the page will take you to a detailed view, either in the Measures Page or the Issues Page. @@ -37,7 +37,7 @@ The project-level **Measures** menu item takes you to a dedicated sub-space wher ### How can I see all the issues in a project? The project-level **Issues** menu item takes you to a project-specific Issues page, where you can perform all the same actions you can at the higher level. -On this page, you can easily narrow the list to the New Issues introduced during the New Code Period, by selecting `New Code` in **Creation Date** facet. +On this page, you can easily narrow the list to the New Issues as set by your New Code definition, by selecting `New Code` in **Creation Date** facet. ### How can I see the project structure and code? The project-level **Code** menu item takes you to an outline of your project structure. Drill down to see files in a directory, and choose a file to see its code. |