一、什么是API接口测试?

API接口有多种,个人将其划分为三类。
第一种是函数级别的,测试需要对接口的各个参数进行测试,如:
Int getResult(String key, String ID, Int ticket)。
第二种是对象级别的,开发在使用API接口时,先引入包名,在使用之前声明一个对象,之后可以使用对象提供的方法,而测试时,需要测试的是API的功能及对数据输入的正确性。第二种和第一种的差别是,我们只需关注提供给用户使用的接口就可以了,不用关心接口调用其他函数情况,相对于第一种来说,测试的粒度要大一些,范围小一些。
第三种是http协议的接口,App客户端和后端服务连接,一般采用的都是http协议,客户端通过get和post的方法从后端服务获取数据。第三种相对于第二种来说,粒度更大,我们关注的接口更少,但是这些接口都是核心功能。

二、为什么要测试API接口?

App后端服务,在出现功能异常时,或者吐出异常数据时,可能会导致客户端功能异常,甚至出现崩溃的现象。而客户端由于数据的问题而崩溃,如果容错不到位,可能导致App永远无法启动。这种伤害,对用户,对公司来说,都是巨大的。因此有必要进行API接口的测试。

三、如何来测试API接口?

目前测试API接口的方法很多,如:使用fiddler的发送get、post的功能进行校验。缺点是,测试一遍后,在回归测试时,需要手动再执行一遍,非常耗时。
有人建议使用python的request进行API接口测试时,通过编码方式进行API接口测试,的确是一个好的方法。但是问题是,时间。在有限的测试时间内,可能没有时间去做这个脚本。如果完成这个脚本,至少要进行一轮手工测试,从而才能了解到期望的返回值是什么样的。
有没有这样一种工具,手动测试完成后,不需要写太多代码,立马可以用功能性测试的cases进行自动化回归呢?
答案:有。PostMan就是这一款工具,既可以像使用Fiddler一样,也可以像使用脚本一样。

  • 试用范围:http  API接口的测试

  • 支持的平台:windows& Mac OS

环境的搭建

  1. 安装chrome浏览器

  2. 在chrome地址栏打开:https://chrome.google.com/webstore/search/postman

  3. 填加postman 和 postmaninterceptor
    注:
    postman是一个独立的chromeapp;
    postman interceptor 可以和postman进行数据同步,并将chrome浏览器中的浏览记录发送到postman。

  4. 在chrome地址栏打开:chrome://extensions/,点击postman下的“详细信息”,填加快捷方式到桌面。

  5. 启动postman并注册一个账号。

Postman的使用

  1. 在chrome浏览器中打开postman interceptor同步开关

  2. 启动post man,打开同步开关

  3. 在chrome浏览器中访问搜狗首页,在postman history的tab下可以看到访问的记录

  4. 填加一个检查点

① 选择需要检查的请求,如:m.sogou.com,点击 GET 请求右侧的 Send 按钮,在body部分可以看到返回的数据。

② 点击请求部分底部的Tests,并从右侧检查点中,选择需要验证的点,如:验证返回的内容中包含“微信”,点击“Response body: Contains string”,则会在检验区域加入一行检查语句,并将要检查的字符串,改成“微信”。然后点击“Save”保存,将检查的请求添加到Collections中。

5. 自动运行检查的集合

①  点击“Collections”Tab,选择建立的集合,点击集合的“Run”按钮,进入Test页面。在Test页面选择,Start Test

6. 测试结果会在右侧的Results的tab中显示出来

7. PostMan支持多种不同的请求。从GET列表中可以选择需要测试的类型。

NewMan的使用

在正确性测试时,可以把要测试请求全部保存下来,这样可以在后续的bug验证及回归时使用。未来再有相同模块提测时,跑一遍之前的脚本,既可以完成之前功能的回归验证。
NewMan是命令行的工具,需要在PC上安装NPM,node环境。安装完成后,进行如下命令安装newman 。

安装完成后,首先需要将postman中的脚本保存到本地,然后在命令行中          执行,即可生成测试报告。

① 将PostMan的Collections保存到本地。

② 在命令行执行postman的脚本

③ newman -c Test.json.postman_collection –Hresult.html

④ 运行完成后,会生成一个html结果页面。

PostMan的优点是:

1. 任何人都可以使用,不需要编码能力;

2. 功能测试时的cases即刻可以变成自动化用例;

3. 像使用Fiddler一样,查看数据的返回情况。

