1、在Jtester中使用DataMap

为什么要使用DataMap?

  早先的jTester中提供了dbFit方式来准备和验证数据库数据,应该来说,这个工具解决了很多问题。
实际使用过程中,开发同学反映编辑和准备数据比较麻烦。数据操作错误需要在单独的html文件中才能
查看到,也比较麻烦。 jTester从1.1.6开始推出了一种新的数据库数据准备和验证的方法 -- DataMap方
式。DataMap对比DbFit有以下几个特性:
• 准备数据和验证数据是在java代码中,无需额外的文件。
• 因为只有java代码,数据编辑会更方便一些。
• 验证数据库数据和jTester中其它断言方式一致,错误信息直接显示在测试方法上。
• 只需要关注自己感兴趣的字段,无关的字段框架自动会帮忙填充。
• 构造数据灵活,可以根据自己需要构造特定规则的数据。
我们下面通过示例来简单的演示jTester是如何通过DataMap往数据库中插入数据和验证数据中已
经存在的数据。

例 4.1. 往数据库中插入一条数据

db.table("tdd_user").clean().insert(new DataMap() {
{
this.put("id", "1");
this.put("first_name", "darui.wu");
this.put("my_date", new Date());
}
}).commit();

DataMap(它是 LinkedHashMap<String, Object> 子类)是jTester中用于准备和验证数据的关键对
象, 上面那段代码完成了4件事:
• db.table("tdd_user")
  指定了插入数据的操作对象(表tdd_user),这条语句接下的操作都是针对表tdd_user的。
• clean()
  清空表tdd_user中所有数据。
• insert( ... )
  往表tdd_user中插入一条数据,其中id字段值为1,first_name字段值为
darui.wu,my_date字段值为客户端的当前日期。
• commit()
  提交前面删除数据操作和插入数据操作。
运行上面那段简单的代码后,数据库中数据状态应该如下:

配置jtester.properties文件
要在jTester矿建下进行数据库的相关的测试,必须在测试代码的classpath根路径下放置一个jtester.properties文件。并在该文件中配置相应的数据源。

 在classpath根路径下建好jtester.properties文件后,需要配置下面选项的值。
• database.type
数据库类型,目前支持mysql,oracle两种
• database.url
数据库连接url,比如jdbc:mysql://localhost/presentationtdd?
characterEncoding=UTF8
• database.userName
连接数据库的用户名
• database.password
用户密码
• database.schemaNames
数据库的具体schema
• database.driverClassName
数据库连接驱动class的全称

为了方便大家理解,下面分别给一个mysql配置示例和一个oracle配置示例

例 4.3. mysql配置示例

database.type=mysql
database.url=jdbc:mysql://localhost/presentationtdd?characterEncoding=UTF8
database.userName=root
database.password=password
database.schemaNames=presentationtdd
database.driverClassName=com.mysql.jdbc.Driver

例 4.4. oracle配置示例

database.type=oracle
database.url=jdbc:oracle:thin:@localhost:1521:crmp?args[applicationEncoding=UTF-8,databaseEncoding=UTF-8]
database.userName=root
database.schemaNames=test
database.password=xxxx
database.driverClassName=com.alibaba.china.jdbc.SimpleDriver

验证数据库中数据总数:

 db.table("tdd_user").count.eq(1);

验证数据库中的数据:

 db.table("tdd_user").query().propertyEqMap(newDataMap() {
{
this.put("id", 1);
this.put("first_name", "wu");
this.put("last_name", "json");
}
});

带条件的数据查询验证:

db.table("tdd_user").queryWhere("post_code=310012").propertyEqMap(2, newDataMap() {
{
this.put("id", 1, 2);
this.put("first_name", "darui.wu", "data.iterator");
this.put("address_id", 0);
this.put("sarary", 0.0);
}
}, EqMode.IGNORE_ORDER);

2、在Jtester中使用Mock

 new MockUp<ResourceFacility>(){
@Mock
public List<NoahResourceModel> getNoahResourceByResType(String resType){
List<NoahResourceModel> rs = new ArrayList<NoahResourceModel>();
NoahResourceModel r= new NoahResourceModel();
r.setName("customer_key_1");
r.setValue("qt_key_1");
rs.add(r); r= new NoahResourceModel();
r.setName("customer_key_2");
r.setValue("qt_key_2");
rs.add(r);
return rs;
}
};

3、测试分组

1、将某个测试方法归为某个测试分组

@Test(groups={"tests.find"})
public class FindServiceTest extends AegeanDomainBaseTest{
@Test
public void testGroup(){ }
}

