Stub setup on spy object cause real method to execute in HttpComponent/HttpClient

562 views
Skip to first unread message

mocked-avatar

unread,
Dec 11, 2013, 3:59:38 PM12/11/13
to moc...@googlegroups.com
Hi,

It seems that when setting up the stub with the correct doReturn/when/method pattern still cause the real method to be invoked when doing it to Apache HttpComponent/HttpClient. I have the full example that shows the problem. Please advice. Thanks.

    java.lang.IllegalArgumentException: Request must not be null.
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:801)
    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:784)
    at SpyTest.setupClient(SpyTest.java:37)


the codes

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.StatusLine;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.mockito.invocation.InvocationOnMock;
import org.mockito.stubbing.Answer;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;

import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

import static org.mockito.Mockito.*;

public class SpyTest {
    HttpClient httpClient;
    private HttpResponse httpResponse;
    private StatusLine responseStatus;
    private HttpEntity responseEntity;

    @BeforeMethod
    public void setupClient() throws Exception {
        List spy = spy(new ArrayList());
        doReturn(true).when(spy).addAll(any(Collection.class)); // this works!

        DefaultHttpClient directClient = new DefaultHttpClient();
        httpClient = spy(directClient);
        httpResponse = mock(HttpResponse.class);
        responseStatus = mock(StatusLine.class);
        responseEntity = mock(HttpEntity.class);
        doReturn(responseStatus).when(httpResponse).getStatusLine();
        doReturn(responseEntity).when(httpResponse).getEntity();
        doReturn(httpResponse).when(httpClient).execute(any(HttpPost.class)); // failing here
    }

    @Test
    public void itShouldSetupTheSpy() throws Exception {
        doReturn(200).when(responseStatus).getStatusCode();
        doReturn("OK").when(responseStatus).getReasonPhrase();
        doAnswer(new Answer() {
            @Override
            public Object answer(InvocationOnMock invocation) throws Throwable {
                OutputStream os = (OutputStream) invocation.getArguments()[0];
                os.write("{\"id\": 100}".getBytes());
                return null;
            }
        }).when(responseEntity).writeTo(any(OutputStream.class));
    }
}

and the maven dependency:tree

[INFO] +- org.codehaus.jackson:jackson-mapper-asl:jar:1.9.3:compile
[INFO] | \- org.codehaus.jackson:jackson-core-asl:jar:1.9.3:compile
[INFO] +- org.testng:testng:jar:6.8:test
[INFO] | +- junit:junit:jar:4.10:test
[INFO] | | \- org.hamcrest:hamcrest-core:jar:1.1:test
[INFO] | +- org.beanshell:bsh:jar:2.0b4:test
[INFO] | +- com.beust:jcommander:jar:1.27:test
[INFO] | \- org.yaml:snakeyaml:jar:1.6:test
[INFO] +- org.mockito:mockito-all:jar:1.9.5:test
[INFO] +- com.newrelic:newrelic-api:jar:2.3.0:compile
[INFO] +- org.apache.httpcomponents:httpclient:jar:4.2.5:compile
[INFO] | +- org.apache.httpcomponents:httpcore:jar:4.2.4:compile
[INFO] | +- commons-logging:commons-logging:jar:1.1.1:compile
[INFO] | \- commons-codec:commons-codec:jar:1.6:compile
[INFO] \- org.apache.commons:commons-lang3:jar:3.1:compile

KARR, DAVID

unread,
Dec 11, 2013, 8:42:07 PM12/11/13
to moc...@googlegroups.com

If that “execute()” method is final, Mockito will silently fail to stub it.  You would have to use PowerMock in that case.

 

--
You received this message because you are subscribed to the Google Groups "mockito" group.
To unsubscribe from this group and stop receiving emails from it, send an email to mockito+u...@googlegroups.com.
To post to this group, send email to moc...@googlegroups.com.
Visit this group at http://groups.google.com/group/mockito.
For more options, visit https://groups.google.com/groups/opt_out.

mocked-avatar

unread,
Dec 12, 2013, 12:40:33 PM12/12/13
to moc...@googlegroups.com
Yes, that's indeed the case! I was looking at the interface method and forgot to check the implementation.

Thanks
Reply all
Reply to author
Forward
0 new messages