HTTP API接口测试利器PostMan介绍的更多相关文章

  1. 数据接口测试工具 Postman 介绍

    此文介绍好用的数据接口测试工具 Postman,能帮助您方便.快速.统一地管理项目中使用以及测试的数据接口. 1. Postman 简介 Postman 一款非常流行的 API 调试工具.其实,开发人 ...

  2. API测试利器postMan 使用教程

    自从开始做API开发之后,我就在寻找合适的API测试工具.一开始不是很想用Chrome扩展,用的 WizTools 的工具,后来试过一次 Postman 之后就停不下来了,还买了付费的Jetpacks ...

  3. API自动化测试利器——Postman

    自从开始做API开发之后,我就在寻找合适的API测试工具.一开始不是很想用Chrome扩展,用的WizTools的工具,后来试过一次Postman之后就停不下来了,还买了付费的Jetpacks.推出T ...

  4. 测试RESTful API利器-Postman

    对于前端开发者而言,最需要的往往不是技术本身,其实技术都没什么难的,而最缺少的则是各种各样好的兵器,比如调试,开发工具等等. 我们这里就推荐一款前端开发的利器-Postman,它是Google Chr ...

  5. Postman API 接口测试、Jenkin 持续集成测试

    Postman 是一个创建和使用API的应用,Postman 对于Web开发者来说非常有用,Postman 带来的便利有很多,诸如: RESTFul接口测试不依赖其他端,进度不受影响 测试脚本即文档, ...

  6. 初步探究Android App API接口测试--实战

    一.Android App API接口测试 1.如何学好Android App API接口测试 postman可以用来实现API接口自动化测试,但是也有弊端,无法实现接口测试数据的参数化,为了达到接口 ...

  7. REST API接口测试

    背景介绍 为什么要做借口测试? 很多系统关联都是基于接口来实现的,接口测试可以将复杂的系统关联进行简化. 接口功能比较单一,能够比较好的进行测试覆盖,也相对容易实现自动化持续集成. 接口相当于界面功能 ...

  8. 实战Rest API接口测试

    一.Android App API接口测试 1.如何学好Android App API接口测试 postman可以用来实现API接口自动化测试,但是也有弊端,无法实现接口测试数据的参数化,为了达到接口 ...

  9. 1、postman介绍与安装

    postman介绍 官方介绍:Developers use Postman to build modern software for the API-first world. 个人理解postman是 ...

随机推荐

  1. WebRTC 源码分析(三):安卓视频硬编码

    数据怎么送进编码器? 怎么从编码器取数据? 如何做流控? 在开始之前,我们先了解一下 MediaCodec 的基本知识. MediaCodec 基础 Developer 官网 上的描述已经很清楚了,下 ...

  2. C51寄存器

    EA   全局中断允许位 ET2 定时器/计时器2中断允许位 ES 串行口中断允许位 ET1 定时器/计时器1中断允许位 EX1 外部中断1中断允许位 ET0 定时器/计时器0中断允许位 EX0 外部 ...

  3. 请教 JTable 里的单元格如何使得双击进入单元格后,单元格的内容处于全选中状态

    http://bbs.csdn.net/topics/390195204 ———————————————————————————————————————— java 达人, 最近在开发一个 java  ...

  4. svn 怎么直接同步指定服务器的某个文件夹

    背景:首先在svn代码库了,我直接从服务器上拖了一个文件夹下来,但是没有显示svn相关信息(比如:左下角的勾勾).这个时候因为直接拖动下来的时候没有生成对应的.svn文件,所以导致. 解决办法: 选中 ...

  5. jQuery验证控件jquery.validate.js的使用介绍

    官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuery plugin: Validation 使用说明 转载 ...

  6. JS函数重载解决方案

    JS的函数定义可以指定形式参数名称,多多少少我们会以为js至少可以支持参数个数不同的方法重载,然而遗憾的是这仅仅是一个假象,js所有的参数都是以arguments传递过去的,这个参数类似于数组,在函数 ...

  7. 2015年第六届蓝桥杯C/C++B组省赛题目解析

    一.奖券数目 有些人很迷信数字,比如带“4”的数字,认为和“死”谐音,就觉得不吉利.虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求.某抽奖活动的奖券号码是5位数(10000-99999),要求其中 ...

  8. e867. 获取和设置外观

    To change the look and feel, you need to know the class name of the new look and feel. This example ...

  9. Python之Python 安装环境搭建

    方法和步骤: python安装包的下载:http://111.13.109.34:83/1Q2W3E4R5T6Y7U8I9O0P1Z2X3C4V5B/www.python.org/ftp/python ...

  10. 用js实现table内容从下到上连续滚动

    网上有很多用ul实现新闻列表滚动的例子,但是很少有直接用table实现列表内容滚动的例子,而Marquee标签滚动的效果不是很好,于是就自己写了一个,提供给攻城师朋友们参考 实现思路:由于table包 ...