implement okhttp response caching
based on patch from: Baldur Gudbjornsson <baldur.gudbjornsson@gmail.com>
This commit is contained in:
@@ -3,6 +3,7 @@ package org.oscim.tiling.source;
|
|||||||
import static org.fest.assertions.api.Assertions.assertThat;
|
import static org.fest.assertions.api.Assertions.assertThat;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
|
|
||||||
@@ -12,6 +13,7 @@ import org.junit.Test;
|
|||||||
import org.oscim.core.Tile;
|
import org.oscim.core.Tile;
|
||||||
import org.oscim.tiling.source.oscimap4.OSciMap4TileSource;
|
import org.oscim.tiling.source.oscimap4.OSciMap4TileSource;
|
||||||
|
|
||||||
|
import com.squareup.okhttp.HttpResponseCache;
|
||||||
import com.squareup.okhttp.mockwebserver.MockResponse;
|
import com.squareup.okhttp.mockwebserver.MockResponse;
|
||||||
import com.squareup.okhttp.mockwebserver.MockWebServer;
|
import com.squareup.okhttp.mockwebserver.MockWebServer;
|
||||||
import com.squareup.okhttp.mockwebserver.RecordedRequest;
|
import com.squareup.okhttp.mockwebserver.RecordedRequest;
|
||||||
@@ -20,6 +22,7 @@ public class OkHttpEngineTest {
|
|||||||
private OkHttpEngine engine;
|
private OkHttpEngine engine;
|
||||||
private MockWebServer server;
|
private MockWebServer server;
|
||||||
private MockResponse mockResponse;
|
private MockResponse mockResponse;
|
||||||
|
private HttpResponseCache cache;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
@@ -87,4 +90,15 @@ public class OkHttpEngineTest {
|
|||||||
assertThat(engine.requestCompleted(true)).isTrue();
|
assertThat(engine.requestCompleted(true)).isTrue();
|
||||||
assertThat(engine.requestCompleted(false)).isFalse();
|
assertThat(engine.requestCompleted(false)).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void create_shouldUseTileSourceCache() throws Exception {
|
||||||
|
cache = new HttpResponseCache(new File("tmp"), 1024);
|
||||||
|
OSciMap4TileSource tileSource =
|
||||||
|
new OSciMap4TileSource(server.getUrl("/tiles/vtm").toString());
|
||||||
|
engine = (OkHttpEngine) new OkHttpEngine.OkHttpFactory(cache).create(tileSource);
|
||||||
|
engine.sendRequest(new Tile(1, 2, new Integer(3).byteValue()));
|
||||||
|
engine.requestCompleted(true);
|
||||||
|
assertThat(cache.getRequestCount()).isEqualTo(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -27,10 +27,15 @@ import java.util.Map.Entry;
|
|||||||
|
|
||||||
import org.oscim.core.Tile;
|
import org.oscim.core.Tile;
|
||||||
import org.oscim.utils.IOUtils;
|
import org.oscim.utils.IOUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import com.squareup.okhttp.HttpResponseCache;
|
||||||
import com.squareup.okhttp.OkHttpClient;
|
import com.squareup.okhttp.OkHttpClient;
|
||||||
|
|
||||||
public class OkHttpEngine implements HttpEngine {
|
public class OkHttpEngine implements HttpEngine {
|
||||||
|
static final Logger log = LoggerFactory.getLogger(OkHttpEngine.class);
|
||||||
|
|
||||||
private final OkHttpClient mClient;
|
private final OkHttpClient mClient;
|
||||||
private final UrlTileSource mTileSource;
|
private final UrlTileSource mTileSource;
|
||||||
|
|
||||||
@@ -41,6 +46,11 @@ public class OkHttpEngine implements HttpEngine {
|
|||||||
mClient = new OkHttpClient();
|
mClient = new OkHttpClient();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public OkHttpFactory(HttpResponseCache responseCache) {
|
||||||
|
mClient = new OkHttpClient();
|
||||||
|
mClient.setResponseCache(responseCache);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public HttpEngine create(UrlTileSource tileSource) {
|
public HttpEngine create(UrlTileSource tileSource) {
|
||||||
return new OkHttpEngine(mClient, tileSource);
|
return new OkHttpEngine(mClient, tileSource);
|
||||||
@@ -95,7 +105,7 @@ public class OkHttpEngine implements HttpEngine {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setCache(OutputStream os) {
|
public void setCache(OutputStream os) {
|
||||||
// TODO: Evaluate OkHttp response cache and determine if additional caching is required.
|
// OkHttp cache implented through tileSource setResponseCache
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
Reference in New Issue
Block a user