1 /*
2  * Copyright (c) 2007 Mockito contributors
3  * This program is made available under the terms of the MIT License.
4  */
5 package org.mockito.internal.debugging;
6 
7 import org.junit.After;
8 import org.junit.Before;
9 import org.junit.Test;
10 import org.mockito.internal.handler.NotifiedMethodInvocationReport;
11 import org.mockito.internal.invocation.InvocationBuilder;
12 import org.mockito.internal.invocation.StubInfoImpl;
13 import org.mockito.invocation.DescribedInvocation;
14 import org.mockito.invocation.Invocation;
15 
16 import java.io.ByteArrayOutputStream;
17 import java.io.PrintStream;
18 
19 import static org.assertj.core.api.Assertions.assertThat;
20 
21 public class VerboseMockInvocationLoggerTest {
22 
23     private VerboseMockInvocationLogger listener;
24 
25     private ByteArrayOutputStream output;
26     private Invocation invocation = new InvocationBuilder().toInvocation();
27     private DescribedInvocation stubbedInvocation = new InvocationBuilder().toInvocation();
28 
29     @Before
init_Listener()30     public void init_Listener() throws Exception {
31         output = new ByteArrayOutputStream();
32         listener = new VerboseMockInvocationLogger(new PrintStream(output));
33     }
34 
35     @After
tearDown()36     public void tearDown() throws Exception {
37         System.out.println(output);
38     }
39 
40     @Test
should_print_to_system_out()41     public void should_print_to_system_out() {
42         assertThat(new VerboseMockInvocationLogger().printStream).isSameAs(System.out);
43     }
44 
45     @Test
should_print_invocation_with_return_value()46     public void should_print_invocation_with_return_value() {
47         // when
48         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, "return value"));
49 
50         // then
51         assertThat(printed())
52                 .contains(invocation.toString())
53                 .contains(invocation.getLocation().toString())
54                 .contains("return value");
55     }
56 
57     @Test
should_print_invocation_with_exception()58     public void should_print_invocation_with_exception() {
59         // when
60         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, new ThirdPartyException()));
61 
62         // then
63         assertThat(printed())
64                 .contains(invocation.toString())
65                 .contains(invocation.getLocation().toString())
66                 .contains(ThirdPartyException.class.getName());
67     }
68 
69     @Test
should_print_if_method_has_not_been_stubbed()70     public void should_print_if_method_has_not_been_stubbed() throws Exception {
71         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, "whatever"));
72 
73         assertThat(printed()).doesNotContain("stubbed");
74     }
75 
76     @Test
should_print_stubbed_info_if_available()77     public void should_print_stubbed_info_if_available() throws Exception {
78         invocation.markStubbed(new StubInfoImpl(stubbedInvocation));
79 
80         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, "whatever"));
81 
82         assertThat(printed())
83                 .contains("stubbed")
84                 .contains(stubbedInvocation.getLocation().toString());
85     }
86 
87     @Test
should_log_count_of_interactions()88     public void should_log_count_of_interactions() {
89         // when & then
90         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, new ThirdPartyException()));
91         assertThat(printed()).contains("#1");
92 
93         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, new ThirdPartyException()));
94         assertThat(printed()).contains("#2");
95 
96         listener.reportInvocation(new NotifiedMethodInvocationReport(invocation, new ThirdPartyException()));
97         assertThat(printed()).contains("#3");
98     }
99 
printed()100     private String printed() {
101         return output.toString();
102     }
103 
104     private static class ThirdPartyException extends Exception {
105         private static final long serialVersionUID = 3022739107688491354L;
106     }
107 }
108