自动化(二正)

Java接口自动化用到的技术栈

技术栈汇总:
①Java基础(封装、反射、泛型、jdbc)
②配置文件解析(properties)
③httpclient(发送http请求)
④fastjson、jsonpath处理数据的
⑤testng自动化测试框架重点
⑥allure测试报告

第一类:http请求相关(fastjson、jsonpath、httpclient)

准备

创建maven项目

①先创建maven项目,newPROJECT–Maven—groupid----finish

在这里插入图片描述
在这里插入图片描述

②再进行查看maven配置

File—settings—maven
在这里插入图片描述

fastjson、jsonpath都是进行处理数据的
testing自动化框架里的重点。
allure测试报告的

1、fastjson(应用场景:解析入参的json字符串、字符串数组)

fastjson处理json字符串、也可以处理json数组
解析json字符串入参、为后续请求做准备

①依赖

<!-https://mvnrepository.com/artifact/com.alibaba/fastjson -->
com.alibaba
fastison
1.2.75

②添加依赖,会自动生成依赖

在这里插入图片描述
下载完后是可以看到自动生成的依赖包

1.1、示例(解析json字符串入参、json字符串数组入参)

1.1.1、解析json字符串入参

比如登录需要用用户名和密码
{“username”:“qzcsbj”, “password”:“123456”}

自动化框架数据源,入参都是json字符串,需要用到fastjson

第一步:创建包名、类名、创建main方法

在这里插入图片描述

第二步:定义一个字符串变量,此处就是需要解析的json字符串
第三步:对于json字符串的处理,先把他解析为jsonObject对象,再放到Map中
1)先创建一个HashMap,key和value都是String

在这里插入图片描述
在这里插入图片描述

2)解析字符串,此处用到的是JSONObjetct.parseObject,返回值是JSONObect类型

类.方法,这个方法是静态

3)获取keys,直接jsonObjetc.keySet方法,即就获取到Set集合

集合里的每一个key都是String

4)再进行遍历,通过遍历的key获取value,再将key,value放到Map中

在这里插入图片描述

现在定义的json字符串解析后已经放到Map中
在这里插入图片描述

5)进行验证一下放到Map中的内容,获取Map中的key

说明将json字符串的内容放到map中
blog.csdnimg.cn/direct/ae6feeba2eae442f961df977a6c8eac1.jpeg)

1.1.2、解析json字符串数组入参

自动化框架中涉及了初始化框架,有的是要对里面的数据进行操作。操作数据库是需要写sql的
此处是json数组,数组里,每个元素是json字符串,里面是键值数据,第一个是sql编号,实际执行的sql。

[{“sqlNo”:“1”,“sq!”:“select * from users where username=‘qzcsbj’;”},.“sqlNo”:“2”,“sql”:“select * from users where username=‘test00501’;”}]

第一步:创建包名、类名、创建main方法
第二步:定义一个字符串变量,此处就是需要解析的json字符串数组
方法一(不可取):解析字符串JSONObjetct.parseArray(String text),返回值是JSONArray
1)解析字符串,此处用到的是JSONObjetct.parseArray

在这里插入图片描述

2)直接遍历,每个元素都是Object类型,并且打印出来也是两个json字符

在这里插入图片描述

3)打印json字符串里面sql的值,此处没有get、set方法,只能获取到json字符串,无法获取到某个key的内容

在这里插入图片描述
此方法一不可取

方法二:JSONObjetct.parseArray(String text,Class clazz),返回值是List < T >,返回类型是List,返回元素是HashMap

传两个参数,第一个参数是要进行解析的String,第二个传的是字节码文件
解决方法是:将第一个参数String解析为Map

1)将每个元素封装成hashmap对象,此处用到的是JSONObjetct.parseArray(String text,Class clazz)解析字符串数组,
2)获取sqlNo,sql是HashMap类型,可以进行get方法

在这里插入图片描述

