Sonar Abacus Plugin
This plug-in estimates the complexity of each file in order to help you use the "abacus methodology" ("méthode des abaques" in French).
This is a methodology widely used in France to estimate the effort of changes. Customers and providers agree on the abacus at the beginning of the maintenance process.
Example of Abacus
|Complexity of the Change|
Values are in man days.
- According to this abacus, the effort of a complex change in a simple file would be estimated to 0.8 man days.
- According to this abacus, the effort of a very complex change in a complex file would be estimated to 5.0 man days.
The complexity of a file is computed according to its cyclomatic complexity.
The default values are (estimation for a Java project):
|Abacus Complexity||Cyclomatic Complexity|
|Medium||20 < X <= 50|
|Complex||50 < X <= 100|
|Very complex||> 100|
See the Configuration section to set your own thresholds.
At module or project level, a widget is available to display the average abacus complexity and the abacus complexity distribution.
The abacus complexity distribution can be displayed either in number of files or percentage.
See screenshots below.
Why using this plug-in?
- To help you estimate your effort of change more accurately and in a quicker way.
- To help clients and subcontractors argue less about the effort of change as they will have a factual way to estimate the complexity of each file.
- Copy the jar into /extensions/plugins/ directory
- Restart Sonar Web server
To set your own thresholds to compute the abacus complexity.
Coma-separated list of colors (hexadecimal format) for the pie chart display.
Make sure to have at least as many colors as levels of complexity in your abacus.
Default value is green, yellow, orange, red and black.
To set the default display: number of files distribution or percentage distribution.
- Drill-down from the average abacus complexity of a module/project does not work due to the following issue in Sonar Core: SONAR-3233.
- Differential views are not implemented.
- Compatibility with VIEWS: as each project can define its own abacus, this plug-in does not compute the abacus complexity and distribution for a view.