Skip to content

Commit

Permalink
Fit and finish for RestClient.newBuilder()
Browse files Browse the repository at this point in the history
  • Loading branch information
jianghaolu committed Feb 10, 2017
1 parent ab07616 commit 4bb09c6
Show file tree
Hide file tree
Showing 4 changed files with 212 additions and 9 deletions.
44 changes: 35 additions & 9 deletions client-runtime/src/main/java/com/microsoft/rest/RestClient.java
Original file line number Diff line number Diff line change
Expand Up @@ -159,6 +159,8 @@ public static class Builder {
private ResponseBuilder.Factory responseBuilderFactory;
/** The logging interceptor to use. */
private LoggingInterceptor loggingInterceptor;
/** The strategy used for retry failed requests. */
private RetryStrategy retryStrategy;

/**
* Creates an instance of the builder with a base URL to the service.
Expand All @@ -168,21 +170,39 @@ public Builder() {
}

private Builder(RestClient restClient) {
this();
this.withBaseUrl(restClient.retrofit.baseUrl().toString())
.withConnectionTimeout(restClient.httpClient.connectTimeoutMillis(), TimeUnit.MILLISECONDS)
.withReadTimeout(restClient.httpClient.readTimeoutMillis(), TimeUnit.MILLISECONDS);
this(restClient.httpClient.newBuilder(), new Retrofit.Builder());
this.httpClientBuilder.interceptors().clear();
this.httpClientBuilder.networkInterceptors().clear();
this.withBaseUrl(restClient.retrofit.baseUrl().toString());
this.responseBuilderFactory = restClient.responseBuilderFactory;
this.serializerAdapter = restClient.serializerAdapter;
if (restClient.credentials != null) {
this.withCredentials(restClient.credentials);
this.credentials = restClient.credentials;
}
if (restClient.retrofit.callbackExecutor() != null) {
this.withCallbackExecutor(restClient.retrofit.callbackExecutor());
}
for (Interceptor interceptor : restClient.httpClient.interceptors()) {
this.withInterceptor(interceptor);
if (interceptor instanceof UserAgentInterceptor) {
this.userAgent = ((UserAgentInterceptor) interceptor).userAgent();
} else if (interceptor instanceof RetryHandler) {
this.retryStrategy = ((RetryHandler) interceptor).strategy();
} else if (interceptor instanceof RequestIdHeaderInterceptor
|| interceptor instanceof BaseUrlHandler) {
} else if (interceptor instanceof CustomHeadersInterceptor) {
this.customHeadersInterceptor = new CustomHeadersInterceptor();
this.customHeadersInterceptor.addHeaderMultimap(((CustomHeadersInterceptor) interceptor).headers());
} else {
this.withInterceptor(interceptor);
}
}
for (Interceptor interceptor : restClient.httpClient.networkInterceptors()) {
this.withNetworkInterceptor(interceptor);
if (interceptor instanceof LoggingInterceptor) {
LoggingInterceptor old = (LoggingInterceptor) interceptor;
this.loggingInterceptor = new LoggingInterceptor(old.logLevel());
} else {
this.withNetworkInterceptor(interceptor);
}
}
}

Expand Down Expand Up @@ -399,7 +419,7 @@ public Builder withResponseBuilderFactory(ResponseBuilder.Factory responseBuilde
* @return the builder itself for chaining
*/
public Builder withRetryStrategy(RetryStrategy strategy) {
this.withInterceptor(new RetryHandler(strategy));
this.retryStrategy = retryStrategy;
return this;
}

Expand All @@ -421,12 +441,18 @@ public RestClient build() {
if (responseBuilderFactory == null) {
responseBuilderFactory = new ServiceResponseBuilder.Factory();
}
RetryHandler retryHandler;
if (retryStrategy == null) {
retryHandler = new RetryHandler();
} else {
retryHandler = new RetryHandler(retryStrategy);
}
OkHttpClient httpClient = httpClientBuilder
.addInterceptor(userAgentInterceptor)
.addInterceptor(new RequestIdHeaderInterceptor())
.addInterceptor(new BaseUrlHandler())
.addInterceptor(customHeadersInterceptor)
.addInterceptor(new RetryHandler())
.addInterceptor(retryHandler)
.addNetworkInterceptor(loggingInterceptor)
.build();
return new RestClient(httpClient,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,13 @@
* when added to the {@link okhttp3.OkHttpClient} interceptors.
*/
public class CustomHeadersInterceptor implements Interceptor {
/**
* @return the currently stored custom headers
*/
public Map<String, List<String>> headers() {
return headers;
}

/**
* A mapping of custom headers.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,13 @@ public class RetryHandler implements Interceptor {
*/
private RetryStrategy retryStrategy;

/**
* @return the strategy used by this handler
*/
public RetryStrategy strategy() {
return retryStrategy;
}

/**
* Initialized an instance of {@link RetryHandler} class.
* Sets default retry strategy base on Exponential Backoff.
Expand Down
163 changes: 163 additions & 0 deletions client-runtime/src/test/java/com/microsoft/rest/RestClientTests.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,163 @@
/**
*
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*
*/

package com.microsoft.rest;

import com.microsoft.rest.credentials.BasicAuthenticationCredentials;
import com.microsoft.rest.credentials.TokenCredentials;
import com.microsoft.rest.interceptors.UserAgentInterceptor;
import com.microsoft.rest.protocol.ResponseBuilder;
import com.microsoft.rest.protocol.SerializerAdapter;
import com.microsoft.rest.serializer.JacksonAdapter;
import com.microsoft.rest.serializer.JacksonConverterFactory;
import okhttp3.Interceptor;
import okhttp3.Response;
import org.junit.Assert;
import org.junit.Test;
import retrofit2.Converter;

import java.io.IOException;
import java.lang.reflect.Type;
import java.util.List;
import java.util.concurrent.TimeUnit;

public class RestClientTests {
@Test
public void defaultConfigs() {
RestClient restClient = new RestClient.Builder().build();
Assert.assertEquals("https://management.azure.com/", restClient.retrofit().baseUrl().toString());
Assert.assertEquals(LogLevel.NONE, restClient.logLevel());
Assert.assertTrue(restClient.responseBuilderFactory() instanceof ServiceResponseBuilder.Factory);
Assert.assertTrue(restClient.serializerAdapter() instanceof JacksonAdapter);
Assert.assertNull(restClient.credentials());
}

@Test
public void newBuilderKeepsConfigs() {
RestClient restClient = new RestClient.Builder()
.withBaseUrl("http://localhost")
.withCredentials(new TokenCredentials("Bearer", "token"))
.withLogLevel(LogLevel.BASIC)
.withInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
return chain.proceed(chain.request());
}
})
.withUserAgent("user")
.withNetworkInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
return chain.proceed(chain.request());
}
})
.withConnectionTimeout(100, TimeUnit.MINUTES)
.build();
RestClient newClient = restClient.newBuilder().build();
Assert.assertEquals(restClient.retrofit().baseUrl().toString(), newClient.retrofit().baseUrl().toString());
Assert.assertEquals(restClient.logLevel(), newClient.logLevel());
Assert.assertEquals(restClient.logLevel().isPrettyJson(), newClient.logLevel().isPrettyJson());
Assert.assertEquals(restClient.serializerAdapter(), newClient.serializerAdapter());
Assert.assertEquals(restClient.responseBuilderFactory(), newClient.responseBuilderFactory());
Assert.assertEquals(restClient.credentials(), newClient.credentials());
for (Interceptor interceptor :
newClient.httpClient().interceptors()) {
if (interceptor instanceof UserAgentInterceptor) {
Assert.assertEquals("user", ((UserAgentInterceptor) interceptor).userAgent());
}
}
Assert.assertEquals(restClient.httpClient().interceptors().size(), newClient.httpClient().interceptors().size());
Assert.assertEquals(restClient.httpClient().networkInterceptors().size(), newClient.httpClient().networkInterceptors().size());
Assert.assertEquals(TimeUnit.MINUTES.toMillis(100), newClient.httpClient().connectTimeoutMillis());
}