3 )此处没有获取里面的键值或类型,默认是Object,我们此处想要的是String,可以进行强制转化,此处就用到了多态,父类引用指向子类对象
4)即就获取到了sql中json字符串里面每个key所对应的值

在这里插入图片描述

5)此方法不足:此处需要显示的写json字符串里的key,如果比较多比较麻烦,
 String sqlNo = (String)sql.get("sqlNo");
方法三:用来解决方法二中第⑤的不足,一般采用封装

把每一个json字符串里的内容封装成对象l,实体类里添加get、set方法,直接对象.get,获取到sql的内容,这种代码提示,写起来也比较方便。自动化也引用了这种封装。即就是将sql封装成对象,
把属性封装成私有的(sqlNo,sql),提供get、set方法,有参构造方法,无参构造方法一定要加上,反射会去调无参的构造方法。如果只写有参,没有写无参构造方法,一定会报错,打印字符串结果,需要加上toString()方法,不然打印的是对象的地址以上实体类就写好了。

再进行优化一下
元素封装到对象,就改为自己写的类.class
即sql.class

1)定义一个sql的javabean:sql类有属性sqlNo,sql,之后再添加get、set方法、构造方法、toString()方法

在这里插入图片描述在这里插入图片描述

2)将每个json字符串封装成sql对象(Test02),JSONObjetct.parseArray(String text,Class clazz),返回值是List < T >,返回类型是List,返回元素是sql对象

上面方法二是将每个元素封装成hashMap对象,而此处是将每个元素封装成sql对象,
在这里插入图片描述

3)进行遍历

从对象里获取属性,直接就是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_);

        }

    }


    }

2、jsonpath(应用场景:解析响应的json数据,比如获取断言字段、比如要获取的关联的值)

因为目前来说项目的话都是前后端分离
后端一般返回的都是json字符串
要去做断言的话,一般会对json做解析,解析完后一般是只对关键字段进行做断言
断言一般是code+关键业务字段
他是json字符串,所以就需要用到jsonpath

①依赖

②添加依赖,会自动生成依赖

blog.csdnimg.cn/5bdd9defd7db47b7a5934f79f9fd0ceb.png)
在这里插入图片描述
需要确认依赖是否下载好

2.1、示例(获取响应数据中的要断言的关键业务字段)

2.1.1、获取响应数据中的要断言的关键业务字段
第一步:创建类名、创建main方法、定义一个字符串变量

此处这个变量就是登录成功返回的响应字段
blog.csdnimg.cn/a20e89ee243c43f69a1b4e1c3a97b89b.png)

第二步:做断言需要将里面的内容断言获取到用到的是Configuration.defaultConfiguration.jsonProvider().parse(),返回值Object类型

在这里插入图片描述
将定义的字段response传入

第三步:使用方法JsonPath.read(Object json,String jsonpath,predicate…filters),返回类型是Object类型

在这里插入图片描述

接口自动化对于依赖数据的处理
从这一行中的前面获取到token,也是$.
获取到后,如果是全局变量,就可以保存到全局变量中
如果是要获取到断言再获取到
再进行断言

3、httpclient(通过写代码的方式来发送请求)

在自动化框架中是通过写代码的方式来发送请求,即就需要用到httpclient,java提供的与服务端交互的库

①依赖

②添加依赖,会自动生成依赖

在这里插入图片描述

3.1、示例(get请求、post请求)

3.1.1、get请求
准备工作:验证swagger接口文档的请求接口是否通,看接口文档,确定get请求findById,需要传的id

需要传id
在这里插入图片描述
从库里看到id为259
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

第一步:创建类名Test04、创建main方法
第二步:定义接口的地址变量url,请求参数parameters

在这里插入图片描述
在数据文件中,parameters都是拼接成json字符串,所以id=259也拼接为json字符串

此处将259放到双引号中,自动进行转义
在这里插入图片描述

第三步:解析json字符串,用JSONObject.parseObject()方法,返回类型是JSONObject类型

