Data-Factory 用于根据对象,随机自动生成初始化信息,避免了手动建立对象的繁琐,便于测试。java
8 大基本类型的支持git
String、Date、金额,日期等常见类型的支持github
java8 常见时间类的支持正则表达式
支持 String 和 Number 类型的注解定义安全
添加 @DataFactory
注解支持bash
支持 Regex 正则表达式maven
变动日志ide
提供线程安全的方法:工具
/** * 构建结果 * @param clazz 类型 * @return 构建结果 */
public static <T> T build(final Class<T> clazz) {
IData data = getInstance();
return (T) data.build(null, clazz);
}
/** * 构建结果 * @param context 执行上下文 * @param clazz 类型 * @return 构建结果 */
public static <T> T build(final IContext context, final Class<T> clazz) {
IData data = getInstance();
return (T) data.build(context, clazz);
}
复制代码
JDK 1.8+测试
Maven 3.0+
若是是 idea,测试的时候 Enable Annotation Processing
。
<dependency>
<groupId>com.github.houbb</groupId>
<artifactId>data-factory-core</artifactId>
<version>0.0.3</version>
</dependency>
复制代码
一个用于演示的普通 java 对象。
public class User {
private String name;
private int age;
private Date birthday;
private List<String> stringList;
//S/F 的枚举
private StatusEnum statusEnum;
private Map<String, String> map;
//Getter & Setter
}
复制代码
@Test
public void buildBeanBaseTest() throws Exception {
User user = DataUtil.build(User.class);
System.out.println(user);
}
复制代码
输出信息以下:
User{name='wZ8CJZtK', age=-564106861, birthday=Wed Feb 27 22:14:34 CST 2019, stringList=[Du4iJkQj], statusEnum=S, map={yA5yDqM=Kdzi}}
复制代码
内容每次都随机。便于基本的测试数据填充。