我编写了一个类来管理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中调用? 所以我的问题是,为什么这种方法不能按预期工作,这样做的正确方法是什么?
答案 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(上述作业仍然有效)