Jtester使用的更多相关文章

  1. 单元测试利器之Jtester

    http://kiral.iteye.com/blog/900975 名词解释: Junit:众所周知的单元测试. 官方网址:http://junit.sourceforge.net/.Junit从4 ...

  2. Jtester+unitils+testng:DAO单元测试文件模板自动生成

    定位 本文适合于不愿意手工编写而想自动化生成DAO单元测试的筒鞋.成果是不能照搬的,但其中的"创建模板.填充内容.自动生成"思想是可以复用的.读完本文,可以了解 Python 读取 ...

  3. Test4J与Jtester单元测试常用注解比较

    package com.alibaba.ceres.catalog.biz.product.impl; import org.junit.After; import org.junit.Before; ...

  4. 编写更少bug的程序的六条准则

          如何编写更少bug的程序?  尽可能避免常见的程序错误.              沟通设计先行 + 编写可复用代码 + 做得更多 + 做的更少 + 创造“编程心流”+ 严格的程序测试   ...

  5. 自己实现的一款在线Javascript正则表达式测试器——JRE-Parser

    本文最初发布于我的个人博客:http://jerryzou.com/posts/jreparser/ 昨天在看<正则表达式30分钟入门教程>的时候,看到博主自己实现了一个C#写的正则测试器 ...

  6. 情景linux--shell如何实现多线程?

    情景linux--shell如何实现多线程? 情景 shell脚本的执行效率虽高,但当任务量巨大时仍然需要较长的时间,尤其是需要执行一大批的命令时.因为默认情况下,shell脚本中的命令是串行执行的. ...

  7. 情景linux--如何摆脱深路径的频繁切换烦恼?

    情景 通常情况下,在linux系统上切换目录的成本很低,使用cd命令就可以了.如果需要在一个目录的不同的子目录和其父目录之间切换,进入到这个目录之后,再使用相对路径会比较方便.如果要切换的目录的路径较 ...

  8. [转]linux shell 多线程实现

    情景 shell脚本的执行效率虽高,但当任务量巨大时仍然需要较长的时间,尤其是需要执行一大批的命令时.因为默认情况下,shell脚本中的命令是串行执行的.如果这些命令相互之间是独立的,则可以使用“并发 ...

  9. #测试框架推荐# test4j,数据库测试

    # 背景 后端都是操作DB的,这块的自动化测试校验的话,是需要数据库操作的,当然可以直接封装方法来操作数据,那么有没有开源框架支持数据操作,让我们关注写sql语句?或者帮我们做mysql的断言呢? # ...

随机推荐

  1. activity工作流学习地址

    https://wenku.baidu.com/view/8572153150e2524de4187e5d.html

  2. luogu P2584 [ZJOI2006]GameZ游戏排名系统 Splay

    实在不想调了QAQ... Code: #include <cstdio> #include <algorithm> #include <cstring> #incl ...

  3. 一些特殊ACII码的用法 在控制台中覆盖显示、刷新显示和删除字符

    很好奇怎么实现在控制台中不换行直接显示新的信息把旧的替换掉,于是找到了两个ACII码字符,他们可以帮助实现. 一个是‘\b’字符,这个字符是backspace,即删除上一个字符,于是可以清除以显示的旧 ...

  4. Vue-给对象新增属性(使用Vue.$set())

    在开发过程中,我们时常会遇到这样一种情况:当vue的data里边声明或者已经赋值过的对象或者数组(数组里边的值是对象)时,向对象中添加新的属性,如果更新此属性的值,是不会更新视图的. 根据官方文档定义 ...

  5. Windows Vista 安装和使用指导 - 停止支持后的几条建议

    简介 曾经被广大网民吐槽的Windows Vista现在已经淡出了人们的视线,但仍有一些朋友想要体验一下这个操作系统.Windows Vista是Windows发展路线上的里程碑,相比之前的Windo ...

  6. python在不同情况下写入csv文件

    情况一(解法一):将列表存储为csv文件.列表的每一项代表csv文件的一行. 列表中的每一项包含多个属性.list=[[属性1,属性2,属性3,……],[属性1,属性2,属性3,……],[属性1,属性 ...

  7. 题解 CF821D 【Okabe and City】

    其实,这道题不用long long也能AC. 题意是给你一个矩阵,有一些格子被点亮有一些没有,每一次只能在被点亮的格子上面走. 然后你每一次都可以选择点亮一行或一排(非永久),现在问你最少点多少次可以 ...

  8. array_combine php一个比较偏门的数组函数

    这函数  返回数组1的值 当做key,把数组2的值当做value,   当查询数据库用了 group +GROUP_CONCAT 两个组合时,(例如查询某个班级的,用户名,用户id,返回的是字符串,打 ...

  9. hdu Swipe Bo(bfs+状态压缩)错了多次的题

    Swipe Bo Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  10. app-framework学习--nav的Scroller禁用与启用

    app-framewor(jqmobi) nav的Scroller禁用与启用 写在panel 的 data-load 方法里 禁用  $.ui.scrollingDivs.menu_scroller. ...