SQ Official Doc Link: https://docs.sonarqube.org/display/SONAR/Concepts
Table of Contents
아키텍처(Architecture)
Concept | Definition | Related Topics |
---|---|---|
Analyzer | 소스 코드를 분석하여 스냅샷(snapshot)을 계산하는 클라이언트 어플리케이션. | SonarQube 설치 및 업그레이드 참조 |
Database | 다음 내용을 저장합니다:
| SonarQube 설치 및 업그레이드 참조 |
Server | 스냅샷(snapshot) 데이터를 브라우즈하고, 환경 설정값을 변경하기 위해 사용하는 웹 인터페이스 | SonarQube 설치 및 업그레이드 참조 |
품질(Quality)
Concept | Definition | Related Topics |
---|---|---|
Bug | 코드의 잘못된 지점을 표시하는 이슈. An issue that represents something wrong in the code. If this has not broken yet, it will, and probably at the worst possible moment. This needs to be fixed. Yesterday. | |
Check | 체크(Check) = 코딩 규칙(Coding Rule) | |
Code Smell | A maintainability-related issue in the code. Leaving it as-is means that at best maintainers will have a harder time than they should making changes to the code. At worst, they'll be so confused by the state of the code that they'll introduce additional errors as they make changes. | |
Coding Rule | A good coding practice. Not complying to coding rules leads to quality flaws and creation of issues in SonarQube. Coding rules can check quality on files, unit tests or packages. | See Viewing Unit Tests > Issues Perspective |
Component | A piece of software (project, module/package, file) or a view or a developer. | |
Cost | See Remediation Cost | |
Debt | See Technical Debt | |
Issue | When a component does not comply with a coding rule, an issue is logged (was violation prior to SonarQube 3.6) on the snapshot. An issue can be logged on a source file or a unit test file. There are 3 types of issue:
| |
Leak Period | The period for which you're keeping a close watch on the introduction of new problems in the code. Typically 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. | |
Measure | The value of a metric for a given component at a given time. Examples:
| |
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:
| See detailed documentation on metrics. |
Non-functional requirement | Non-functional requirement = coding rule | |
Quality Profile | A set of coding rules. Each snapshot is based on a single quality profile. | See Quality Profiles. |
Remediation Cost | The estimated time required to fix Vulnerability and Reliability Issues. | |
Snapshot | A set of measures and issues on a given component at a given time. A snapshot is generated for each analysis. | |
Technical Debt | The estimated time required to fix all Maintainability Issues / code smells | |
Vulnerability | A security-related issue which represents a potential backdoor for attackers. See also Security-related rules. |