@Test
public void newBuilderClonesProperties() {
RestClient restClient = new RestClient.Builder()
.withBaseUrl("http://localhost")
.withCredentials(new TokenCredentials("Bearer", "token"))
.withLogLevel(LogLevel.BASIC.withPrettyJson(true))
.withInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
return chain.proceed(chain.request());
}
})
.withUserAgent("user")
.withNetworkInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
return chain.proceed(chain.request());
}
})
.withConnectionTimeout(100, TimeUnit.MINUTES)
.build();
RestClient newClient = restClient.newBuilder()
.withBaseUrl("https://contoso.com")
.withCredentials(new BasicAuthenticationCredentials("user", "pass"))
.withLogLevel(LogLevel.BODY_AND_HEADERS)
.withUserAgent("anotheruser")
.withConnectionTimeout(200, TimeUnit.SECONDS)
.withSerializerAdapter(new SerializerAdapter<Object>() {
@Override
public Object serializer() {
return null;
}

@Override
public Converter.Factory converterFactory() {
return JacksonConverterFactory.create();
}

@Override
public String serialize(Object object) throws IOException {
return null;
}

@Override
public String serializeRaw(Object object) {
return null;
}

@Override
public String serializeList(List<?> list, CollectionFormat format) {
return null;
}

@Override
public <U> U deserialize(String value, Type type) throws IOException {
return null;
}
})
.withResponseBuilderFactory(new ResponseBuilder.Factory() {
@Override
public <T, E extends RestException> ResponseBuilder<T, E> newInstance(SerializerAdapter<?> serializerAdapter) {
return null;
}
})
.build();
Assert.assertNotEquals(restClient.retrofit().baseUrl().toString(), newClient.retrofit().baseUrl().toString());
Assert.assertNotEquals(restClient.logLevel(), newClient.logLevel());
Assert.assertNotEquals(restClient.logLevel().isPrettyJson(), newClient.logLevel().isPrettyJson());
Assert.assertNotEquals(restClient.serializerAdapter(), newClient.serializerAdapter());
Assert.assertNotEquals(restClient.responseBuilderFactory(), newClient.responseBuilderFactory());
Assert.assertNotEquals(restClient.credentials(), newClient.credentials());
for (Interceptor interceptor :
restClient.httpClient().interceptors()) {
if (interceptor instanceof UserAgentInterceptor) {
Assert.assertEquals("user", ((UserAgentInterceptor) interceptor).userAgent());
}
}
for (Interceptor interceptor :
newClient.httpClient().interceptors()) {
if (interceptor instanceof UserAgentInterceptor) {
Assert.assertEquals("anotheruser", ((UserAgentInterceptor) interceptor).userAgent());
}
}
Assert.assertNotEquals(restClient.httpClient().connectTimeoutMillis(), newClient.httpClient().connectTimeoutMillis());
}
}

0 comments on commit 4bb09c6

Please sign in to comment.