AssertJ断言系列-----------<数据库断言二>
那么,在实际的接口测试中,我们除了要断言响应的数据正确之外,可能有的还需要断言数据层是否数据真的有入库。
assertj db是可以直接对数据库进行断言和操作的。
一、创建一个students表
CREATE TABLE `students` (
`id` VARCHAR(32) DEFAULT NULL,
`Name` VARCHAR(32) DEFAULT NULL,
`Sex` VARCHAR(32) DEFAULT NULL,
`Age` VARCHAR(32) DEFAULT NULL
) ENGINE=INNODB DEFAULT CHARSET=utf8
二、插入三条数据
insert into `students` (`id`, `Name`, `Sex`, `Age`) values('1','hello','1','11');
insert into `students` (`id`, `Name`, `Sex`, `Age`) values('2','world','2','22');
insert into `students` (`id`, `Name`, `Sex`, `Age`) values('3','java','3','33');
三、编辑代码
package org.assertj.examples.db; import org.assertj.db.type.Request;
import org.assertj.db.type.Source;
import org.junit.BeforeClass;
import org.junit.Test; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.List;
import static org.assertj.db.api.Assertions.assertThat; /**
* @ClassName DataAssertionExample
* @Description TODO
* @Author 12457
* @Date 2019/1/27 10:43
* @Version 1.0
**/ public class DataAssertionExample { private static String driver = "com.mysql.jdbc.Driver";
private static String url = "jdbc:mysql://localhost:3306/course";
private static String username = "****"; //实际用户名
private static String password = "****"; //实际密码
private static Connection conn = null; /*
*数据库配置连接
**/
@BeforeClass
public static void beforeClass(){
try {
Class.forName(driver);
conn = (Connection) DriverManager.getConnection(url,username,password);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} } @Test
public void basic_request_assertion_examples(){
Source source = new Source(url,username,password);
Request request = new Request(source,"SELECT * FROM students");
//获取该表的字段名
List<String> list = request.getColumnsNameList();
for (String s : list) {
System.out.print(s + "\t");
}
//断言name这一列数据
assertThat(request).column("name")
.value().isEqualTo("hello")
.value().isEqualTo("world")
.value().isEqualTo("java"); //断言数据库表中的数据条数
assertThat(request).hasNumberOfRows(3); //断言第一行的数据的值,row(0)代表第一行数据
assertThat(request).row(0)
.value().isEqualTo("1")
.value().isEqualTo("hello")
.value().isEqualTo("1")
.value().isEqualTo("11");
} @Test
public void basic_column_request_assertion_examples(){
Source source = new Source(url,username,password);
Request request = new Request(source,"SELECT * FROM students"); //断言sex列中数据
assertThat(request).column("sex")
.hasValues("1","2","3");
} @Test
public void basic_row_request_assertion_examples(){
Source source = new Source(url,username,password);
Request request = new Request(source,"SELECT * FROM students");
assertThat(request).row(1)
.hasValues("2","world","2","22");
} @Test
public void size_request_assertion_examples(){
Source source = new Source(url,username,password);
Request request = new Request(source,"SELECT * FROM students"); //表有4列3行数据
assertThat(request).hasNumberOfColumns(4);
assertThat(request).hasNumberOfRows(3); //另外相等的一种写法
assertThat(request).column().hasNumberOfRows(3);
assertThat(request).row().hasNumberOfColumns(4);
} @Test
public void request_parameters_examples(){
Source source = new Source(url,username,password);
Request request = new Request(source,"SELECT name,sex FROM students where name like ?","%o%"); //查询出来有2条数据符号,然后对values值进行判断
assertThat(request).hasNumberOfColumns(2).hasNumberOfRows(2);
assertThat(request)
.row().hasNumberOfColumns(2).hasValues("hello","1")
.row().hasValues("world","2");
}
}
AssertJ断言系列-----------<数据库断言二>的更多相关文章
- AssertJ断言系列-----------<数据库断言三>
其实,是有很多种数据断言的使用.那么,我们在接口的测试中,到底应不应该加上数据库断言呢?我的观点是,视情况而定:某一些特殊的场景或者特殊的业务,那么我们就一定要加上数据库断言.不是我们测试人员,不相信 ...
- AssertJ断言系列<一>
1 - Get AssertJ Core assertions Maven的pom.xml加入如下配置: <dependency> <groupId>org.assertj&l ...
- ShoneSharp语言(S#)的设计和使用介绍系列(7)— 布尔Bool及对象Object
ShoneSharp语言(S#)的设计和使用介绍 系列(7)— 布尔Bool及对象Object 作者:Shone 声明:原创文章欢迎转载,但请注明出处,https://www.cnblogs.com/ ...
- Java单元測试工具JUnit 5新特性一览
Java单元測试工具JUnit 5新特性一览 作者:chszs,未经博主同意不得转载. 经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs JUnit是最流行的开源 ...
- 流式断言器AssertJ介绍
本文来自网易云社区 作者:范旭斐 大家在使用testng.junit做自动化测试的过程中,经常会用到testng.junit自带的断言器,有时候对一个字符串.日期.列表进行断言很麻烦,需要借助到jdk ...
- JUnit 单元测试断言推荐 AssertJ
文章转自:http://sgq0085.iteye.com/blog/2030609 前言 由于JUnit的Assert是公认的烂API,所以不推荐使用,目前推荐使用的是AssertJ. Assert ...
- Pytest系列(2) - assert断言详细使用
如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 前言 与unittest不同,py ...
- Selenium3 + Python3自动化测试系列五——常用断言Assertion
断言Assertion 验证应用程序的状态是否同所期望的一致. 常见的断言包括:验证页面内容,如标题是否为X或当前位置是否正确,或是验证该复选框是否被勾选. selenium 提供了三种模式的断言:a ...
- $python正则表达式系列(5)——零宽断言
本文主要总结了python正则零宽断言(zero-length-assertion)的一些常用用法. 1. 什么是零宽断言 有时候在使用正则表达式做匹配的时候,我们希望匹配一个字符串,这个字符串的前面 ...
随机推荐
- 深入剖析java的try…catch…finally语句
一.前言 前些天参加面试的时候有一道题: public class test { public static void main(String[] args){ try { return; } fin ...
- Halcon中的坐标系特点及XLD的镜像转换
我们知道,Halcon中的坐标系的原点在左上角,而一般二维平面坐标系的原点在左下角.那么Halcon中坐标系和一般的二维坐标系有什么区别呢?我通过下面这个例子来分析. gen_image_const ...
- Differential expression analysis for paired RNA-seq data 成对RNA-seq数据的差异表达分析
Differential expression analysis for paired RNA-seq data 抽象背景:RNA-Seq技术通过产生序列读数并在不同生物条件下计数其频率来测量转录本丰 ...
- Spring JMX之二:远程访问MBean
虽然最初的JMX规范提及了通过MBean进行应用的远程管理,但是它并没有定义实际的远程 访问协议或API.因此,会由JMX供应商定义自己的JMX远程访问解决方案,但这通常又是专 有的. 为了满足以标准 ...
- Mockplus组件样式库一键解决风格复用
在Mockplus3.3版本中,新增了组件样式库,可以快速复用组件风格,同时可以将组件风格保存到库中. 官网地址:https://www.mockplus.cn 1. 保存样式 选中组件,设置好该组件 ...
- parseInt(string, radix)
参数 描述 string 必需.要被解析的字符串. radix 可选.表示要解析的数字的基数.该值介于 2 ~ 36 之间. 如果省略该参数或其值为 0,则数字将以 10 为基础来解析.如果它以 “0 ...
- windows下Apache的虚拟主机配置
1.Apache虚拟主机: 在Apache上有关于虚拟主机的具体说明,具体可以参考Apache手册,这里简单的说一下虚拟主机主要分为两种: 1.基于主机名的虚拟主机(一个IP地址,多个网站) 2.基于 ...
- IE(IE6/IE7/IE8)支持HTML5标签
让IE(ie6/ie7/ie8)支持HTML5元素,我们需要在HTML头部添加以下JavaScript,这是一个简单的document.createElement声明,利用条件注释针对IE来调用这个j ...
- (广搜)可口可乐 -- hdu -- 1495
链接: http://acm.hdu.edu.cn/showproblem.php?pid=1495 Time Limit: 2000/1000 MS (Java/Others) Memory ...
- (巴什博弈 sg函数入门1) Brave Game -- hdu -- 1846
链接: http://acm.hdu.edu.cn/showproblem.php?pid=1846 首先来玩个游戏,引用杭电课件上的: (1) 玩家:2人:(2) 道具:23张扑克牌:(3) 规则: ...