如果把测试简单地分为两类,那么就是客户端测试和服务器端测试。客户端测试包括UI测试、兼容性测试等,服务器端测试包括接口测试。接口测试检查数据交换、传输和控制管理过程,绕过客户端,直接测试服务器。
客户端测试和服务器测试之间的关系图:
界面测试的价值
服务器非常复杂,就像下面的阿里核心链接图,大概包含150个组件。组件之间相互作用,形成密集的后端网络。UI测试无法覆盖如此复杂的组件交互网络,需要绕过客户端,直接使用接口测试对服务器进行测试。
阿里核心链接图:
界面测试系统
对行业内的各种测试进行分层,级别越高,发现bug越晚,成本(时间、人力、损失)越高。与ui测试相比,界面测试(Service)可以更早发现问题,更快给出质量反馈。同样,与接口测试相比,单元测试可以更早发现问题,提供更快的质量反馈和更低的成本。
分层测试:
客户端测试和服务器测试之间的关系
虽然接口测试覆盖的范围很广,但是不能用来代替客户端测试。UI测试涉及到用户体验的问题,这是界面测试无法替代的。
tcp/udp/http/restful/dubbo等协议的区别与解读
数据包分析tcp协议
TCP是传输层中一种面向连接的、可靠的、基于字节流的传输层通信协议。将接口测试工具分为以下几类:
网络嗅探工具:tcpdump、wireshark代理工具:fiddler、charles、anyproxyburpsuite、mitmproxy分析工具:curl、postman、chrome Devtool使用postman发送请求
作为测试,需要有测试接口的能力。在界面测试中,第一个常用的工具是postman。Postman是一个功能强大的界面测试平台,具有用户友好的可视化界面。它经常被用作开发的接口调试工具和用于测试的手动接口测试工具。
可以进入邮差官网,选择自己的系统下载安装。邮差官网:https://www.postman.com/
邮递员的使用练习
使用邮递员发送获取请求。用https://httpbin.testing-studio.com/,学院的官方练习地址来演示。
进入邮差软件界面,在网址处填写https://httpbin.testing-studio.com/GET,选择获取请求模式,点击表头,填写接受键值,填写申请/json值,点击发送按钮,查看返回内容。
使用curl发送请求
CURL是一个强大的命令行工具,通过URL传输数据。CURL可以与Chrome Devtool结合使用,还原浏览器发送的带有认证信息的真实请求,无需浏览器即可执行。开发人员可以方便地重放请求、修改调试参数和编写脚本。也可以单独使用,根据自己的需求调整参数,构建多种接口测试场景。
在学习curl命令之前,您需要先了解Chrome Devtool工具。
ChromeDevTools
Chrome开发工具
s(Chrome 开发者工具)是内嵌在Chrome浏览器里的一组用于网页制作和调试的工具。在测试的过程中,也常常用作一个简单的抓包工具。如何操作
选择右上角Chrome 菜单,然后选择更多工具 -> 开发者工具或者右键,选择检查/审查元素在 Network 面板中可以查看通过网络来请求来的资源的详细信息:
curl常见用法
从浏览器copy
右键左侧数据,选择Copy -> copy as curl,即可把请求内容转化为curl命令。将命令copy在gitbash或bash上并运行,则会看到返回信息。对上面命令进行细化,加入-v参数可以打印更详细的内容,用2>&1将标准错误重定向到标准输出,发送此命令将得到细化后的内容细化后的命令如下
curl 'https://home.testing-studio.com/' -H 'authority: home.testing-studio.com' -H 'pragma: no-cache' -H 'cache-control: no-cache' -H 'upgrade-insecure-requests: 1' -H 'user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.116 Safari/537.36' -H 'sec-fetch-dest: document' -H 'accept: text/html,application/xhtml+xml, application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8, application/signed-exchange;v=b3;q=0.9' -H 'sec-fetch-site: none' -H 'sec-fetch-mode: navigate' -H 'sec-fetch-user: ?1' -H 'accept-language: en,zh-CN;q=0.9,zh;q=0.8' --compressed -v 2>&1其他常用命令
发起get请求
curl"https://httpbin.testing-studio.com/get" -H "accept: application/json"发起post请求
curl -X POST "https://httpbin.testing-studio.com/post" -H "accept: application/json"proxy的使用
curl -x 'http://127.0.0.1:8080'$urlcurl命令重要参数
参数
含义
-H
消息头设置
-u
用户认证
-d
表示来自于文件
–data-urlencode
对内容进行url编码
-G
把data数据当成get
-o
写文件
-x
http代理、socks5代理
-v
打印更详细日志
-s
关闭一些提示输出
–help
查看帮助
curl实战演练
通过几个小实战演练,了解一些常用参数的用法
1. 篡改请求头信息,将User-Agent改为”testing-studio“
curl -H "User-Agent:testing-studio""http://www.baidu.com" -v可以看到请求中的User-Agent成功改为了testing-studio
* Trying 14.215.177.39... * TCP_NODELAY set * Connected to www.baidu.com (14.215.177.39) port 80 (#0) > GET / HTTP/1.1 > Host: www.baidu.com > Accept: */* > User-Agent:testing-studio2. 在企业微信中通过curl命令创建标签,这是一个post请求,通过--data参数传递tagname和tagid
curl -H "Content-Type: application/json" -X POST --data '{"tagname": "hogwarts","tagid": 13}' https://qyapi.weixin.qq.com/cgi-bin/tag/create?access_token=$token3. 认证,通过put上传到ElasticSearch,使用–user进行用户认证
curl -X PUT "$ES_HOST/$index/_doc/$id?pretty" --user username:password -H 'Content-Type: application/json' -d "$content"