一、什么是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. PCL点云特征描述与提取(2)

    点特征直方图(PFH)描述子 正如点特征表示法所示,表面法线和曲率估计是某个点周围的几何特征基本表示法.虽然计算非常快速容易,但是无法获得太多信息,因为它们只使用很少的几个参数值来近似表示一个点的k邻 ...

  2. Generalization and Equilibrium in Generative Adversarial Nets

    Paper link: https://arxiv.org/abs/1703.00573 Blog link: http://www.offconvex.org/2017/03/30/GANs2/ G ...

  3. C语言课程设计-保安值班系统支持任意输入保安值班时间

    //.cpp : Defines the entry point for the console application. // #include "string.h" #incl ...

  4. tornado 的 define 和options方法解读

    一.源码解读 tornado是facebook开源的非阻塞web容器,类似java的netty,tornado.options是负责解析tornado容器的全局参数的,同时也能够解析命令行传递的参数和 ...

  5. python写的读取json配置文件

    配置文件默认为conf.json 使用函数set完成追回配置项. 使用load或取配置项. 代码如下: #!/usr/bin/env python3 # -*- coding: utf-8 -*- ' ...

  6. CI框架 -- 核心文件 之 Exceptions.php

    使用CI框架,我们通常使用一下三个函数处理错误: show_error('消息' [, int $status_code = 500 ] ) show_404('页面' [, 'log_error'] ...

  7. php 统计fasta 序列长度和GC含量

    最近php7的消息铺天盖地, 忍不住想尝试下.星期天看了下语法, 写个小脚本练下手: 这个脚本读取fasta 文件, 输出序列的长度和GC含量: <?php $fasta = "tes ...

  8. vue form表单绑定事件与方法

    使用v-on绑定事件 <button @click="hello">Hello</button><br /> <button @click ...

  9. 获取 SharpSvn 执行 svn 操作的实时日志

    1 获取 SharpSvn 操作日志的方式 之前一篇随笔(使用 SharpSvn 执行 svn 操作)讲到可以通过声称一个绑定到一个 SvnClient 对象的 SvnClientReport 对象. ...

  10. Lua string库详解

    1. string库中所有的字符索引从前往后是1,2,...;从后往前是-1,-2,...2. string库中所有的function都不会直接操作字符串,而是返回一个结果 string.byte(s ...