API 自动化测试
JMeter
ApiPost产生的初衷是为了提高研发团队各个角色的效率!产品的使用受众为由前端开发、后端开发和测试人员以及技术经理组成的整个研发技术团队。
APIPOST通过协作功能将研发团队的每个角色整合打通。
安装
ApiPost目前提供Window64位,Window32位、Mac、Linux版本的安装包下载。
使用
发送HTTP请求
API界面功能布局
data:image/s3,"s3://crabby-images/011f7/011f7b954dcb2b7198f2838ba173da8d0492e086" alt=""
API请求参数
Header 参数
你可以设置或者导入 Header 参数,cookie也在Header进行设置
Query 参数
data:image/s3,"s3://crabby-images/c3003/c30037155e79d612aaf2eebc05b54cec10dc7cd7" alt=""
Query 支持构造URL参数,同时支持 RESTful 的 PATH 参数(如:id)
Body 参数
Body 提供三种类型 form-data / x-www-form-urlencoded / raw ,每种类型提供三种不同的UI界面
当你需要提交表单时,切换到 x-www-form-urlencoded
data:image/s3,"s3://crabby-images/6a958/6a958c0f8bec9a1b82e93eae65635cc1cd8354f1" alt=""
当你需要提交有文件的表单时,切换到 form-data
data:image/s3,"s3://crabby-images/48499/48499fae01796f654c9ec02d48f0e5242acf9028" alt=""
当您需要发送JSON对象或者其他对象时,切换到对应的raw类型即可
data:image/s3,"s3://crabby-images/8220b/8220b8e51e4b91cff0047ac9c30e235631c8e726" alt=""
API 请求响应
data:image/s3,"s3://crabby-images/f4bc0/f4bc0cb175992cf9a004789b71b61dc39def5013" alt=""
点击发送按钮后,如果有数据返回,则会显示返回数据,响应时间,响应码,Cookie等。
注意:返回数据默认是Pretty模式,便于查看 JSON XML 格式。您可以通过切换 原生 或 预览 模式 查看其它类型的类型。
返回Headers
data:image/s3,"s3://crabby-images/b1d4d/b1d4df0c4ae8bfb90817433e4bfccaf9e1d16624" alt=""
全局参数和目录参数
实际的企业级应用开发常见下,通常会约定一些通用的数据,比如token、时间、终端这些,如果每个接口都去独立去维护,势必会对开发、调试带来一些不必要的工作量;此时,我们就需要有一个能设置全局参数的地方来统一管理这些公共参数
全局参数
我们打开全局参数管理器,在全局header除填上token参数:
data:image/s3,"s3://crabby-images/39e14/39e145b144d3e2f7b4ffb004c04a61b36cc45c6f" alt=""
每次在接口请求的时候,就会自动带上这些公共配置的参数。
目录参数
目录参数和全局参数的作用一样,属于一个更细化的功能,可以通过目录,来区分全局参数的作用域;可以为不同的目录设置不用的公共参数:
data:image/s3,"s3://crabby-images/be8b6/be8b66746088520352984541c3a6b09abf15f3e5" alt=""
参数的优先级
当全局参数、目录参数、接口中都使用了同一个参数时,最终会按照以下优先级读取参数值:
单个接口 > 目录参数 > 全局参数
响应和断言
响应
data:image/s3,"s3://crabby-images/35cfa/35cfa41a74953c070875539c1b2ffafa887c1521" alt=""
当Http请求发送之后,得到的服务端返回的结果表示一个响应;其中会得到状态码、数据、Headers、Cookie等。
Headers
data:image/s3,"s3://crabby-images/50aed/50aed0095b6d12f2548964c226303a8b990e8249" alt=""
断言
服务器返回了响应数据,并不代表着接口就一定正常了,很可能以为bug或者数据异常导致得到的结果并没有达到实际的预期;因此,我们就可以使用断言功能,来判断最终响应的结果是不是我们想要的;
data:image/s3,"s3://crabby-images/d6a85/d6a85601ce01f13f0ffa52be4b3921761901c05b" alt=""
常用断言表达式
1、检查response body中是否包含某个string
apt.assert('response.raw.responseText=="test"'); // 检查响应文本是否等于test字符串
apt.assert('response.raw.responseText.indexOf("test") > -1'); // 检查响应文本是否含有test字符串