二.HttpClient+testNG实现对接口的测试及校验

在上面第一篇中已经实现了基础配置和测试用例数据准备,本篇文章将以登录举例进行测试执行。

这是之前login接口的代码

@Test(groups = "loginTrue",description = "用户登录接口测试")

public void loginTrue() throws IOException {

SqlSession session = DatabaseUtil.getSqlsession();

LoginCase loginCase = session.selectOne("loginCase",1);

System.out.println(loginCase.toString());

System.out.println(TestConfig.loginUrl);

}

//接下来只需要进行两步:1.发送请求 2.验证返回结果

//第一步发送请求

String result = getResult(loginCase);

//第二步验证返回结果

Assert.assertEquals(loginCase.getExpected(),result);

getResult方法被我抽离出来了放在下面,原因是无论我是登录成功,或者登录失败,等会执行相同的操作,只是测试数据和校验部分会不一样。

这是getResult方法的具体代码:

private String getResult(LoginCase loginCase) throws IOException {

HttpPost post = new HttpPost(TestConfig.loginUrl);

//设置body部分

JSONObject param = new JSONObject();

param.put("userName",loginCase.getUserName());

param.put("password",loginCase.getPassword());

//设置header部分信息

post.setHeader("content-type","application/json");

StringEntity entity = new StringEntity(param.toString(),"utf-8");

post.setEntity(entity);

//测试执行

String result;

HttpResponse response  = TestConfig.defaultHttpClient.execute(post);

result = EntityUtils.toString(response.getEntity(),"utf-8");

System.out.println(result);

TestConfig.store = TestConfig.defaultHttpClient.getCookieStore();

return result;

}

获取的结果会返回到result中,然后与mysql中存的预期值loginCase.getExpected()进行对比,如结果一样则测试通过。

三.Mybatis之Mapper接口的开发方式

该方式开发,不需要写dao层的实现类,而是mybatis根据映射文件等信息对接口进行jdk动态代理生成代理类来实现接口中的方法,因此,采用这种方式,我们只需要编辑接口,而不需要去写实现。

这里举一个例子来说明:

3.1.需求分析

根据id查询用户。

3.2.Mapper开发代理规范

1、mapper接口的全限定名要和mapper映射文件的namespace值一致。

2、mapper接口的方法名称要和mapper映射文件的statement,即sql中的id一致。

3、mapper接口的方法参数类型要和mapper映射文件的statement即sql中的parameterType的值一致,而且它的参数是一个。

4、mapper接口的方法返回值类型要和mapper映射文件的statement即sql中的resultType的值一致。

3.3.代码实现

准备po类:

@Data

public class User {

private Integer id;

private String username;

private Date birthday;

private String sex;

private String address;

//getter和setter方法省略,可以通过@Data注解自动添加get和set方法

}

Mapper接口:

public interface UserMapper {

public User findUserById(int id);

}

UserMapper.xml配置文件:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE mapper

PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<!--

namespace:命名空间,它的作用就是对SQL进行分类化管理,可以理解为SQL隔离

注意:使用mapper代理开发时,namespace有特殊且重要的作用

-->

<configuration>

<typeAliases>

<package name=" com.lc.mybatis.mapper"/>

</typeAliases>

</configuration>

<mapper namespace="UserMapper">

<!-- 根据用户ID查询用户信息 -->

<!-- select:表示一个MappedStatement对象 -->

<!-- id:statement的唯一标识 -->

<!--  #{}:表示一个占位符?-->

<!-- #{id}:里面的id表示输入参数的参数名称,如果该参数为简单类型,那么#{}里面的参数可以任意 -->

<!-- parameterType:输入参数的java类型 -->

<!-- resultType:输出结果的所映射的java类型(单条结果所对应的java类型) -->

<select id="findUserById" parameterType="java.lang.Integer" resultType="com.lc.mybatis.po.User">

SELECT * FROM USER WHERE id = #{id}

</select>

</mapper>

在全局配置文件SqlMapperConfig中添加该映射文件

测试代码:

//也可通过集成springboot来管理mapper

@RunWith(SpringRunner.class)

@SpringBootTest

public class UserMapperTest {

@Resource

private UserMapper userMapper;

//或者不使用springboot集成管理mapper,则需要加下面的setUp方法

private SqlSessionFactory sqlSessionFactory ;

@Before

public void setUp() throws IOException {

InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");

sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

}

@Test

public void testFindUserById() {

SqlSession sqlSession = sqlSessionFactory.openSession();

//获取UserMapper的代理类

UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

User user = userMapper.findUserById(10);

System.out.println(user);

sqlSession.close();

//使用springboot集成

User user = userMapper.findUserById(10);

System.out.println(user);

}

}

四.jenkins集成httpclient项目并生成在线报告

本章主要讲解项目的业务代码在写完后,如何集成至jenkins实现自动构建执行。

在执行下面的流程之前,需要完成两件事:

1.将项目代码上传至git

2.安装tomcat

实现过程:

1.   新建自由风格项目

如何构建配置请参考-此篇文章

2.配置Tomcat并启动

因为jenkins一般是部署在linux上,生成的报告其他用户无法直接查看,tomcat作为一个web中间件,将jenkins生成的报告拷贝至tomcat服务上,用以让其他用户进行查看。

下载完成后,因为tomcat默认的端口号是8080,与jenkins冲突了,所以我们首先在conf文件下的server.xml文件中配置tomcat的默认端口号,将默认的8080修改为可用端口号,在这里我修改为8088,保存后退出。

切换至bin目录下,执行startup.sh文件,启动tomcat。

3.将jenkins生成的测试报告拷贝至tomcat

在jenkins的工程配置部分,shell中添加以下语句

