diff options
author | Julien HENRY <julien.henry@sonarsource.com> | 2013-01-17 19:16:20 +0100 |
---|---|---|
committer | Julien HENRY <julien.henry@sonarsource.com> | 2013-01-17 19:16:20 +0100 |
commit | 5d5c4140f8f4c2b2c1eea1f7840df7aad6fb5cea (patch) | |
tree | 85b5d3086d5d7b4b609b5123022e2919acc24942 | |
parent | a10143d0914482a570ef930f2e32279438d1210d (diff) | |
download | sonar-scanner-cli-5d5c4140f8f4c2b2c1eea1f7840df7aad6fb5cea.tar.gz sonar-scanner-cli-5d5c4140f8f4c2b2c1eea1f7840df7aad6fb5cea.zip |
SONARPLUGINS-2468 Improve display of errors.
-rw-r--r-- | src/main/java/org/sonar/runner/Bootstrapper.java | 8 | ||||
-rw-r--r-- | src/main/java/org/sonar/runner/Main.java | 6 |
2 files changed, 11 insertions, 3 deletions
diff --git a/src/main/java/org/sonar/runner/Bootstrapper.java b/src/main/java/org/sonar/runner/Bootstrapper.java index d201f47..bfe6757 100644 --- a/src/main/java/org/sonar/runner/Bootstrapper.java +++ b/src/main/java/org/sonar/runner/Bootstrapper.java @@ -29,6 +29,7 @@ import java.net.ConnectException; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.URL; +import java.net.UnknownHostException; import java.util.ArrayList; import java.util.List; @@ -77,9 +78,12 @@ class Bootstrapper { serverVersion = remoteContent(VERSION_PATH); } catch (ConnectException e) { Logs.error("Sonar server '" + serverUrl + "' can not be reached"); - throw new IllegalStateException("Fail to request server version", e); + throw new RunnerException("Fail to request server version", e); + } catch (UnknownHostException e) { + Logs.error("Sonar server '" + serverUrl + "' can not be reached"); + throw new RunnerException("Fail to request server version", e); } catch (IOException e) { - throw new IllegalStateException("Fail to request server version", e); + throw new RunnerException("Fail to request server version", e); } } return serverVersion; diff --git a/src/main/java/org/sonar/runner/Main.java b/src/main/java/org/sonar/runner/Main.java index 90994fb..9cb9d47 100644 --- a/src/main/java/org/sonar/runner/Main.java +++ b/src/main/java/org/sonar/runner/Main.java @@ -132,8 +132,12 @@ public final class Main { Logs.error(message); if (e != null) { Logs.error(e.getMessage()); - for (Throwable cause = e.getCause(); cause != null; cause = cause.getCause()) { + String previousMsg = ""; + for (Throwable cause = e.getCause(); cause != null + && cause.getMessage() != null + && !cause.getMessage().equals(previousMsg); cause = cause.getCause()) { Logs.error("Caused by: " + cause.getMessage()); + previousMsg = cause.getMessage(); } } Logs.error(""); |