Class FakeHttpLayer
java.lang.Object
org.robolectric.shadows.httpclient.FakeHttpLayer
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
static class
static class
static class
static class
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addHttpResponse
(org.apache.http.HttpResponse response) As a consumer of the fake http call, you should never call this method.void
addHttpResponseContent
(byte[] content) void
addHttpResponseRule
(String uri, String response) void
addHttpResponseRule
(String method, String uri, org.apache.http.HttpResponse response) void
addHttpResponseRule
(String uri, org.apache.http.HttpResponse response) void
addHttpResponseRule
(HttpEntityStub.ResponseRule responseRule) void
addHttpResponseRule
(RequestMatcher requestMatcher, List<? extends org.apache.http.HttpResponse> responses) Add a response rule.void
addHttpResponseRule
(RequestMatcher requestMatcher, org.apache.http.HttpResponse response) void
addPendingHttpResponse
(int statusCode, String responseBody, org.apache.http.Header... headers) void
addPendingHttpResponse
(org.apache.http.HttpResponse httpResponse) void
addPendingHttpResponse
(HttpResponseGenerator httpResponseGenerator) void
addRequestInfo
(HttpRequestInfo requestInfo) This method is not supposed to be consumed by tests.void
void
Call this method if you want to ensure that there's no http responses logged from this point until the next response arrives.void
void
org.apache.http.HttpResponse
emulateRequest
(org.apache.http.HttpHost httpHost, org.apache.http.HttpRequest httpRequest, org.apache.http.protocol.HttpContext httpContext, org.apache.http.client.RequestDirector requestDirector) List<org.apache.http.HttpResponse>
This method return a list containing all the HTTP responses logged by the fake http layer, be it mocked http responses, be it real http calls (if {code}interceptHttpRequests{/code} is set to false).List<byte[]>
org.apache.http.HttpResponse
Helper method that returns the latest received response from the server.getSentHttpRequestInfo
(int index) boolean
boolean
boolean
boolean
void
interceptHttpRequests
(boolean interceptHttpRequests) You can disable Robolectric's fake HTTP layer temporarily by calling this method.void
interceptResponseContent
(boolean interceptResponseContent) boolean
boolean
void
void
setDefaultHttpResponse
(int statusCode, String responseBody) void
setDefaultHttpResponse
(org.apache.http.HttpResponse defaultHttpResponse) void
silence()
-
Constructor Details
-
FakeHttpLayer
public FakeHttpLayer()
-
-
Method Details
-
getLastSentHttpRequestInfo
-
addPendingHttpResponse
public void addPendingHttpResponse(int statusCode, String responseBody, org.apache.http.Header... headers) -
addPendingHttpResponse
public void addPendingHttpResponse(org.apache.http.HttpResponse httpResponse) -
addPendingHttpResponse
-
addHttpResponseRule
-
addHttpResponseRule
-
addHttpResponseRule
-
addHttpResponseRule
public void addHttpResponseRule(RequestMatcher requestMatcher, org.apache.http.HttpResponse response) -
addHttpResponseRule
public void addHttpResponseRule(RequestMatcher requestMatcher, List<? extends org.apache.http.HttpResponse> responses) Add a response rule.- Parameters:
requestMatcher
- Request matcherresponses
- A list of responses that are returned to matching requests in order from first to last.
-
addHttpResponseRule
-
setDefaultHttpResponse
public void setDefaultHttpResponse(org.apache.http.HttpResponse defaultHttpResponse) -
setDefaultHttpResponse
-
emulateRequest
public org.apache.http.HttpResponse emulateRequest(org.apache.http.HttpHost httpHost, org.apache.http.HttpRequest httpRequest, org.apache.http.protocol.HttpContext httpContext, org.apache.http.client.RequestDirector requestDirector) throws org.apache.http.HttpException, IOException - Throws:
org.apache.http.HttpException
IOException
-
hasPendingResponses
public boolean hasPendingResponses() -
hasRequestInfos
public boolean hasRequestInfos() -
clearRequestInfos
public void clearRequestInfos() -
addRequestInfo
This method is not supposed to be consumed by tests. This exists solely for the purpose of logging real HTTP requests, so that functional/integration tests can verify if those were made, without messing with the fake http layer to actually perform the http call, instead of returning a mocked response. If you are just using mocked http calls, you should not even notice this method here.- Parameters:
requestInfo
- Request info object to add.
-
hasResponseRules
public boolean hasResponseRules() -
hasRequestMatchingRule
-
getSentHttpRequestInfo
-
getNextSentHttpRequestInfo
-
logHttpRequests
public void logHttpRequests() -
silence
public void silence() -
getSentHttpRequestInfos
-
clearHttpResponseRules
public void clearHttpResponseRules() -
clearPendingHttpResponses
public void clearPendingHttpResponses() -
getHttpResponses
This method return a list containing all the HTTP responses logged by the fake http layer, be it mocked http responses, be it real http calls (if {code}interceptHttpRequests{/code} is set to false). It doesn't make much sense to call this method if said property is set to true, as you yourself are providing the response, but it's here nonetheless.- Returns:
- List of all HTTP Responses logged by the fake http layer.
-
addHttpResponse
public void addHttpResponse(org.apache.http.HttpResponse response) As a consumer of the fake http call, you should never call this method. This should be used solely by components that exercises http calls.- Parameters:
response
- The final response received by the server
-
addHttpResponseContent
public void addHttpResponseContent(byte[] content) -
getHttpResposeContentList
-
getLastHttpResponse
public org.apache.http.HttpResponse getLastHttpResponse()Helper method that returns the latest received response from the server.- Returns:
- The latest HTTP response or null, if no responses are available
-
clearHttpResponses
public void clearHttpResponses()Call this method if you want to ensure that there's no http responses logged from this point until the next response arrives. Helpful to ensure that the state is "clear" before actions are executed. -
interceptHttpRequests
public void interceptHttpRequests(boolean interceptHttpRequests) You can disable Robolectric's fake HTTP layer temporarily by calling this method.- Parameters:
interceptHttpRequests
- whether all HTTP requests should be intercepted (true by default)
-
isInterceptingHttpRequests
public boolean isInterceptingHttpRequests() -
interceptResponseContent
public void interceptResponseContent(boolean interceptResponseContent) -
isInterceptingResponseContent
public boolean isInterceptingResponseContent()
-