Static Analysis
🕓 15 minutes
What you’ll learn​
How to thoroughly analyze your code to create a clear and professional application without bugs and security-related issues.
- For example:
- You can detect whether the code contains duplicated blocks or deprecated annotation/methods.
- Your code will be analyzed for OWASP and SANS security standards.
- The static analysis will count the unit tests and tell you the code coverage in your project.
Prerequisites​
Outline​
There are two ways of choosing an application component for static analysis:
-
Go to your application, select the "More" option, and then "Static Analysis".
- Here you will see the complete analysis of the chosen application component.
-
Find the "Quality Management" section and choose the "Static Analysis" option.
- There you will see all the created application components from every existing application.
- You can sort and filter them by different parameters or simply type the needed component name into the search field.
- There you will see all the created application components from every existing application.
data:image/s3,"s3://crabby-images/87aae/87aae92365f8cc84e87a361ea94b3b845788d571" alt="static_analysis"
data:image/s3,"s3://crabby-images/c3697/c36977ea67cfe1e73d3d804e52469e0754e0c52a" alt="static_analysis"
data:image/s3,"s3://crabby-images/ff8a2/ff8a25ad1f0ed862756410e2b70b58699598da10" alt="static_analysis"
data:image/s3,"s3://crabby-images/500d7/500d732008177b0c483e2483ba4f065f7a817ffa" alt="static_analysis"
-
For the static code analysis, CodeNow use the SonarQube tool.
- You can read more about it here: https://www.sonarqube.org/about/
-
In the top right corner, you can see the last build version and time the application was built.
data:image/s3,"s3://crabby-images/10070/10070a4137872d272687795ce1ba82c08a32783e" alt="static_analysis"
- You can also choose the branch that you want to be analyzed.
data:image/s3,"s3://crabby-images/094b2/094b26da66d0f713b5723e417b9224fcd39c932a" alt="static_analysis"
- In the right sidebar, you can see the base information about your component such as the number of lines of code, what languages were used, etc.
data:image/s3,"s3://crabby-images/2f2af/2f2af962efb7ad4b68f5080285f4934aaaa3fcb1" alt="static_analysis"
Overview section​
- In this section you can see the basic information about your component:
- Quality Gate
- It helps you know immediately whether your project is production-ready.
- If the current status is not Passed, it will show you the measures that caused the problem and the values required to pass.
- Bugs
- Shows the number of bugs in the code.
- Vulnerabilities
- Shows the number of security-related issues in the code.
- Code Smells
- A maintainability-related issue in the code.
- Coverage
- Shows the number of unit tests in your project and how the code is covered by them.
- Duplications
- Shows the number of duplicated blocks of code in the project.
- Quality Gate
data:image/s3,"s3://crabby-images/9f97b/9f97bd428e2bc9e4ecb4b44312ded9a396dbf7be" alt="static_analysis"
Issue section​
- In this section, you can see all the open issues in your code.
- You can select them by different parameters such as type, status, creation date, and more.
- You can find all of them in the left sidebar menu.
data:image/s3,"s3://crabby-images/87d75/87d7544d43a08008ebbb0a4c1b9ad7139e00c982" alt="static_analysis"
data:image/s3,"s3://crabby-images/0e854/0e854d091629de02c893e069c6c6c193b40664c3" alt="static_analysis"
Security Reports section​
- This section contains security vulnerabilities in your code.
- You can check them by OWASP Top 10 or SANS Top 25.
data:image/s3,"s3://crabby-images/bb9cd/bb9cdd906594b1258ac856839c4a0f4ca2ac0031" alt="static_analysis"
OWASP Top 10​
- This is a standard awareness document for developers and web application security.
- It represents a broad consensus about the most critical security risks to web applications.
- For more information, see: https://owasp.org/www-project-top-ten/
data:image/s3,"s3://crabby-images/62809/628094d1f8935af88ed1e20686c759181fd9e25d" alt="static_analysis"
SANS Top 25​
- The SANS Top 25 list contains the most dangerous software errors.
- For more information, see: https://www.sans.org/top25-software-errors
data:image/s3,"s3://crabby-images/58bfc/58bfcf35f84612452d2116c679c1d54002b0f3bd" alt="static_analysis"
Measures section​
- This section contains 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.
data:image/s3,"s3://crabby-images/b1397/b13979d5353d3090bc378d1d45f07d6cd523defb" alt="static_analysis"
Code section​
- Here you can find an analysis for every part of your code.
- You can search through the code hierarchy.
- You can search for files and sub-projects using the search field.
data:image/s3,"s3://crabby-images/d12b0/d12b03bab6fcfa1932d1c82a10429a8db9315a7d" alt="static_analysis"
data:image/s3,"s3://crabby-images/6dacc/6daccacbe321fd8ed5f2d17bebe76e498599ffa2" alt="static_analysis"
Activity section​
- The Activity page offers to see the evolution of the project over time (with each new build).
data:image/s3,"s3://crabby-images/f58a8/f58a8850589ba3b3e89d0ce3c003787338250ea8" alt="static_analysis"
- Graphs on the activity page help you understand the evolution of up to three measures of your choice against each other.
- Graph mouseovers show the measure values and events associated with particular analyses.
data:image/s3,"s3://crabby-images/96647/966478b877a5e040e771195b745404f905816c3e" alt="static_analysis"
- You can filter the history by events and set the start and end dates.
data:image/s3,"s3://crabby-images/cbf18/cbf18bb4925e09dcb0013d2b3089f9f2de43215d" alt="static_analysis"
- Choose the type of analysis to see the code and analytics changes related to the specific type on the graph.
data:image/s3,"s3://crabby-images/e6157/e6157be100d6b2f931d560838f52fe04b49317e9" alt="static_analysis"