Java程序  |  82行  |  3.68 KB

package org.mockitousage.debugging;

import org.junit.Assert;
import org.junit.Test;
import org.mockito.Mock;
import org.mockito.internal.debugging.InvocationsPrinter;
import org.mockitousage.IMethods;
import org.mockitoutil.TestBase;

import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.when;

public class InvocationsPrinterTest extends TestBase {

    @Mock IMethods mock;

    @Test public void no_invocations() {
        assertThat(new InvocationsPrinter().printInvocations(mock)).isEqualTo("No interactions and stubbings found for mock: mock");
    }

    @Test public void prints_invocations() {
        mock.simpleMethod(100);
        triggerInteraction();

        assertThat(filterLineNo(new InvocationsPrinter().printInvocations(mock)))
                .isEqualTo(filterLineNo("[Mockito] Interactions of: mock\n" +
                        " 1. mock.simpleMethod(100);\n" +
                        "  -> at org.mockitousage.debugging.InvocationsPrinterTest.prints_invocations(InvocationsPrinterTest.java:0)\n" +
                        " 2. mock.otherMethod();\n" +
                        "  -> at org.mockitousage.debugging.InvocationsPrinterTest.triggerInteraction(InvocationsPrinterTest.java:0)\n"));
    }

    @Test public void prints_stubbings() {
        triggerStubbing();

        assertThat(filterLineNo(new InvocationsPrinter().printInvocations(mock)))
                .isEqualTo(filterLineNo("[Mockito] Unused stubbings of: mock\n" +
                        " 1. mock.simpleMethod(\"a\");\n" +
                        "  - stubbed -> at org.mockitousage.debugging.InvocationsPrinterTest.triggerStubbing(InvocationsPrinterTest.java:70)\n"));
    }

    @Test public void prints_invocations_and_stubbings() {
        triggerStubbing();

        mock.simpleMethod("a");
        triggerInteraction();

        assertThat(filterLineNo(new InvocationsPrinter().printInvocations(mock)))
                .isEqualTo(filterLineNo("[Mockito] Interactions of: mock\n" +
                        " 1. mock.simpleMethod(\"a\");\n" +
                        "  -> at org.mockitousage.debugging.InvocationsPrinterTest.prints_invocations_and_stubbings(InvocationsPrinterTest.java:49)\n" +
                        "   - stubbed -> at org.mockitousage.debugging.InvocationsPrinterTest.triggerStubbing(InvocationsPrinterTest.java:73)\n" +
                        " 2. mock.otherMethod();\n" +
                        "  -> at org.mockitousage.debugging.InvocationsPrinterTest.triggerInteraction(InvocationsPrinterTest.java:34)\n"));
    }

    @Test public void prints_invocations_and_unused_stubbings() {
        triggerStubbing();

        mock.simpleMethod("b");
        triggerInteraction();

        assertThat(filterLineNo(new InvocationsPrinter().printInvocations(mock)))
                .isEqualTo(filterLineNo("[Mockito] Interactions of: mock\n" +
                        " 1. mock.simpleMethod(\"b\");\n" +
                        "  -> at org.mockitousage.debugging.InvocationsPrinterTest.prints_invocations_and_unused_stubbings(InvocationsPrinterTest.java:55)\n" +
                        " 2. mock.otherMethod();\n" +
                        "  -> at org.mockitousage.debugging.InvocationsPrinterTest.triggerInteraction(InvocationsPrinterTest.java:34)\n" +
                        "[Mockito] Unused stubbings of: mock\n" +
                        " 1. mock.simpleMethod(\"a\");\n" +
                        "  - stubbed -> at org.mockitousage.debugging.InvocationsPrinterTest.triggerStubbing(InvocationsPrinterTest.java:62)\n"));
    }

    private void triggerInteraction() {
        mock.otherMethod();
    }

    private void triggerStubbing() {
        when(mock.simpleMethod("a")).thenReturn("x");
    }
}