//获取最后一次构建的id

result=$(curl -s http://ip:8080/job/JavaApiTest/lastBuild/buildNumber --user admin:admin)

//tomcat目录下新建文件用以保存测试报告

sudo mkdir /Applications/apache-tomcat-9.0.10/webapps/ROOT/$result

//将jenkins生成的目录拷贝至tomcat内

sudo cp /Users/Shared/Jenkins/test/ApiTest/test-output/index.html /Applications/apache-tomcat-9.0.10/webapps/ROOT/$result/index.html

然后构建项目,执行完,构建成功~

然后访问tomcat:http://ip:8088/65/index.html,可以看到生成的报告

在这里说明一下,为什么要用tomcat。如果不用tomcat,直接访问jenkins生成的报告也是可以的,但是一般jenkins会部署在linux服务器上,无法直接访问或者访问需要权限。tomcat作为一个web中间件,浏览权限是公开的。

java接口自动化基础知识(二)的更多相关文章

  1. java接口自动化基础知识(一)

    一.TestNG+MySQL+MyBatis实现对测试用例数据的读取 本篇文章讲解TestNG+MySQL+MyBatis+ExtentReports实现对测试用例数据的读取,下面放出所有配置文件的目 ...

  2. java 基础知识二 基本类型与运算符

    java  基础知识二 基本类型与运算符 1.标识符 定义:为类.方法.变量起的名称 由大小写字母.数字.下划线(_)和美元符号($)组成,同时不能以数字开头 2.关键字 java语言保留特殊含义或者 ...

  3. Java JDBC的基础知识(二)

    在我的上一篇Java JDBC的基础知识(一)中,最后演示的代码在关闭资源的时候,仅仅用了try/catch语句,这里是有很大的隐患的.在程序创建连接之后,如果不进行关闭,会消耗更多的资源.创建连接之 ...

  4. Java面试题-基础知识

    参考文章:Java面试题-基础知识 基础能力 什么是值传递和引用传递 线程状态有哪些,它们之间是如何转换的 进程与线程的区别,进程间如何通讯,线程间如何通讯? HashMap的数据结构是什么?如何实现 ...

  5. JAVA核心技术I---JAVA基础知识(工具类Arrays和Collections类)

    一:工具类 –不存储数据,而是在数据容器上,实现高效操作 • 排序 • 搜索 –Arrays类 –Collection类 二:Arrays类(处理数组) (一)基本方法 –排序:对数组排序, sort ...

  6. 【Java面试】基础知识篇

    [Java面试]基础知识篇 Java基础知识总结,主要包括数据类型,string类,集合,线程,时间,正则,流,jdk5--8各个版本的新特性,等等.不足的地方,欢迎大家补充.源码分享见个人公告.Ja ...

  7. 第76节:Java中的基础知识

    第76节:Java中的基础知识 设置环境,安装操作系统,安装备份,就是镜像,jdk配置环境,eclipse下载解压即可使用,下载tomcat 折佣动态代理解决网站的字符集编码问题 使用request. ...

  8. JAVA核心技术I---JAVA基础知识(static关键字)

    一:static特殊关键字用处 –变量 –方法 –类 –匿名方法 二:静态变量:类共有成员 –static变量只依赖于类存在(通过类即可访问),不依赖于对象实例存在. –所有的对象实例,对于静态变量都 ...

  9. Java JDBC的基础知识(三)

    在前面的Java JDBC的基础知识(二)和(三)中,主要介绍JDBC的原理和简单的应用过程.尤其在(二)中,可以发现代码进行多次try/catch,还有在前面创建连接等过程中好多参数我都给写定了. ...

随机推荐

  1. KeyError: 'Spider not found: test'

    Error Msg: File "c:\python36\lib\site-packages\scrapy\cmdline.py", line 157, in _run_comma ...

  2. MariaDB第三章:数据库设计与备份--小白博客

    数据库设计 1.第一范式(确保每列保持原子性) 第一范式是最基本的范式.如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式. 2.第二范式(确保表中的每列都和主键相关) 第 ...

  3. Jmeter录制手机app脚本

    转:http://www.cnblogs.com/yangxia-test/p/5484616.html   环境准备: 1.手机 2.wifi 3.Jmeter   具体步骤: 1.启动Jmeter ...

  4. BEX5下新建任务到待办任务

    List<OrgUnit> list = new ArrayList<OrgUnit>(); // 1.查询出执行者 String sql = "select t.f ...

  5. mongoDB 文档操作_删

    mongoDB 文档删除 MySQL对比 mysql delete from table where ... mongo db.collection.deleteOne(query) 删除函数 del ...

  6. Magento2自定义命令

    命令命名准则 命名指南概述 Magento 2引入了一个新的命令行界面(CLI),使组件开发人员能够插入模块提供的命令. Command name Command name 在命令中,它紧跟在命令的名 ...

  7. FastDFS分布式文件系统客户端安装

    软件安装前提:服务器已配置好LNMP环境安装libfastcommon见FastDFS服务器安装文档(http://www.cnblogs.com/Mrhuangrui/p/8316481.html) ...

  8. L2-006 树的遍历 (25 分) (根据后序遍历与中序遍历建二叉树)

    题目链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805069361299456 L2-006 树的遍历 (25 分 ...

  9. python之模块之shutil模块

    shutil -- --High-level file operations  高级的文件操作模块. os模块提供了对目录或者文件的新建/删除/查看文件属性,还提供了对文件以及目录的路径操作.比如说: ...

  10. IDEA打印gc日志,设置JVM参数方法

    打印gc日志 1.对指定运行程序输出GC日志: 点击edit configurations... 在vm options处加入-XX:+PrintGCDetails 测试:代码调用system.gc后 ...