在这里插入图片描述

第四步:定义一个静态方法getRequest(String url,JSONObject jsonobject)

在这里插入图片描述

第五步:再在main方法中去进行调用getRquest(),返回值是String类型

在这里插入图片描述

第六步:完善getRequest()方法逻辑

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

1)通过jsonobetct.keySet()获取key,得到一个Set集合

在这里插入图片描述

2)遍历Set集合,得到key值

在这里插入图片描述

3)还需要考虑多个值的情况,即定义flag= true,先写true的情况,并且是第一个

在这里插入图片描述

4)否则就写后面的

在这里插入图片描述

5)定义一个res空字符串,返回res

在这里插入图片描述
以上就将发送get请求的参数url和参数拼接好,创建好后需要去创建一个get请求对象

6)创建httpget请求对象 ,new HttpGet(org.apache.http.client.methods)选这个构造器

将url传进去
此处就获取到httpget请求对象
在这里插入图片描述

7)创建httpclient客户端,使用的是HttpClients.createDefault()方法,返回类型是CloseableHttpClient

在这里插入图片描述

而CloseableHttpClient抽象类实现了HttpClient,Closeable接口
在这里插入图片描述
可以用多态,子类对象指向父类引用(父类实现的接口)
在这里插入图片描述

8)执行请求execute()方法,传httpget对象,再进行抛异常

在这里插入图片描述
在这里插入图片描述

9)获取HttpResponse对象后,可以调取它的getEntity方法,去获取Httpentity响应对象,获取到之后EntityUtils.toString方法,返回类型为String类型,

在这里插入图片描述
在这里插入图片描述
上面定义了结果res

在这里插入图片描述

10)运行

在这里插入图片描述

3.1.2、post请求
准备工作:验证swagger接口文档的请求接口是否通

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

第一步:创建类名Test05、创建main方法

http://47.108.153.47:18089/qzcsbj/user/login
url,请求参数parameters、请求头

在这里插入图片描述

第二步:定义接口的地址变量url,请求参数parameters、请求头

这些参数在自动化框架中都是从数据文件去获取的
在这里插入图片描述
在这里插入图片描述

第三步:解析json字符串para、headers,用JSONObject.parseObject()方法,返回值是JSONObject类型
第四步:定义一个发送post请求的方法,完善逻辑,传参header、url、parameters

定义res
返回res

在这里插入图片描述

1)通过jsonobetct.keySet()获取key,得到一个Set集合,遍历key得到key

在这里插入图片描述

2)想要通过httppost对象调addHeader()方法,,返回类型是HttPost需要先创建httpppost对象

传url
在这里插入图片描述

3)通过httppost对象调addHeader()方法

在这里插入图片描述

4)需要httpEntity,但是httpEntity是接口,接口不能实例化对象,需要实现类StringEntity实现接口httpEntity

在这里插入图片描述
在这里插入图片描述
看一下构造方法可以传String,指定第二个构造方法

在这里插入图片描述
在这里插入图片描述
以上就将发送的post请求:请求头、要发送的数据都定义好了

5)创建httpclient客户端,使用的是HttpClients.createDefault()方法,返回类型是CloseableHttpClient

子类对象指向父类引用
在这里插入图片描述

6)发送请求,执行请求execute()方法,传httppost对象,再进行抛异常

在这里插入图片描述

7))获取HttpResponse对象后,可以调取它的getEntity方法,去获取Httpentity响应对象,获取到之后EntityUtils.toString方法,返回类型为String类型

在这里插入图片描述

8)main方法里调用刚才定义的方法

在这里插入图片描述

9)运行

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/792768.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

从0开始的STM32HAL库学习4

对射式红外传感器计数复现 配置工程 我们直接复制oled的工程&#xff0c;但是要重命名。 将PB14设置为中断引脚 自定义命名为sensorcount 设置为上升沿触发 打开中断 配置NVCI 都为默认就可以了 修改代码 修改stm32f1xx_it.c 文件 找到中断函数并修改 void EXTI15_10_I…

