diff options
author | Julien Lancelot <julien.lancelot@sonarsource.com> | 2017-08-16 14:24:51 +0200 |
---|---|---|
committer | Janos Gyerik <janos.gyerik@sonarsource.com> | 2017-09-12 10:59:56 +0200 |
commit | 426593fb7e2035dd77a988998dd10332d2aebf53 (patch) | |
tree | 2a236d74ef493b2be3b85ead03ca2787a0e686b4 /sonar-scanner-engine | |
parent | 7adee5ee96b30672fbdebd0f80981faa4aa4cf0d (diff) | |
download | sonarqube-426593fb7e2035dd77a988998dd10332d2aebf53.tar.gz sonarqube-426593fb7e2035dd77a988998dd10332d2aebf53.zip |
SONAR-9616 Send branch type into the report as characteristic
Diffstat (limited to 'sonar-scanner-engine')
-rw-r--r-- | sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ReportPublisher.java | 11 | ||||
-rw-r--r-- | sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ReportPublisherTest.java | 61 |
2 files changed, 58 insertions, 14 deletions
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ReportPublisher.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ReportPublisher.java index f1265ebc421..790e6192772 100644 --- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ReportPublisher.java +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/report/ReportPublisher.java @@ -47,6 +47,7 @@ import org.sonar.api.utils.log.Loggers; import org.sonar.scanner.analysis.DefaultAnalysisMode; import org.sonar.scanner.bootstrap.ScannerWsClient; import org.sonar.scanner.protocol.output.ScannerReportWriter; +import org.sonar.scanner.scan.BranchConfiguration; import org.sonarqube.ws.MediaTypes; import org.sonarqube.ws.WsCe; import org.sonarqube.ws.client.HttpException; @@ -74,12 +75,13 @@ public class ReportPublisher implements Startable { private final TempFolder temp; private final ReportPublisherStep[] publishers; private final Server server; + private final BranchConfiguration branchConfiguration; private Path reportDir; private ScannerReportWriter writer; public ReportPublisher(Configuration settings, ScannerWsClient wsClient, Server server, AnalysisContextReportPublisher contextPublisher, - InputModuleHierarchy moduleHierarchy, DefaultAnalysisMode analysisMode, TempFolder temp, ReportPublisherStep[] publishers) { + InputModuleHierarchy moduleHierarchy, DefaultAnalysisMode analysisMode, TempFolder temp, ReportPublisherStep[] publishers, BranchConfiguration branchConfiguration) { this.settings = settings; this.wsClient = wsClient; this.server = server; @@ -88,6 +90,7 @@ public class ReportPublisher implements Startable { this.analysisMode = analysisMode; this.temp = temp; this.publishers = publishers; + this.branchConfiguration = branchConfiguration; } @Override @@ -178,7 +181,11 @@ public class ReportPublisher implements Startable { post.setParam("characteristic", "incremental=true"); } - settings.get(BRANCH_NAME).ifPresent(b -> post.setParam("characteristic", "branch=" + b)); + String branchName = branchConfiguration.branchName(); + if (branchName != null) { + post.setParam("characteristic", "branch=" + branchName); + post.setParam("characteristic", "branchType=" + branchConfiguration.branchType().name()); + } WsResponse response; try { diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ReportPublisherTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ReportPublisherTest.java index fd868541970..e7da36601b0 100644 --- a/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ReportPublisherTest.java +++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/report/ReportPublisherTest.java @@ -46,6 +46,7 @@ import org.sonar.core.config.CorePropertyDefinitions; import org.sonar.core.config.ScannerProperties; import org.sonar.scanner.analysis.DefaultAnalysisMode; import org.sonar.scanner.bootstrap.ScannerWsClient; +import org.sonar.scanner.scan.BranchConfiguration; import org.sonarqube.ws.WsCe; import org.sonarqube.ws.client.HttpException; import org.sonarqube.ws.client.WsRequest; @@ -58,6 +59,7 @@ import static org.mockito.Matchers.any; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; +import static org.sonar.scanner.scan.BranchConfiguration.BranchType.SHORT; public class ReportPublisherTest { @@ -77,6 +79,7 @@ public class ReportPublisherTest { InputModuleHierarchy moduleHierarchy = mock(InputModuleHierarchy.class); DefaultInputModule root; AnalysisContextReportPublisher contextPublisher = mock(AnalysisContextReportPublisher.class); + BranchConfiguration branchConfiguration = mock(BranchConfiguration.class); @Before public void setUp() throws IOException { @@ -90,7 +93,7 @@ public class ReportPublisherTest { @Test public void log_and_dump_information_about_report_uploading() throws IOException { ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); settings.setProperty(ScannerProperties.ORGANIZATION, "MyOrg"); underTest.logSuccess("TASK-123"); @@ -114,7 +117,7 @@ public class ReportPublisherTest { @Test public void parse_upload_error_message() throws IOException { ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); HttpException ex = new HttpException("url", 404, "{\"errors\":[{\"msg\":\"Organization with key 'MyOrg' does not exist\"}]}"); WsResponse response = mock(WsResponse.class); when(response.failIfNotSuccessful()).thenThrow(ex); @@ -129,7 +132,7 @@ public class ReportPublisherTest { public void log_public_url_if_defined() throws IOException { when(server.getPublicRootUrl()).thenReturn("https://publicserver/sonarqube"); ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); underTest.logSuccess("TASK-123"); @@ -151,7 +154,7 @@ public class ReportPublisherTest { public void fail_if_public_url_malformed() throws IOException { when(server.getPublicRootUrl()).thenReturn("invalid"); ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); exception.expect(MessageException.class); exception.expectMessage("Failed to parse public URL set in SonarQube server: invalid"); @@ -161,7 +164,7 @@ public class ReportPublisherTest { @Test public void log_but_not_dump_information_when_report_is_not_uploaded() { ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); underTest.logSuccess(/* report not uploaded, no server task */null); @@ -179,7 +182,7 @@ public class ReportPublisherTest { Path reportDir = temp.getRoot().toPath().resolve("scanner-report"); Files.createDirectory(reportDir); ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); underTest.start(); underTest.stop(); @@ -190,7 +193,8 @@ public class ReportPublisherTest { public void should_delete_report_by_default() throws IOException { Path reportDir = temp.getRoot().toPath().resolve("scanner-report"); Files.createDirectory(reportDir); - ReportPublisher job = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), new ReportPublisherStep[0]); + ReportPublisher job = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), new ReportPublisherStep[0], + branchConfiguration); job.start(); job.stop(); @@ -200,7 +204,7 @@ public class ReportPublisherTest { @Test public void test_ws_parameters() throws Exception { ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); settings.setProperty(ScannerProperties.ORGANIZATION, "MyOrg"); @@ -227,16 +231,49 @@ public class ReportPublisherTest { } @Test - public void test_send_characteristics() throws Exception { + public void test_send_incremental_characteristic() throws Exception { ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), - new ReportPublisherStep[0]); + new ReportPublisherStep[0], branchConfiguration); when(mode.isIncremental()).thenReturn(true); String orgName = "MyOrg"; settings.setProperty(ScannerProperties.ORGANIZATION, orgName); + WsResponse response = mock(WsResponse.class); + + PipedOutputStream out = new PipedOutputStream(); + PipedInputStream in = new PipedInputStream(out); + WsCe.SubmitResponse.newBuilder().build().writeTo(out); + out.close(); + + when(response.failIfNotSuccessful()).thenReturn(response); + when(response.contentStream()).thenReturn(in); + + when(wsClient.call(any(WsRequest.class))).thenReturn(response); + underTest.upload(temp.newFile()); + + ArgumentCaptor<WsRequest> capture = ArgumentCaptor.forClass(WsRequest.class); + verify(wsClient).call(capture.capture()); + + WsRequest wsRequest = capture.getValue(); + assertThat(wsRequest.getParameters().getKeys()).hasSize(3); + assertThat(wsRequest.getParameters().getValues("organization")).containsExactly(orgName); + assertThat(wsRequest.getParameters().getValues("projectKey")).containsExactly("struts"); + assertThat(wsRequest.getParameters().getValues("characteristic")) + .containsExactly("incremental=true"); + } + + @Test + public void test_send_branches_characteristics() throws Exception { + ReportPublisher underTest = new ReportPublisher(settings.asConfig(), wsClient, server, contextPublisher, moduleHierarchy, mode, mock(TempFolder.class), + new ReportPublisherStep[0], branchConfiguration); + + String orgName = "MyOrg"; + settings.setProperty(ScannerProperties.ORGANIZATION, orgName); + String branchName = "feature"; - settings.setProperty(ScannerProperties.BRANCH_NAME, branchName); + when(branchConfiguration.branchName()).thenReturn(branchName); + when(branchConfiguration.branchType()).thenReturn(SHORT); WsResponse response = mock(WsResponse.class); @@ -259,7 +296,7 @@ public class ReportPublisherTest { assertThat(wsRequest.getParameters().getValues("organization")).containsExactly(orgName); assertThat(wsRequest.getParameters().getValues("projectKey")).containsExactly("struts"); assertThat(wsRequest.getParameters().getValues("characteristic")) - .containsExactly("incremental=true", "branch=" + branchName); + .containsExactlyInAnyOrder("branch=" + branchName, "branchType=" + SHORT.name()); } } |