From 9c74dc7710f74e5b60beefdb6949a022a5ed2c6a Mon Sep 17 00:00:00 2001 From: Duarte Meneses Date: Wed, 1 Mar 2017 13:47:39 +0100 Subject: SONAR-8783 Improve display of error when uploading scanner report --- .../org/sonar/scanner/bootstrap/ScannerWsClient.java | 2 +- .../java/org/sonar/scanner/report/ReportPublisher.java | 10 +++++++++- .../org/sonar/scanner/report/ReportPublisherTest.java | 17 ++++++++++++++++- 3 files changed, 26 insertions(+), 3 deletions(-) (limited to 'sonar-scanner-engine/src') diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerWsClient.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerWsClient.java index f1c87bdf71d..19e0169e182 100644 --- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerWsClient.java +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerWsClient.java @@ -106,7 +106,7 @@ public class ScannerWsClient { response.failIfNotSuccessful(); } - private static String tryParseAsJsonError(String responseContent) { + public static String tryParseAsJsonError(String responseContent) { try { JsonParser parser = new JsonParser(); JsonObject obj = parser.parse(responseContent).getAsJsonObject(); 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 0f4e2ecf1e6..c06f344c8ab 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 @@ -52,6 +52,7 @@ import org.sonar.scanner.protocol.output.ScannerReportWriter; import org.sonar.scanner.scan.ImmutableProjectReactor; import org.sonarqube.ws.MediaTypes; import org.sonarqube.ws.WsCe; +import org.sonarqube.ws.client.HttpException; import org.sonarqube.ws.client.PostRequest; import org.sonarqube.ws.client.WsResponse; @@ -174,7 +175,14 @@ public class ReportPublisher implements Startable { .setParam("projectName", projectDefinition.getOriginalName()) .setParam("projectBranch", projectDefinition.getBranch()) .setPart("report", filePart); - WsResponse response = wsClient.call(post).failIfNotSuccessful(); + + WsResponse response; + try { + response = wsClient.call(post).failIfNotSuccessful(); + } catch (HttpException e) { + throw MessageException.of(String.format("Failed to upload report - %d: %s", e.code(), ScannerWsClient.tryParseAsJsonError(e.content()))); + } + try (InputStream protobuf = response.contentStream()) { return WsCe.SubmitResponse.parser().parseFrom(protobuf).getTaskId(); } catch (Exception e) { 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 118b460b740..a47550ba721 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 @@ -47,6 +47,7 @@ import org.sonar.scanner.analysis.DefaultAnalysisMode; import org.sonar.scanner.bootstrap.ScannerWsClient; import org.sonar.scanner.scan.ImmutableProjectReactor; import org.sonarqube.ws.WsCe; +import org.sonarqube.ws.client.HttpException; import org.sonarqube.ws.client.WsRequest; import org.sonarqube.ws.client.WsResponse; @@ -71,7 +72,7 @@ public class ReportPublisherTest { DefaultAnalysisMode mode = mock(DefaultAnalysisMode.class); Settings settings = new MapSettings(new PropertyDefinitions(CorePropertyDefinitions.all())); - ScannerWsClient wsClient = mock(ScannerWsClient.class, Mockito.RETURNS_DEEP_STUBS); + ScannerWsClient wsClient; Server server = mock(Server.class); ImmutableProjectReactor reactor = mock(ImmutableProjectReactor.class); ProjectDefinition root; @@ -79,6 +80,7 @@ public class ReportPublisherTest { @Before public void setUp() { + wsClient = mock(ScannerWsClient.class, Mockito.RETURNS_DEEP_STUBS); root = ProjectDefinition.create().setKey("struts").setWorkDir(temp.getRoot()); when(reactor.getRoot()).thenReturn(root); when(server.getPublicRootUrl()).thenReturn("https://localhost"); @@ -108,6 +110,19 @@ public class ReportPublisherTest { "ceTaskUrl=https://localhost/api/ce/task?id=TASK-123\n"); } + @Test + public void parse_upload_error_message() throws IOException { + ReportPublisher underTest = new ReportPublisher(settings, wsClient, server, contextPublisher, reactor, mode, mock(TempFolder.class), new ReportPublisherStep[0]); + 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); + when(wsClient.call(any(WsRequest.class))).thenReturn(response); + + exception.expect(MessageException.class); + exception.expectMessage("Failed to upload report - 404: Organization with key 'MyOrg' does not exist"); + underTest.upload(temp.newFile()); + } + @Test public void log_public_url_if_defined() throws IOException { when(server.getPublicRootUrl()).thenReturn("https://publicserver/sonarqube"); -- cgit v1.2.3