aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-ws/src/main/java/org/sonarqube/ws/client/HttpRequestFactory.java44
-rw-r--r--sonar-ws/src/main/java/org/sonarqube/ws/client/WsClient.java7
-rw-r--r--sonar-ws/src/test/java/org/sonarqube/ws/client/HttpRequestFactoryTest.java81
-rw-r--r--sonar-ws/src/test/java/org/sonarqube/ws/client/WsClientTest.java7
4 files changed, 44 insertions, 95 deletions
diff --git a/sonar-ws/src/main/java/org/sonarqube/ws/client/HttpRequestFactory.java b/sonar-ws/src/main/java/org/sonarqube/ws/client/HttpRequestFactory.java
index 4ae2ce1f912..3b10c9d0a48 100644
--- a/sonar-ws/src/main/java/org/sonarqube/ws/client/HttpRequestFactory.java
+++ b/sonar-ws/src/main/java/org/sonarqube/ws/client/HttpRequestFactory.java
@@ -26,7 +26,6 @@ import com.google.protobuf.InvalidProtocolBufferException;
import com.google.protobuf.Message;
import com.google.protobuf.Parser;
import java.util.Arrays;
-import java.util.Map;
import javax.annotation.Nullable;
import static java.net.HttpURLConnection.HTTP_CREATED;
@@ -41,7 +40,11 @@ public class HttpRequestFactory {
private static final int[] RESPONSE_SUCCESS = {HTTP_OK, HTTP_CREATED, HTTP_NO_CONTENT};
private final String baseUrl;
- private String login, password, proxyHost, proxyLogin, proxyPassword;
+ private String login;
+ private String password;
+ private String proxyHost;
+ private String proxyLogin;
+ private String proxyPassword;
private int proxyPort;
private int connectTimeoutInMilliseconds;
private int readTimeoutInMilliseconds;
@@ -126,16 +129,6 @@ public class HttpRequestFactory {
return readTimeoutInMilliseconds;
}
- public String get(String wsUrl, Map<String, Object> queryParams) {
- HttpRequest request = prepare(HttpRequest.get(buildUrl(wsUrl), queryParams, true));
- return execute(request);
- }
-
- public String post(String wsUrl, Map<String, Object> queryParams) {
- HttpRequest request = prepare(HttpRequest.post(buildUrl(wsUrl), true)).form(queryParams, HttpRequest.CHARSET_UTF8);
- return execute(request);
- }
-
public String execute(WsRequest wsRequest) {
HttpRequest httpRequest = wsRequestToHttpRequest(wsRequest);
return execute(httpRequest);
@@ -148,7 +141,7 @@ public class HttpRequestFactory {
} catch (InvalidProtocolBufferException e) {
Throwables.propagate(e);
}
-
+
throw new IllegalStateException("Uncatched exception when parsing protobuf response");
}
@@ -161,9 +154,13 @@ public class HttpRequestFactory {
case PROTOBUF:
httpRequest.accept(MediaType.PROTOBUF.toString());
break;
- default:
+ case JSON:
httpRequest.accept(MediaType.JSON_UTF_8.toString());
break;
+ case TEXT:
+ default:
+ httpRequest.accept(MediaType.PLAIN_TEXT_UTF_8.toString());
+ break;
}
return httpRequest;
@@ -179,21 +176,20 @@ public class HttpRequestFactory {
return url.toString();
}
- private String execute(HttpRequest request) {
+ private static String execute(HttpRequest request) {
try {
- if (isSuccess(request)) {
- return request.body(HttpRequest.CHARSET_UTF8);
- }
- // TODO better handle error messages
- throw new HttpException(request.url().toString(), request.code(), request.body());
-
+ checkSuccess(request);
+ return request.body(HttpRequest.CHARSET_UTF8);
} catch (HttpRequest.HttpRequestException e) {
- throw new IllegalStateException("Fail to request " + request.url(), e.getCause());
+ throw new IllegalStateException("Fail to request " + request.url(), e);
}
}
- private boolean isSuccess(HttpRequest request) {
- return Arrays.binarySearch(RESPONSE_SUCCESS, request.code()) >= 0;
+ private static void checkSuccess(HttpRequest request) {
+ boolean isSuccess = Arrays.binarySearch(RESPONSE_SUCCESS, request.code()) >= 0;
+ if (!isSuccess) {
+ throw new HttpException(request.url().toString(), request.code(), request.body());
+ }
}
private HttpRequest prepare(HttpRequest request) {
diff --git a/sonar-ws/src/main/java/org/sonarqube/ws/client/WsClient.java b/sonar-ws/src/main/java/org/sonarqube/ws/client/WsClient.java
index e6e6c827bd6..641ac51d8a1 100644
--- a/sonar-ws/src/main/java/org/sonarqube/ws/client/WsClient.java
+++ b/sonar-ws/src/main/java/org/sonarqube/ws/client/WsClient.java
@@ -87,7 +87,12 @@ public class WsClient {
}
public static class Builder {
- private String login, password, url, proxyHost, proxyLogin, proxyPassword;
+ private String login;
+ private String password;
+ private String url;
+ private String proxyHost;
+ private String proxyLogin;
+ private String proxyPassword;
private int proxyPort = 0;
private int connectTimeoutMs = DEFAULT_CONNECT_TIMEOUT_MILLISECONDS, readTimeoutMs = DEFAULT_READ_TIMEOUT_MILLISECONDS;
diff --git a/sonar-ws/src/test/java/org/sonarqube/ws/client/HttpRequestFactoryTest.java b/sonar-ws/src/test/java/org/sonarqube/ws/client/HttpRequestFactoryTest.java
index f14ad893b54..5007e4d827a 100644
--- a/sonar-ws/src/test/java/org/sonarqube/ws/client/HttpRequestFactoryTest.java
+++ b/sonar-ws/src/test/java/org/sonarqube/ws/client/HttpRequestFactoryTest.java
@@ -19,27 +19,24 @@
*/
package org.sonarqube.ws.client;
-import java.net.ConnectException;
-import java.text.ParseException;
-import java.text.SimpleDateFormat;
-import java.util.Collections;
-import java.util.Date;
import org.junit.Rule;
import org.junit.Test;
+import org.junit.rules.ExpectedException;
import static org.assertj.core.api.Assertions.assertThat;
-import static org.junit.Assert.fail;
public class HttpRequestFactoryTest {
@Rule
public MockHttpServerInterceptor httpServer = new MockHttpServerInterceptor();
+ @Rule
+ public ExpectedException expectedException = ExpectedException.none();
@Test
public void test_get() {
httpServer.stubStatusCode(200).stubResponseBody("{'issues': []}");
HttpRequestFactory factory = new HttpRequestFactory(httpServer.url());
- String json = factory.get("/api/issues", Collections.<String, Object>emptyMap());
+ String json = factory.execute(new WsRequest("/api/issues"));
assertThat(json).isEqualTo("{'issues': []}");
assertThat(httpServer.requestedPath()).isEqualTo("/api/issues");
@@ -47,48 +44,11 @@ public class HttpRequestFactoryTest {
@Test
public void should_throw_illegal_state_exc_if_connect_exception() {
- HttpRequestFactory factory = new HttpRequestFactory("http://localhost:1");
- try {
- factory.get("/api/issues", Collections.<String, Object>emptyMap());
- fail();
- } catch (Exception e) {
- assertThat(e).isInstanceOf(IllegalStateException.class);
- assertThat(e).hasMessage("Fail to request http://localhost:1/api/issues");
- assertThat(e.getCause().getMessage()).matches(".*(Connection refused|Connexion refusée).*");
- }
- }
-
- @Test
- public void test_post() {
- httpServer.stubStatusCode(200).stubResponseBody("{}");
-
- HttpRequestFactory factory = new HttpRequestFactory(httpServer.url());
- String json = factory.post("/api/issues/change", Collections.<String, Object>emptyMap());
-
- assertThat(json).isEqualTo("{}");
- assertThat(httpServer.requestedPath()).isEqualTo("/api/issues/change");
- }
-
- @Test
- public void post_successful_if_created() {
- httpServer.stubStatusCode(201).stubResponseBody("{}");
+ expectedException.expect(IllegalStateException.class);
+ expectedException.expectMessage("Fail to request http://localhost:1/api/issues");
- HttpRequestFactory factory = new HttpRequestFactory(httpServer.url());
- String json = factory.post("/api/issues/change", Collections.<String, Object>emptyMap());
-
- assertThat(json).isEqualTo("{}");
- assertThat(httpServer.requestedPath()).isEqualTo("/api/issues/change");
- }
-
- @Test
- public void post_successful_if_no_content() {
- httpServer.stubStatusCode(204).stubResponseBody("");
-
- HttpRequestFactory factory = new HttpRequestFactory(httpServer.url());
- String json = factory.post("/api/issues/change", Collections.<String, Object>emptyMap());
-
- assertThat(json).isEqualTo("");
- assertThat(httpServer.requestedPath()).isEqualTo("/api/issues/change");
+ HttpRequestFactory factory = new HttpRequestFactory("http://localhost:1");
+ factory.execute(new WsRequest("/api/issues"));
}
@Test
@@ -96,7 +56,7 @@ public class HttpRequestFactoryTest {
httpServer.stubStatusCode(200).stubResponseBody("{}");
HttpRequestFactory factory = new HttpRequestFactory(httpServer.url()).setLogin("karadoc").setPassword("legrascestlavie");
- String json = factory.get("/api/issues", Collections.<String, Object>emptyMap());
+ String json = factory.execute(new WsRequest("/api/issues"));
assertThat(json).isEqualTo("{}");
assertThat(httpServer.requestedPath()).isEqualTo("/api/issues");
@@ -105,34 +65,21 @@ public class HttpRequestFactoryTest {
@Test
public void test_proxy() throws Exception {
+ expectedException.expect(IllegalStateException.class);
+
HttpRequestFactory factory = new HttpRequestFactory(httpServer.url())
.setProxyHost("localhost").setProxyPort(1)
.setProxyLogin("john").setProxyPassword("smith");
- try {
- factory.get("/api/issues", Collections.<String, Object>emptyMap());
- fail();
- } catch (IllegalStateException e) {
- // it's not possible to check that the proxy is correctly configured
- assertThat(e.getCause()).isInstanceOf(ConnectException.class);
- }
+ factory.execute(new WsRequest("/api/issues"));
}
@Test
public void beginning_slash_is_optional() throws Exception {
HttpRequestFactory factory = new HttpRequestFactory(httpServer.url());
- factory.get("api/foo", Collections.<String, Object>emptyMap());
+ factory.execute(new WsRequest("api/foo"));
assertThat(httpServer.requestedPath()).isEqualTo("/api/foo");
- factory.get("/api/bar", Collections.<String, Object>emptyMap());
+ factory.execute(new WsRequest("/api/bar"));
assertThat(httpServer.requestedPath()).isEqualTo("/api/bar");
}
-
- protected static Date toDate(String sDate) {
- try {
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
- return sdf.parse(sDate);
- } catch (ParseException e) {
- throw new RuntimeException(e);
- }
- }
}
diff --git a/sonar-ws/src/test/java/org/sonarqube/ws/client/WsClientTest.java b/sonar-ws/src/test/java/org/sonarqube/ws/client/WsClientTest.java
index 6a62da72401..715d8a4cc76 100644
--- a/sonar-ws/src/test/java/org/sonarqube/ws/client/WsClientTest.java
+++ b/sonar-ws/src/test/java/org/sonarqube/ws/client/WsClientTest.java
@@ -92,7 +92,7 @@ public class WsClientTest {
expectedException.expect(IllegalStateException.class);
expectedException.expectMessage("Server URL must be set");
- underTest.builder().build();
+ WsClient.builder().build();
}
@Test
@@ -100,7 +100,7 @@ public class WsClientTest {
expectedException.expect(IllegalStateException.class);
expectedException.expectMessage("Server URL must be set");
- underTest.create("");
+ WsClient.create("");
}
@Test
@@ -119,7 +119,8 @@ public class WsClientTest {
@Test
public void test_custom_configuration() throws Exception {
- underTest = WsClient.builder().url("http://localhost:9000")
+ underTest = WsClient.builder()
+ .url("http://localhost:9000")
.login("eric")
.password("pass")
.connectTimeoutMilliseconds(12345)