《Java单元测试实战》——编写技巧:Java单元测试技巧之JSON序列化(2) https://developer.aliyun.com/article/1232286?groupCode=java
三、 测试用例及资源命名
俗话说:“没有规矩,不成方圆。”所以,为了更好地利用JSON序列化技巧,首先对测试用例和资源文件进行规范化命名。
1. 测试类命名
按照行业惯例,测试类的命名应以被测试类名开头并以Test结尾。比如:UserService(用户服务类)的测试类需要命名为UserServiceTest(用户服务测试类)。
单元测试类应该放在被测试类的同一工程的"src/test/java"目录下,并且要放在被测试类的同一包下。注意,单元测试类不允许写在业务代码目录下,否则在编译时没法过滤这些测试用例。
2. 测试方法命名
按照行业规范,测试方法命名应以test开头并以被测试方法结尾。比如:batchCreate(批量创建)的测试方法需要命名为testBatchCreate(测试:批量创建),queryByCompanyId(根据公司标识查询)的测试方法需要命名为testQueryByCompanyId(测试:根据公司标识查询)。
当一个方法对应多个测试用例时,就需要创建多个测试方法,原有测试方法命名已经不能满足需求了。有人建议在原有的测试方法命名的基础上,添加123等序号表示不同的用例。比如:testBatchCreate1(测试:批量创建1)、testBatchCreate2(测试:批量创建2)……但是,这种方法不能明确每个单元测试的用意。
这里,作者建议在原有的测试方法命名的基础上,添加”With+条件“来表达不同的测试用例方法。
1) 按照结果命名
• testBatchCreateWithSuccess(测试:批量创建-成功)
• testBatchCreateWithFailure(测试:批量创建-失败)
• testBatchCreateWithException(测试:批量创建-异常)
2) 按照参数命名
• testBatchCreateWithListNull(测试:批量创建-列表为NULL)
• testBatchCreateWithListEmpty(测试:批量创建-列表为空)
• testBatchCreateWithListNotEmpty(测试:批量创建-列表不为空)
3) 按照意图命名
• testBatchCreateWithNormal(测试:批量创建-正常)
• testBatchCreateWithGray(测试:批量创建-灰度)
• testBatchCreateWithException(测试:批量创建-异常)
当然,还有形成其它的测试方法命名方式,也可以把不同的测试方法命名方式混用,只要能清楚地表达出这个测试用例的涵义即可。
《Java单元测试实战》——编写技巧:Java单元测试技巧之JSON序列化(4) https://developer.aliyun.com/article/1232284?groupCode=java