-
Notifications
You must be signed in to change notification settings - Fork 31
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #11 from MaibornWolff/newsonarqubeapi
Connector to SonarQube Measures-API, Default metrics, Exception handling for sonarimporter
- Loading branch information
Showing
41 changed files
with
2,572 additions
and
612 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,84 +1,84 @@ | ||
@if "%DEBUG%" == "" @echo off | ||
@rem ########################################################################## | ||
@rem | ||
@rem Gradle startup script for Windows | ||
@rem | ||
@rem ########################################################################## | ||
|
||
@rem Set local scope for the variables with windows NT shell | ||
if "%OS%"=="Windows_NT" setlocal | ||
|
||
set DIRNAME=%~dp0 | ||
if "%DIRNAME%" == "" set DIRNAME=. | ||
set APP_BASE_NAME=%~n0 | ||
set APP_HOME=%DIRNAME% | ||
|
||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
set DEFAULT_JVM_OPTS= | ||
|
||
@rem Find java.exe | ||
if defined JAVA_HOME goto findJavaFromJavaHome | ||
|
||
set JAVA_EXE=java.exe | ||
%JAVA_EXE% -version >NUL 2>&1 | ||
if "%ERRORLEVEL%" == "0" goto init | ||
|
||
echo. | ||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
echo. | ||
echo Please set the JAVA_HOME variable in your environment to match the | ||
echo location of your Java installation. | ||
|
||
goto fail | ||
|
||
:findJavaFromJavaHome | ||
set JAVA_HOME=%JAVA_HOME:"=% | ||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||
|
||
if exist "%JAVA_EXE%" goto init | ||
|
||
echo. | ||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||
echo. | ||
echo Please set the JAVA_HOME variable in your environment to match the | ||
echo location of your Java installation. | ||
|
||
goto fail | ||
|
||
:init | ||
@rem Get command-line arguments, handling Windows variants | ||
|
||
if not "%OS%" == "Windows_NT" goto win9xME_args | ||
|
||
:win9xME_args | ||
@rem Slurp the command line arguments. | ||
set CMD_LINE_ARGS= | ||
set _SKIP=2 | ||
|
||
:win9xME_args_slurp | ||
if "x%~1" == "x" goto execute | ||
|
||
set CMD_LINE_ARGS=%* | ||
|
||
:execute | ||
@rem Setup the command line | ||
|
||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||
|
||
@rem Execute Gradle | ||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||
|
||
:end | ||
@rem End local scope for the variables with windows NT shell | ||
if "%ERRORLEVEL%"=="0" goto mainEnd | ||
|
||
:fail | ||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||
rem the _cmd.exe /c_ return code! | ||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||
exit /b 1 | ||
|
||
:mainEnd | ||
if "%OS%"=="Windows_NT" endlocal | ||
|
||
:omega | ||
@if "%DEBUG%" == "" @echo off | ||
@rem ########################################################################## | ||
@rem | ||
@rem Gradle startup script for Windows | ||
@rem | ||
@rem ########################################################################## | ||
|
||
@rem Set local scope for the variables with windows NT shell | ||
if "%OS%"=="Windows_NT" setlocal | ||
|
||
set DIRNAME=%~dp0 | ||
if "%DIRNAME%" == "" set DIRNAME=. | ||
set APP_BASE_NAME=%~n0 | ||
set APP_HOME=%DIRNAME% | ||
|
||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
set DEFAULT_JVM_OPTS= | ||
|
||
@rem Find java.exe | ||
if defined JAVA_HOME goto findJavaFromJavaHome | ||
|
||
set JAVA_EXE=java.exe | ||
%JAVA_EXE% -version >NUL 2>&1 | ||
if "%ERRORLEVEL%" == "0" goto init | ||
|
||
echo. | ||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
echo. | ||
echo Please set the JAVA_HOME variable in your environment to match the | ||
echo location of your Java installation. | ||
|
||
goto fail | ||
|
||
:findJavaFromJavaHome | ||
set JAVA_HOME=%JAVA_HOME:"=% | ||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||
|
||
if exist "%JAVA_EXE%" goto init | ||
|
||
echo. | ||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||
echo. | ||
echo Please set the JAVA_HOME variable in your environment to match the | ||
echo location of your Java installation. | ||
|
||
goto fail | ||
|
||
:init | ||
@rem Get command-line arguments, handling Windows variants | ||
|
||
if not "%OS%" == "Windows_NT" goto win9xME_args | ||
|
||
:win9xME_args | ||
@rem Slurp the command line arguments. | ||
set CMD_LINE_ARGS= | ||
set _SKIP=2 | ||
|
||
:win9xME_args_slurp | ||
if "x%~1" == "x" goto execute | ||
|
||
set CMD_LINE_ARGS=%* | ||
|
||
:execute | ||
@rem Setup the command line | ||
|
||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||
|
||
@rem Execute Gradle | ||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||
|
||
:end | ||
@rem End local scope for the variables with windows NT shell | ||
if "%ERRORLEVEL%"=="0" goto mainEnd | ||
|
||
:fail | ||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||
rem the _cmd.exe /c_ return code! | ||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||
exit /b 1 | ||
|
||
:mainEnd | ||
if "%OS%"=="Windows_NT" endlocal | ||
|
||
:omega |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
69 changes: 69 additions & 0 deletions
69
...src/main/java/de/maibornwolff/codecharta/importer/sonar/SonarComponentProjectAdapter.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
package de.maibornwolff.codecharta.importer.sonar; | ||
|
||
import de.maibornwolff.codecharta.importer.sonar.model.Component; | ||
import de.maibornwolff.codecharta.importer.sonar.model.Measure; | ||
import de.maibornwolff.codecharta.importer.sonar.model.Qualifier; | ||
import de.maibornwolff.codecharta.model.Node; | ||
import de.maibornwolff.codecharta.model.NodeType; | ||
import de.maibornwolff.codecharta.model.Project; | ||
import de.maibornwolff.codecharta.nodeinserter.FileSystemPath; | ||
import de.maibornwolff.codecharta.nodeinserter.NodeInserter; | ||
|
||
import java.util.List; | ||
import java.util.Map; | ||
import java.util.stream.Collectors; | ||
|
||
public class SonarComponentProjectAdapter extends Project { | ||
|
||
public SonarComponentProjectAdapter(String name) { | ||
super(name); | ||
this.getNodes().add(new Node("root", NodeType.Folder)); | ||
} | ||
|
||
public void addComponentAsNode(Component component) { | ||
Node node = new Node(createNodeName(component.getPath()), createNodeTypeFromQualifier(component.getQualifier()), createAttributes(component.getMeasures())); | ||
NodeInserter.insertByPath(this, createParentPath(component.getPath()), node); | ||
} | ||
|
||
private Map<String, Object> createAttributes(List<Measure> measures) { | ||
return measures.stream() | ||
.filter(this::isMeasureConvertible) | ||
.collect(Collectors.toMap(Measure::getMetric, this::convertMetricValue)); | ||
} | ||
|
||
private Object convertMetricValue(Measure measure) { | ||
return Double.parseDouble(measure.getValue()); | ||
} | ||
|
||
private boolean isMeasureConvertible(Measure measure) { | ||
if (measure.getValue() != null) { | ||
try { | ||
Double.parseDouble(measure.getValue()); | ||
return true; | ||
} catch (NumberFormatException nfe) { | ||
return false; | ||
} | ||
} | ||
|
||
return false; | ||
|
||
} | ||
|
||
private NodeType createNodeTypeFromQualifier(Qualifier qualifier) { | ||
switch (qualifier) { | ||
case FIL: | ||
case UTS: | ||
return NodeType.File; | ||
default: | ||
return NodeType.Folder; | ||
} | ||
} | ||
|
||
private static String createNodeName(String path) { | ||
return path.substring(path.lastIndexOf('/') + 1); | ||
} | ||
|
||
private FileSystemPath createParentPath(String lname) { | ||
return new FileSystemPath(lname.substring(0, lname.lastIndexOf('/') + 1)); | ||
} | ||
} |
49 changes: 49 additions & 0 deletions
49
.../SonarImporter/src/main/java/de/maibornwolff/codecharta/importer/sonar/SonarImporter.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
package de.maibornwolff.codecharta.importer.sonar; | ||
|
||
import com.google.common.collect.ImmutableList; | ||
import de.maibornwolff.codecharta.importer.sonar.dataaccess.SonarMeasuresAPIDatasource; | ||
import de.maibornwolff.codecharta.importer.sonar.dataaccess.SonarMetricsAPIDatasource; | ||
import de.maibornwolff.codecharta.importer.sonar.model.Qualifier; | ||
import de.maibornwolff.codecharta.model.Project; | ||
import io.reactivex.Flowable; | ||
import io.reactivex.schedulers.Schedulers; | ||
|
||
import java.util.List; | ||
|
||
public class SonarImporter { | ||
|
||
public static final List STANDARD_SONAR_METRICS = ImmutableList.of( | ||
"complexity", "ncloc", "functions", "duplicated_lines", "classes", "blocker_violations", "generated_lines", "bugs", "commented_out_code_lines", "lines", "violations", "comment_lines", "duplicated_blocks"); | ||
|
||
private SonarMeasuresAPIDatasource measuresDS; | ||
|
||
public SonarImporter(SonarMeasuresAPIDatasource measuresDS) { | ||
this.measuresDS = measuresDS; | ||
} | ||
|
||
public Project getProjectFromMeasureAPI(String name, List<String> metrics) throws SonarImporterException { | ||
List<String> metricsList = getMetricList(metrics); | ||
SonarComponentProjectAdapter project = new SonarComponentProjectAdapter(name); | ||
|
||
int noPages = measuresDS.getNumberOfPages(metricsList); | ||
|
||
Flowable.range(1, noPages) | ||
.flatMap(p -> Flowable.just(p) | ||
.subscribeOn(Schedulers.io()) | ||
.map(page -> measuresDS.getMeasures(metricsList, page))) | ||
.filter(m -> m.getComponents() != null) | ||
.flatMap(m -> Flowable.fromIterable(m.getComponents())) | ||
.filter(c -> c.getQualifier() == Qualifier.FIL || c.getQualifier() == Qualifier.UTS) | ||
.blockingForEach(project::addComponentAsNode); | ||
|
||
return project; | ||
} | ||
|
||
public List<String> getMetricList(List<String> metrics) { | ||
if (metrics.isEmpty()) { | ||
return STANDARD_SONAR_METRICS; | ||
} | ||
return metrics; | ||
} | ||
|
||
} |
Oops, something went wrong.