zoukankan      html  css  js  c++  java
  • 学习笔记-接口测试基础

    什么是接口

    接口一般来说有两种:一种是程序内部的接口;一种是系统对外的接口。

    什么是接口

    Webservice接口和http api接口是最常用的两种接口

    Webservice接口是走soap协议通过http传输,请求报文和返回报文都是xml格式的,通过工具(如:soapui)进行调用和测试

    Http api接口是走http协议,通过路径来区分调用的方法,请求报文都是key-value形式的,返回报文一般都是json串,常用的请求方式有:get、post

    什么是接口测试

    接口测试是对系统组件间接口的测试,它属于功能测试。其实接口测试和普通功能测试的区别就在于:功能测试是在页面上点点点,在页面上输入值,提交数据看结果,而接口测试没有页面,通过接口规范文档上的调用地址、请求参数,拼接报文,然后发送请求,检查返回结果

    咱们测的都是程序对外部的接口,接口其实就是各种操作数据库。通常软件由前端(客户端)及后端(服务端、server端)组成,前端主要是负责展示效果,后端负责业务逻辑处理。比如付款操作时,前端进行付款可成功,其实后端也同样需要校验才能付款金额是否正确,界面操作只能判断前端(客户端)是否校验,只有对前后端之间的该接口进行测试才能判断后端(服务端、server端)是否也进行检验

    接口测试的必要性

    一、可以发现很多在页面上操作发现不了的bug

    二、检查系统的异常处理能力

    三、 检查系统的安全性、稳定性

    四、前端随便变,接口测好了,后端不用变

    接口测试的流程

    一、需求评审,熟悉业务和需求

    二、开发提供接口文档

    三、编写接口测试用例

    四、用例评审

    五、提测后开始测试

    六、提交测试报告

    接口规范文档 是接口测试的重要依据。接口文档至少包括:

    1、接口说明

    2、调用url

    3、请求方法(getpost)

    4、请求参数、参数类型、请求参数说明

    5、返回参数说明

    如何测接口-Http 接口 

    有了接口文档后,可根据接口文档来拼接参数调用接口。接口请求报文拼接有:

    1、最简单的一种是:url?param=value&param2=value  问题前面是请求url,后面是请求的参数名和参数值,多个参数用&连接

                               如:http://httpbin.org/get?key2=value2&key1=value1

    2、还有一种就是:入参是json串格式的。这种格式不能把参数直接连在url中,需要写在请求的body里面,可借助工具Postman

               常用的请求有:GET和POST。GET请求通常用来接收数据,POST请求通常用来发送数据;测GET请求可直接用浏览器就能发请求,不需要借助工具,GET请求             没有请求体(body),只有请求头(header),请求的参数只能写在url里面或者cookie里面;POST请求既有请求头(header)也有请求体(body),请求参数               放在请求体(body)里面,从而需要借助工具进行发送请求

    发送请求后,Http会返回一个状态码表示是否请求成功,状态码有三位,其中开头一位确定了状态类型:

             ①  2xx: 表示请求发送成功,常见200

             ②  3xx: 代表重定向,要完成请求必须进行更进一步的操作,或把请求重定向到别的地方了,最常见的是302

             ③  4xx: 客户端错误,请求有语法错误或请求无法实现,常见的有:

                  400代表客户端发送的请求有语法错误,不能被服务器所理解;

                  401代表访问的页面没有授权;

                  403服务器收到请求,但是拒绝提供服务,比如没有权限访问这个页面;

                  404请求的资源不存在,比如输入错的URL没有这个页面。

             ④  5xx: 代表服务器有异常,常见的有:

                  500代表服务器内部异常;

                  503服务器当前不能处理客户端的请求,一段时间后可能恢复正常;

                  504代表服务器端超时,没返回结果。

    如何测接口-Webservice 接口 

    不需要拼接报文,直接把webservice地址或wsdl文件(这两个都由开发人员提供)直接在soapui导入,就可以看到所有接口及报文,直接填写参数发送请求,查看返回结果就可以了

    接口测试用例设计

    1、通过性验证:首先保证测试的接口是可以用的,按文档正常传入,查看是否可以返回正确的结果

    2、参数组合: 按接口文档中对参数的要求进行有目的的组合。比如有一个收藏接口,参数有:id,flag(值为1时为收藏,值为0时为取消收藏),则需要对flag的两种情况分别与id组合测试

    3、接口安全:

                ①  绕过正常值验证

                ②  绕过身份授权验证

                ③  参数是否加密,加密规则是否容易破解

                ④  密码安全规则,密码的复杂程度校验

    4、异常验证:不按照接口文档上的要求输传参,来验证接口对异常情况的校验。主要检查点有三方面:必传非必传、参数类型、入参长度

    5、根据业务逻辑进行设计测试用例,比如注册接口,短信验证码30分钟有效;做任务接口,需要完成初级任务才能做中级任务.....

    接口测试用例模板   

    进行接口测试,也需要编写测试用例,因而就有接口测试模板了。模板其实没有定性,可根据公司项目情况增减相关描述,公司统一模板就好。参考模板中体现字段有:

    1、项目            是哪个项目的

    2、模块            测试接口是属于哪个模块的

    3、用例id

    4、接口名称

    5、用例标题      这个测试用例功能描述

    6、请求方式      GET/POST

    7、请求url        URL地址

    8、请求参数

    9、前置条件       执行当前请求依赖的条件,不满足就不能正确执行

    10、结果验证     预期结果

    11、请求报文     

    12、返回报文  

    13、测试结果    通过/失败

    14、测试人员   

                              

  • 相关阅读:
    Spring 系列目录
    Netty 源码 ChannelHandler(四)编解码技术
    Netty 源码 ChannelHandler(三)概述
    Netty 源码 Channel(二)核心类
    Netty 源码 Channel(二)主要类
    NOIP 2017 PJ
    初学 Size Balanced Tree(bzoj3224 tyvj1728 普通平衡树)
    一文读懂后缀自动机 Suffix_Automata
    完美字符子串 单调队列预处理+DP线段树优化
    棋盘覆盖 状压DP+矩阵快速幂
  • 原文地址:https://www.cnblogs.com/fenggf/p/8559697.html
Copyright © 2011-2022 走看看