Data-Factory 用于根据对象,随机自动生成初始化信息,避免了手动建立对象的繁琐,便于测试。java
8 大基本类型的支持git
String、Date、金额,日期等常见类型的支持github
java8 常见时间类的支持正则表达式
支持 String 和 Number 类型的注解定义安全
添加 @DataFactory
注解支持 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+ ui
若是是 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}}
内容每次都随机。便于基本的测试数据填充。