element plus 实现跨页面+跨tab栏多选

文章目录 element plus 层面数据层面 菜鸟好久没写博客了&#xff0c;主要是没遇见什么很难的问题&#xff0c;今天碰见了一个没有思路的问题&#xff0c;解决后立马来和大家伙分享了&#xff01; 菜鸟今天要实现一个需求&#xff0c;就是&#xff1a;实现跨页面跨 tab栏 多选…

Linux 程序卡死的特殊处理

一、前言 Linux环境。 我们在日常编写的程序中&#xff0c;可能会出现一些细节问题&#xff0c;导致程序卡死&#xff0c;即程序没法正常运行&#xff0c;界面卡住&#xff0c;也不会闪退... 当这种问题出现在客户现场&#xff0c;那就是大问题了。。。 当我们暂时还无法排…

USB转RS485+RS232+TTL串口电路

USB转RS485RS232TTL电路 USB转RS485RS232TTL电路如下图所示&#xff0c;可实现USB转RS485RS232TTL串口&#xff0c;一个电路模块即可实现电路调试过程中用到常用接口。 电路模块上留有2.54MM单排针接口和接线端子两种接线方式&#xff0c;可接线和跳线。电路模块同时有5V和3.3V…

不仅是输出信息,console.log 也能玩出花

console.log 是 JavaScript 中一个常用的函数&#xff0c;用于向控制台输出信息。 console.log 虽然主要用于调试目的&#xff0c;但也包含了一些有趣的用法&#xff0c; console.log 不仅能输出文本&#xff0c;还能以更丰富的方式展示信息。 比如我们打开 B 站&#xff0c;然…

计算机网络体系结构解析

OSI参考模型 与 TCP/IP模型 如图所示 TCP/IP模型有几层 应用层&#xff1a;只需要专注于为用户提供应用功能 HTTP、SMTP、Telnet等&#xff0c;工作在操作系统中的用户态&#xff0c;传输层及以下工作在内核态传输层&#xff1a;为应用层提供网络支持&#xff08;TCP、UDP传…

c++多态的定义和原理

目录 1、多态的定义和实现 1.多态的构成条件 2.虚函数 3.虚函数的重写(覆盖) 4.虚函数重写的两个例外 5.c11 override和final 6.重载&#xff0c;覆盖(重写)和隐藏(重定义) 2、抽象类 概念 接口继承和实现继承 3、多态的原理 1.虚函数表 2.多态的原理 4、多继承中的虚…

武夷山细节决定成败抓质量求生存

在当今竞争激烈的市场环境中&#xff0c;细节决定成败&#xff0c;质量求生存的理念已成为企业发展的关键。蓝鹏测控科技有限公司&#xff0c;一家专业从事工业测量领域的高新技术企业&#xff0c;正是秉持这一理念&#xff0c;在工业测径仪领域取得了显著成就。 蓝鹏测控科技…

Ozon俄罗斯哪些产品热销中?Ozon7月市场热卖趋势放送

Ozon俄罗斯哪些产品热销工具&#xff1a;D。DDqbt。COm/74rD 据Ozon数据&#xff0c;2023年&#xff0c;在自提服务方面&#xff0c;Ozon投资了100亿扩展自提网络&#xff0c;自提点数量激增至超过5万个&#xff0c;是之前的2.6倍。 物流基础设施方面&#xff0c;Ozon在仓库建…

BGP第二日

上图为今日所用拓扑 &#xff0c;其中R1和R4&#xff0c;R3和R5为EBGP邻居&#xff0c;R1和R3为IBGP邻居&#xff0c;AS200区域做OSPF动态路由 一.BGP建立邻居的六种状态 1.idle 空闲状态&#xff1a;建立邻居最初的状态 2.Connect 连接状态&#xff1a;在…

360安全浏览器就是不行-python秒破解

