Android - 如何使用mockito

时间:2016-02-05 06:16:28

标签: android junit mockito powermock

我编写了一个类来管理android应用程序项目中的日志记录。 LogManager基本上是android.util.log的包装器 如果应用程序崩溃,它会处理对文件的记录,以及标准的调试日志记录。 我想使用JUnit对该类进行单元测试。

我尝试了以下内容,但在阅读这些示例后,它似乎没有产生我期望的结果:

LogManager.class(这是我用过的类的简化版本,用于演示目的)

public class LogManager implements ILogManager
{
     public void log(String tag, String message)
     {
           Log.e(tag, message);
     }
}

这是我的测试类

@RunWith(RobolectricGradleTestRunner.class)
@Config(constants = BuildConfig.class, sdk = 21)
@PrepareForTest({Log.class, LogManager.class})
public class LogManagerUnitTest
{

    @Test
    public void testLogConsoleInfo()
    {
        PowerMockito.mockStatic(Log.class);

        LogManager.getInstance().log(LogLevel.INFO, "test", "test");

        PowerMockito.verifyStatic(Mockito.times(1));
        Log.e(anyString(), anyString());
    }
}

我的问题是,无论我放什么,这都会通过。 例如:如果我用Log.wtf(...)代替最后一次调用,它仍会通过。我会假设它应该失败,因为Log.wtf没有在静态类Log中调用? 所以我的问题是,为什么这种方法不能按预期工作,这样做的正确方法是什么?

2 个答案:

答案 0 :(得分:6)

我开始了一个新项目,并且能够让它失败测试并使用以下方法成功,所以我假设runwith是罪魁祸首:

@RunWith(PowerMockRunner.class)
@PrepareForTest(android.util.Log.class) 
public class LoggerUnitTest {
    @Test
    public void testLog() throws Exception
    {
        PowerMockito.mockStatic(Log.class); //        when(Log.e(anyString(), anyString())).thenReturn(1);

        Logger.log("test", "test");

        PowerMockito.verifyStatic(times(1));
        Log.e(anyString(), anyString());
    } }

答案 1 :(得分:0)

对于RobolectricGradleTestRunner,以下咒语会暴露您的日志记录: ShadowLog.stream = System.out 默认情况下,Robolectric不会打印Android系统日志记录。

还值得注意的是RobolectricGradleTestRunner已被弃用,而不是fully operational RobolectricTestRunner(上述作业仍然有效)