testable-mock/docs/zh-cn/doc/upgrade-guide.md
2021-11-07 11:06:37 +08:00

3.6 KiB
Raw Blame History

版本升级说明

升级到0.7.x版本

0.7版本重命名了Mock相关的注解和方法以避免命名冲突和由于名字带来的理解歧义包括两部分变化。

  1. 用于验证Mock方法调用的verify()方法与包括com.sun包在内的多个JVM内置静态方法重名在IDE自动添加import时会有误选的情况,该方法在新版本中更名为verifyInvoked(),同时所属的类型更名为InvocationVerifier
  2. 注解@MockMethod@MockConstructor的实际作用是对方法调用和New操作进行Mock而其名称容易使人误解为是对方法和构造器本身进行了Mock在新版本中这两个注解分别已被分别更名为@MockInvoke@MockNew

这些注解和方法的使用与之前版本并无差异,从0.6.x版本升级到0.7.0及以上版本时,请全局替换相关名称即可。

升级到0.6.x版本

0.6版本中,TestableMock提供了快速构造复杂参数对象的能力,同时包含一处与0.5版本不兼容的修改,PrivateAccessor类型的包路径从com.alibaba.testable.core.accessor移到了com.alibaba.testable.core.tool

例如在此前的测试代码中若使用了如下类型引用语句:

import com.alibaba.testable.core.accessor.PrivateAccessor;

当升级TestableMock0.6版本时,请将其修改为:

import com.alibaba.testable.core.tool.PrivateAccessor;

升级到0.5.x版本

0.5版本中,TestableMock解决了此前遗留的三大历史问题:

  1. Mock方法无法调用其他非静态方法。新版中的Mock方法与普通方法不再有任何差别可以访问任意外部方法和成员变量。
  2. Mock方法总是作用于整个测试生命周期。从现在开始Mock方法支持将生效范围限定为所属测试类里的测试用例不用担心跨类测试调用被意外Mock掉了。
  3. 需手工清理MOCK_CONTEXT且只支持类粒度的并行测试。现在每个测试用例拥有了独立的MOCK_CONTEXT变量,无需清理也不会串号,而且可以放心使用任意粒度的并行单元测试啦。

在使用方式上,0.5版本延续了简洁轻量原则同时为了更好的实现Mock方法复用新版本的Mock类与测试类之间有了明确的边界。从0.4版本升级到0.5唯一需要的改变是将测试类中的所有Mock方法使用一个public static class Mock { }包裹起来。

例如,原先有如下测试类定义:

public class DemoMockTest {
    @MockMethod(targetClass = DemoMock.class)
    private String innerFunc(String text) {
        return "hello_" + text;
    }
        
    @Test
    void should_mock_member_method() throws Exception {
        assertEquals("hello_world", demoMock.outerFunc());
        verifyInvoked("innerFunc").with("world");
    }
}

升级为0.5版本后将所有Mock方法此例中只有innerFunc这一个方法)移到一个名称为Mock的静态内部类中,相当于增加两行代码:

public class DemoMockTest {

    public static class Mock {   // 增加此行
        @MockMethod(targetClass = DemoMock.class)
        private String innerFunc(String text) {
            return "hello_" + text;
        }
    }                            // 增加此行
        
    @Test
    void should_mock_member_method() throws Exception {
        assertEquals("hello_world", demoMock.outerFunc());
        verifyInvoked("innerFunc").with("world");
    }
}

然后将pom.xmlbuild.gradle文件中的TestableMock依赖升级到对应的新版本即可。