赞
踩
技术栈汇总:
①Java基础(封装、反射、泛型、jdbc)
②配置文件解析(properties)
③httpclient(发送http请求)
④fastjson、jsonpath处理数据的
⑤testng自动化测试框架重点
⑥allure测试报告
File—settings—maven
fastjson、jsonpath都是进行处理数据的
testing自动化框架里的重点。
allure测试报告的
fastjson处理json字符串、也可以处理json数组
解析json字符串入参、为后续请求做准备
<!-https://mvnrepository.com/artifact/com.alibaba/fastjson -->
com.alibaba
fastison
1.2.75
下载完后是可以看到自动生成的依赖包
比如登录需要用用户名和密码
{“username”:“qzcsbj”, “password”:“123456”}
自动化框架数据源,入参都是json字符串,需要用到fastjson
类.方法,这个方法是静态
集合里的每一个key都是String
现在定义的json字符串解析后已经放到Map中
说明将json字符串的内容放到map中
blog.csdnimg.cn/direct/ae6feeba2eae442f961df977a6c8eac1.jpeg)
自动化框架中涉及了初始化框架,有的是要对里面的数据进行操作。操作数据库是需要写sql的
此处是json数组,数组里,每个元素是json字符串,里面是键值数据,第一个是sql编号,实际执行的sql。
[{“sqlNo”:“1”,“sq!”:“select * from users where username=‘qzcsbj’;”},.“sqlNo”:“2”,“sql”:“select * from users where username=‘test00501’;”}]
此方法一不可取
传两个参数,第一个参数是要进行解析的String,第二个传的是字节码文件
解决方法是:将第一个参数String解析为Map
String sqlNo = (String)sql.get("sqlNo");
把每一个json字符串里的内容封装成对象l,实体类里添加get、set方法,直接对象.get,获取到sql的内容,这种代码提示,写起来也比较方便。自动化也引用了这种封装。即就是将sql封装成对象,
把属性封装成私有的(sqlNo,sql),提供get、set方法,有参构造方法,无参构造方法一定要加上,反射会去调无参的构造方法。如果只写有参,没有写无参构造方法,一定会报错,打印字符串结果,需要加上toString()方法,不然打印的是对象的地址以上实体类就写好了。
再进行优化一下
元素封装到对象,就改为自己写的类.class
即sql.class
上面方法二是将每个元素封装成hashMap对象,而此处是将每个元素封装成sql对象,
从对象里获取属性,直接就是get方法
此方法就更加方便,不需要去获取很多key
pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>mavenProject</groupId> <artifactId>mavenProject</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.75</version> </dependency> </dependencies> </project>
sql类
package com.zhou.demo; public class Sql { private String sql; private String sqlNo; public Sql() { } public Sql(String sql) { this.sql = sql; } public Sql(String sql, String sqlNo) { this.sql = sql; this.sqlNo = sqlNo; } public void setSql(String sql) { this.sql = sql; } public void setSqlNo(String sqlNo) { this.sqlNo = sqlNo; } public String getSql() { return sql; } public String getSqlNo() { return sqlNo; } @Override public String toString() { return "sql{" + "sql='" + sql + '\'' + ", sqlNo='" + sqlNo + '\'' + '}'; } }
package com.zhou.demo; import com.alibaba.fastjson.JSONObject; import java.util.HashMap; import java.util.Set; //需求:将json字符串转化成map,字符串:{"username":"qzcsbj", "password":"123456"} public class Test { public static void main(String[] args) { String parameters="{\"username\":\"qzcsbj\", \"password\":\"123456\"}"; //先解析为JSONObject,然后转换为map HashMap<String, String> map = new HashMap<String, String>(); // 解析json格式字符串为JSONObject(JSONObject是Map接口的一个实现类,和HashMap平级) JSONObject jsonObject = JSONObject.parseObject(parameters); // 将JSO\\\\\\\ NObject转换为map,先获取keys,先将keyset获取,集合里的每一个key都是String,通过遍历的key获取value,再放到map中 Set<String> keys= jsonObject.keySet(); for (String key:keys) { map.put(key,jsonObject.getString(key)); } //验证,获取Map中的key Set<String> keys2 = map.keySet(); for (String key :keys2) { System.out.println(key+"="+map.get(key)); } } }
package com.zhou.demo; import com.alibaba.fastjson.JSONObject; import java.util.HashMap; import java.util.List; //JSON数组,每个元素是json字符串 public class Test02 { public static void main(String[] args) { String initsql="[\n" + "{\"sqlNo\":\"1\",\"sql\":\"select * from users where username='qzcsbj';\"},\n" + "{\"sqlNo\":\"2\",\"sql\":\"select * from users where username='tester00501';\"}\n" + "\n" + "]"; /* //元素解析为Map List<HashMap> sqls = JSONObject.parseArray(initsql,HashMap.class); for (HashMap sql:sqls) { System.out.println(sql); String sqlNo = (String)sql.get("sqlNo"); String sql_ = (String)sql.get("sql"); System.out.println("sqlNo-"+sqlNo+",sql_-"+sql_); }*/ //元素封装到对象 List<Sql> sqls = JSONObject.parseArray(initsql, Sql.class); for (Sql sql:sqls) { String sqlNo = sql.getSqlNo(); String sql_ = sql.getSql(); System.out.println("sqlNo-"+",sql_"+sql_); } } }
因为目前来说项目的话都是前后端分离
后端一般返回的都是json字符串
要去做断言的话,一般会对json做解析,解析完后一般是只对关键字段进行做断言
断言一般是code+关键业务字段
他是json字符串,所以就需要用到jsonpath
blog.csdnimg.cn/5bdd9defd7db47b7a5934f79f9fd0ceb.png)
需要确认依赖是否下载好
此处这个变量就是登录成功返回的响应字段
blog.csdnimg.cn/a20e89ee243c43f69a1b4e1c3a97b89b.png)
将定义的字段response传入
接口自动化对于依赖数据的处理
从这一行中的前面获取到token,也是$.
获取到后,如果是全局变量,就可以保存到全局变量中
如果是要获取到断言再获取到
再进行断言
在自动化框架中是通过写代码的方式来发送请求,即就需要用到httpclient,java提供的与服务端交互的库
需要传id
从库里看到id为259
在数据文件中,parameters都是拼接成json字符串,所以id=259也拼接为json字符串
此处将259放到双引号中,自动进行转义
get请求:http://47.108.153.47:18089/qzcsbj/user/findById?id=259
?后面直接拼接参数
还需要考虑多个值:http://47.108.153.47:18089/qzcsbj/user/findById?id=259&name=jack
以上就将发送get请求的参数url和参数拼接好,创建好后需要去创建一个get请求对象
将url传进去
此处就获取到httpget请求对象
而CloseableHttpClient抽象类实现了HttpClient,Closeable接口
可以用多态,子类对象指向父类引用(父类实现的接口)
上面定义了结果res
即
http://47.108.153.47:18089/qzcsbj/user/login
url,请求参数parameters、请求头
这些参数在自动化框架中都是从数据文件去获取的
定义res
返回res
传url
看一下构造方法可以传String,指定第二个构造方法
以上就将发送的post请求:请求头、要发送的数据都定义好了
子类对象指向父类引用
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。