diff --git a/AndroidAsync/src/com/koushikdutta/async/http/AsyncHttpRequest.java b/AndroidAsync/src/com/koushikdutta/async/http/AsyncHttpRequest.java index 212d98cda9a58e830d0488d079ab5f21da5c4862..3a6fab5cc9eb56435a3b37f227096a6e910d5ef6 100644 --- a/AndroidAsync/src/com/koushikdutta/async/http/AsyncHttpRequest.java +++ b/AndroidAsync/src/com/koushikdutta/async/http/AsyncHttpRequest.java @@ -34,7 +34,7 @@ public class AsyncHttpRequest { @Override public String toString() { - String path = AsyncHttpRequest.this.getUri().getPath(); + String path = AsyncHttpRequest.this.getUri().getRawPath(); if (path.length() == 0) path = "/"; String query = AsyncHttpRequest.this.getUri().getRawQuery(); diff --git a/AndroidAsyncTest/src/com/koushikdutta/async/test/HttpClientTests.java b/AndroidAsyncTest/src/com/koushikdutta/async/test/HttpClientTests.java index 1817cebaac4d704cf4cceb0fe27c41d5b9512a32..f39246a0c494c6249ff8f868794c68045078b9f4 100644 --- a/AndroidAsyncTest/src/com/koushikdutta/async/test/HttpClientTests.java +++ b/AndroidAsyncTest/src/com/koushikdutta/async/test/HttpClientTests.java @@ -10,12 +10,9 @@ import com.koushikdutta.async.callback.CompletedCallback; import com.koushikdutta.async.callback.DataCallback; import com.koushikdutta.async.future.Future; import com.koushikdutta.async.future.FutureCallback; -import com.koushikdutta.async.http.AsyncHttpClient; +import com.koushikdutta.async.http.*; import com.koushikdutta.async.http.AsyncHttpClient.DownloadCallback; import com.koushikdutta.async.http.AsyncHttpClient.StringCallback; -import com.koushikdutta.async.http.AsyncHttpGet; -import com.koushikdutta.async.http.AsyncHttpResponse; -import com.koushikdutta.async.http.ResponseCacheMiddleware; import com.koushikdutta.async.http.callback.HttpConnectCallback; import com.koushikdutta.async.http.server.AsyncHttpServer; import com.koushikdutta.async.http.server.AsyncHttpServerRequest; @@ -26,6 +23,7 @@ import junit.framework.Assert; import junit.framework.TestCase; import java.io.File; +import java.net.URI; import java.util.concurrent.CancellationException; import java.util.concurrent.ExecutionException; import java.util.concurrent.Semaphore; @@ -330,4 +328,10 @@ public class HttpClientTests extends TestCase { proxyServer.stop(); } } + + public void testUriPathWithSpaces() throws Exception { + AsyncHttpRequest request = new AsyncHttpRequest(URI.create("http://jpkc.seiee.sjtu.edu.cn/ds/ds2/Course%20lecture/chapter%2010.pdf"), AsyncHttpGet.METHOD); + String requestLine = request.getRequestLine().toString(); + assertEquals("GET /ds/ds2/Course%20lecture/chapter%2010.pdf HTTP/1.1", requestLine); + } }