Java程序  |  123行  |  4.61 KB

package org.mockitousage.junitrunner;

import org.junit.Test;
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.exceptions.misusing.UnfinishedStubbingException;
import org.mockito.internal.util.SimpleMockitoLogger;
import org.mockito.junit.TestableJUnitRunner;
import org.mockitousage.IMethods;
import org.mockitoutil.TestBase;

import static org.junit.Assert.assertEquals;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import static org.mockitoutil.JUnitResultAssert.assertThat;

public class StubbingWarningsJUnitRunnerTest extends TestBase {

    JUnitCore runner = new JUnitCore();
    SimpleMockitoLogger logger = TestableJUnitRunner.refreshedLogger();

    @Test public void no_arg_mismatch_warnings() {
        //when
        runner.run(PassingArgMismatch.class, FailingWithMatchingArgs.class, MismatchButStubAlreadyUsed.class);

        //then
        assertEquals("", filterLineNo(logger.getLoggedInfo()));
    }

    @Test public void shows_arg_mismatch_warnings_when_test_fails() {
        //when
        runner.run(FailingWithArgMismatch.class);

        //then
        assertEquals("[MockitoHint] FailingWithArgMismatch.test (see javadoc for MockitoHint):\n" +
                "[MockitoHint] 1. Unused... -> at org.mockitousage.junitrunner.StubbingWarningsJUnitRunnerTest$FailingWithArgMismatch.test(StubbingWarningsJUnitRunnerTest.java:0)\n" +
                "[MockitoHint]  ...args ok? -> at org.mockitousage.junitrunner.StubbingWarningsJUnitRunnerTest$FailingWithArgMismatch.test(StubbingWarningsJUnitRunnerTest.java:0)\n", filterLineNo(logger.getLoggedInfo()));
    }

    @Test public void shows_arg_mismatch_warnings_only_for_mismatches() {
        //when
        runner.run(FailingWithSomeStubMismatches.class);

        //then
        assertEquals("[MockitoHint] FailingWithSomeStubMismatches.test (see javadoc for MockitoHint):\n" +
                "[MockitoHint] 1. Unused... -> at org.mockitousage.junitrunner.StubbingWarningsJUnitRunnerTest$FailingWithSomeStubMismatches.test(StubbingWarningsJUnitRunnerTest.java:0)\n" +
                "[MockitoHint]  ...args ok? -> at org.mockitousage.junitrunner.StubbingWarningsJUnitRunnerTest$FailingWithSomeStubMismatches.test(StubbingWarningsJUnitRunnerTest.java:0)\n", filterLineNo(logger.getLoggedInfo()));
    }

    @Test public void validates_mockito_usage() {
        //when
        Result result = runner.run(InvalidMockitoUsage.class);

        //then
        assertThat(result).fails(1, UnfinishedStubbingException.class);
    }

    @RunWith(TestableJUnitRunner.class)
    public static class PassingArgMismatch {
        IMethods mock = mock(IMethods.class);
        @Test public void test() throws Exception {
            when(mock.simpleMethod(1)).thenReturn("1");
            mock.simpleMethod(2);
        }
    }

    @RunWith(TestableJUnitRunner.class)
    public static class FailingWithArgMismatch {
        @Mock IMethods mock;
        @Test public void test() throws Exception {
            when(mock.simpleMethod(1)).thenReturn("1");
            mock.simpleMethod(2);
            throw new RuntimeException("x");
        }
    }

    @RunWith(TestableJUnitRunner.class)
    public static class FailingWithMatchingArgs {
        @Mock IMethods mock;
        @Test public void test() throws Exception {
            when(mock.simpleMethod(1)).thenReturn("1");
            mock.simpleMethod(1);
            throw new RuntimeException("x");
        }
    }

    @RunWith(TestableJUnitRunner.class)
    public static class FailingWithSomeStubMismatches {
        @Mock IMethods mock;
        @Test public void test() throws Exception {
            when(mock.simpleMethod(1)).thenReturn("1"); // <- used
            when(mock.simpleMethod(2)).thenReturn("2"); // <- unused

            mock.simpleMethod(1); // <- not reported
            mock.simpleMethod(3); // <- reported

            throw new RuntimeException("x");
        }
    }

    @RunWith(TestableJUnitRunner.class)
    public static class MismatchButStubAlreadyUsed {
        @Mock IMethods mock;
        @Test public void test() throws Exception {
            when(mock.simpleMethod(1)).thenReturn("1");
            mock.simpleMethod(1); // <-- used
            mock.simpleMethod(2); // <-- arg mismatch, but the stub was already used

            throw new RuntimeException("x");
        }
    }

    @RunWith(TestableJUnitRunner.class)
    public static class InvalidMockitoUsage {
        @Mock IMethods mock;
        @Test public void test() throws Exception {
            when(mock.simpleMethod()); // <-- unfinished stubbing
        }
    }
}