下面画框都很容易破解&#xff0c;大家试试

ZGC在三色指针中的应用

ZGC基于颜色指针的并发处理算法 ZGC初始化之后&#xff0c;整个内存空间的地址视图被设置为Remapped&#xff0c;当进入标记阶段时的视图转变为Marked0&#xff08;也称为M0&#xff09;或者Marked1&#xff08;也称为M1&#xff09;&#xff0c;从标记阶段结束进入转移阶段时…

怎么样的主食冻干算好冻干?品质卓越、安全可靠的主食冻干分享

当前主食冻干市场产品质量参差不齐。一些品牌过于追求营养数据的堆砌和利润的增长&#xff0c;却忽视了猫咪健康饮食的基本原则&#xff0c;导致市场上出现了以肉粉冒充鲜肉、修改产品日期等不诚信行为。更令人担忧的是&#xff0c;部分产品未经过严格的第三方质量检测便上市销…

MATLAB中的SDPT3、LMILab、SeDuMi工具箱

MATLAB中的SDPT3、LMILab、SeDuMi工具箱都是用于解决特定数学优化问题的工具箱&#xff0c;它们在控制系统设计、机器学习、信号处理等领域有广泛的应用。以下是对这三个工具箱的详细介绍&#xff1a; 1. SDPT3工具箱 简介&#xff1a; SDPT3&#xff08;Semidefinite Progra…

Jetson-AGX-Orin 非docker环境源码编译安装CyberRT

Jetson-AGX-Orin 非docker环境源码编译安装CyberRT 1、安装依赖 sudo apt update sudo apt-get install g gdb gcc cmake sudo apt install libpoco-dev uuid-dev libncurses5-dev python3-dev python3-pip python3 -m pip install protobuf3.14.02、下载CyberRT源码 git cl…

拥抱 AGI:PieDataCS 引领云原生数据计算系统新范式

自2023年后&#xff0c;人工智能技术进入了一个更为成熟和广泛应用的阶段&#xff0c;人工通用智能&#xff08;AGI&#xff09;这一概念也成为了科技界和产业界热议的焦点。本文将结合 AGI 时代背景&#xff0c;从架构设计到落地实践&#xff0c;详细介绍拓数派云原生数据计算…

Spring开发实践(四)

VO&#xff0c;BO&#xff0c;PO&#xff0c;DO&#xff0c;DTO的区别 1、PO&#xff1a;Persistant Object(持久对象)&#xff0c;基本上&#xff0c;PO对象中的属性就是对应着数据库中表的字段&#xff0c;加上⼀些get和set⽅法的组成。例&#xff1a;个⼈信息表中分别有&am…

德国哥廷根大学《Nature Geoscience》最新成果!揭示热带森林对季节性干旱的响应机制!

本文首发于“生态学者”微信公众号&#xff01; 越来越多的研究称热带森林的生产力受到养分限制&#xff0c;这可能影响其对季节性干旱的反应&#xff08;Nature正刊&#xff01;亚利桑那大学 博士生陈舒立一作兼通讯 最新重磅成果&#xff01;&#xff1b;《Nature Geoscience…

简洁易用,快速制作高品质产品册的工具

在数字化时代&#xff0c;高效制作高品质产品册的需求日益增长。市场上涌现出众多声称能够帮助快速制作产品册的工具&#xff0c;但真正能兼顾简洁易用和品质的却寥寥无几。 ​这款工具名为“FLBOOK”&#xff0c;它凭借其强大的功能和简单易用的操作界面&#xff0c;赢得了众多…

RK3568笔记三十三: helloworld 驱动测试

若该文为原创文章&#xff0c;转载请注明原文出处。 报着学习态度&#xff0c;接下来学习驱动是如何使用的&#xff0c;从简单的helloworld驱动学习起。 开始编写第一个驱动程序—helloworld 驱动。 一、环境 1、开发板&#xff1a;正点原子的ATK-DLRK3568 2、系统&#xf…