测试数据修改
使用占位符来替代参数,可以在代码中动态修改它的值。
修改前测试参数:
{"mobile_phone":"13212332111","pwd":"12345678"}
测试参数
{"mobile_phone":"${register_md}","pwd":"${register_pwd}"}
测试SQL
["select count(*) from member a where a.mobile_phone = '${register_mb}';"]
Maven导入测试数据生成
com.github.binarywang
java-testdata-generator
1.1.2
随机测试参数生成
package com.zhongxin.utils;
import cn.binarywang.tools.generator.ChineseMobileNumberGenerator;
import java.util.HashMap;
import java.util.Map;
public class UserData{
// 存储接口响应对象
public static Map VARS = new HashMap<>();
// 存储默认请求头
public static Map DEFAULT_HEADERS = new HashMap<>();
static {
// 静态代码:类在加载时会自动加载一次此代码
DEFAULT_HEADERS.put("X-Lemonban-Media-Type", "lemonban.v2");
DEFAULT_HEADERS.put("Content-Type", "application/json");
// 把需要参数化的数据存储到VARS
// 随机手机号码
VARS.put("${register_mb}", ChineseMobileNumberGenerator.getInstance().generate());
VARS.put("${register_pwd}", "12345678");
VARS.put("${amount}", "5000");
}
}
测试前的参数替换
public void paramsReplace(CaseInfo caseInfo){
Set keySet = UserData.VARS.keySet();
String params = caseInfo.getParams();
String sql = caseInfo.getSql();
String expectedResult = caseInfo.getExpectedResult();
String url = caseInfo.getUrl();
for (String placeHolder : keySet) {
String value = UserData.VARS.get(placeHolder).toString();
if (StringUtils.isNotBlank(params)) {
params = params.replace(placeHolder, value);
}
if (StringUtils.isNotBlank(sql)) {
sql = sql.replace(placeHolder, value);
}
if (StringUtils.isNotBlank(expectedResult)) {
expectedResult = expectedResult.replace(placeHolder, value);
}
if (StringUtils.isNotBlank(url)) {
url = url.replace(placeHolder, value);
}
}
caseInfo.setParams(params);
caseInfo.setSql(sql);
caseInfo.setExpectedResult(expectedResult);
caseInfo.setUrl(url);
}
Maven中导入异常排除
cn.afterturn
easypoi-base
4.0.0
org.apache.commons
commons-lang3
使用常量替代
final修饰变量,变量成为常量,常量只能赋值一次。
package com.zhongxin.utils;
public class Constants{
// 响应数据回写列
public static final int PESPONSE_CELL_NUM = 8;
// 断言数据回写列
public static final int ASSERT_CELL_NUM = 10;
// 用例文件路径
public static final String EXCEL_PATH = "src/test/resources/cases_v3.xlsx";
}
部分可能会变更的数据写入到Constants类中定义为一个常量
日志记录
引入Maven
log4j
log4j
1.2.17
定义输出
src/test/resources/log4j.properties
log4j.rootLogger = INFO,console,file
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
log4j.appender.file = org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.File = log/api_auto.log
log4j.appender.file.Append = false
log4j.appender.file.layout = org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
定义logger
src/test/java/com/zhongxin/utils/HttpUtils.java
import org.apache.log4j.Logger;
private static Logger logger = Logger.getLogger(HttpUtils.class);
使用
logger.info(statusCode);
测试日志打印
打印