2020-11-18 11:03:53 +08:00
|
|
|
|
自助问题排查
|
|
|
|
|
---
|
|
|
|
|
|
2020-11-24 23:18:12 +08:00
|
|
|
|
相比Mockito等由开发者手工放置Mock类的做法,TestableMock使用方法名和参数类型匹配自动寻找需Mock的调用。这种机制在带来方便的同时也有可能发生预料之外的Mock替换。
|
|
|
|
|
|
|
|
|
|
若要排查Mock相关的问题,只需在测试类上添加`@MockWith`注解,并配置参数`diagnose`值为`MockDiagnose.ENABLE`,在运行测试时就会打印出详细的Mock方法替换过程。
|
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
@MockWith(diagnose = MockDiagnose.ENABLE)
|
|
|
|
|
class DemoTest {
|
|
|
|
|
...
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
输出日志示例如下:
|
|
|
|
|
|
|
|
|
|
```text
|
|
|
|
|
[DIAGNOSE] Handling test class com/alibaba/testable/demo/DemoMockTest
|
|
|
|
|
[DIAGNOSE] Handling source class com/alibaba/testable/demo/DemoMock
|
|
|
|
|
[DIAGNOSE] Found 7 mock methods
|
|
|
|
|
[DIAGNOSE] Handling method <init>
|
|
|
|
|
[DIAGNOSE] Handling method newFunc
|
|
|
|
|
[DIAGNOSE] Line 14, mock method createBlackBox used
|
|
|
|
|
[DIAGNOSE] Handling method outerFunc
|
|
|
|
|
[DIAGNOSE] Line 22, mock method innerFunc used
|
|
|
|
|
[DIAGNOSE] Handling method commonFunc
|
|
|
|
|
[DIAGNOSE] Line 29, mock method trim used
|
|
|
|
|
[DIAGNOSE] Line 29, mock method sub used
|
|
|
|
|
[DIAGNOSE] Line 29, mock method startsWith used
|
|
|
|
|
[DIAGNOSE] Handling method getBox
|
|
|
|
|
[DIAGNOSE] Line 36, mock method secretBox used
|
|
|
|
|
[DIAGNOSE] Handling method callerOne
|
|
|
|
|
[DIAGNOSE] Line 43, mock method callFromDifferentMethod used
|
|
|
|
|
[DIAGNOSE] Handling method callerTwo
|
|
|
|
|
[DIAGNOSE] Line 47, mock method callFromDifferentMethod used
|
|
|
|
|
[DIAGNOSE] Handling method innerFunc
|
|
|
|
|
[DIAGNOSE] Handling method callFromDifferentMethod
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
该日志展示了被测类中所有发生了Mock替换的调用和相应代码行号。
|