• 12
  • 12
分享

接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。

测试的策略:

接口测试也是属于功能测试,所以跟我们以往的功能测试流程并没有太大区别,测试流程依旧是:

  1. 评审测试接口文档(需求文档);

  2. 根据接口文档编写测试用例(用例编写完全可以按照以往规则来编写,例如等价类划分,边界值等设计方法);

  3. 执行测试,查看不同的参数请求,接口的返回的数据是否达到预期。

那么设计测试用例时我们主要考虑如下几个方面:

功能测试:

  • 接口的功能是否正确实现了;

  • 接口是否按照设计文档中来实现(比如username参数写为了user,那么这就不符合,因为接口文档在整个开发中都需要使用,所以接口实际的设计要与接口设计文档中保持一致);

  • 兼容性测试:比如说今天接口进行了调整,但是前端没有进行变更,这时候需要验证新的接口是否满足旧的调用方式;

  • 错误码测试:通用的错误码与业务错误码是否能够清晰的说明调用问题,错误码是否能够尽可能的全的覆盖所有的情况;

  • 返回值测试:返回值除了内容需要是正确的,还需要类型也是正确的,保证调用方拿到这些参数能够正确的解析;

  • 参数边界值、等价类测试;

  • json格式测试:通常我们的接口一般设计的都是传递json串,那么就需要去测试如果传递非json的情况,这时候程序会不会正确的处理,返回相应的errorcode;

  • 默认值测试:很多情况一些非必填的参数会有默认值,比如说一个查询的接口,参数count为返回查询的结果数量,默认为10,那么就应该有一条case来测试,当然前置条件是数据库里面必须要存在这样的数据超过10条。

逻辑业务:

  • 是否有依赖业务,比如查看订单,是需要用户首先登录的,所以肯定要保证登录了或有相应的cookie

  • 业务逻辑测试:传递正确的参数,接口对数据库进行查询的操作,需要去验证数据库查询是否正确,接口对数据库进行增删改的操作,也需要看数据库是否同步进行了这些操作。

异常测试:

异常分为两类,参数异常和数据异常

参数异常:

  • 关键字参数:将参数写为开发语言中的关键字

  • 参数为空:比如去掉了username参数

  • 多或少参数:多或者少参数的验证,现在还不确定如果一个接口多了参数如果没有报错是否是合理的,或者是否需要优化,因为就目前开发给予的答案是,一般不对接口多了参数的处理

  • 错误参数:比如将username参数写为了user等看是否能返回相应的errorcode

数据异常:

  • 关键字数据:将参数的值填为开发语言中的关键字

  • 数据为空:将参数的额值填为空

  • 长度不一致:因为数据库中每个字段都设置有字段长度,填写不符合的长度进行验证

  • 错误数据:就是将参数的值任意填写,或填写不存在的数值

  • 异常类型测试:比如count参数,这个参数的类型一定是可以转换为int类型的,这时候我们需要测试如果传的一些不可以转换为int类型值来测试代码是否加入判断

性能测试:

  • 响应时间

  • 吞吐量

  • 并发用户数

  • 占用内存,CPU等

安全性测试:

  • 敏感信息是否加密

  • 必要参数是否后端也进行校验(现在很多系统前后端架构是分离的,从安全层面来说,只依赖前端进行限制已经完全不能满足系统的安全要求(绕过前端太容易了),需要后端同样进行控制,在这种情况下就需要从接口层面进行验证)

  • 接口是否防恶意请求(SQL注入)

  • cookie:就是将header中的cookie修改或删除后看是否能返回相应的errorcode

  • header:就是删除或修改header中部分参数的值,看是否能返回相应的errorcode

  • 唯一识别码:删除修改唯一识别码测试


作者:fireporsche

原文链接:https://www.cnblogs.com/fireporsche/p/9949805.html

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 缘由很多情况下我们写程序过程中只会对固定模块采取并发限制,而且asp.net对于多线程也有他自己的处理机制,尤其对于注重业务,结果导向的团队可能更注重一定时间节点给出满意的产品,但是你的模块到底是否健壮,你心理有谱吗? 大声的告诉我 are you sure? 下面我们通过一个工具来窥探一下.He is Jmeter!基本简介Apache JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试但后来扩展到其他测试领域。 它可以用于测试静态和动态资源例如静态文件、Java 小服务程序、CGI 脚本、Java 对象、数据库, FTP 服...
            2 2 2290
            分享
          • 1.BUG等级划分建议:目前project上的BUG严重程度分为五个等级,按照CMM5中定义的规范,BUG严重等级可分为3-5个等级,由于我们公司的CMM水平还处于初级阶段,将BUG等级划分过细不符合我们当前的CMM水平,同时也不利于测试人员对BUG等级的精确划分。根据我们公司的情况,同时参照其它中小公司的等级划分标准,建议将BUG等级划分四个等级,分别为致命、严重、一般、提示。致命(可对应目前BUG体系中的“非常严重”):致命性问题主要为:系统无法执行、崩溃或严重资源不足、应用模块无法启动或异常退出、无法测试、造成系统不稳定。具体基本上可分为:严重花屏内存泄漏用户数据丢失或破坏系统崩溃/死机...
            0 0 3598
            分享
          • 1、按严重程度分类:是指bug对软件质量的破坏程度,即此bug的存在将对软件的功能和性能产生什么样的影响。崩溃(Blocker):系统无法正常运行。阻碍开发或测试工作的问题;造成系统崩溃、死机、死循环、导致数据库数据丢失,与数据库连接错误,主要功能丧失,基本模块缺失等问题。如:代码错误、死循环、数据库发生死锁、重要的一级菜单功能不能使用等(该问题在测试中较少出现,一旦出现应立即中止当前版本测试)。严重(Critical):很明显的错误性的bug。系统主要功能部分丧失、数据库保存调用错误、用户数据丢失,一级功能菜单不能使用但是不影响其他功能的测试。功能设计与需求严重不符模块无法启动或调用,程序重...
            0 0 1211
            分享
          • http接口工具有很多如:postman、jmeter、soupUI、Java+httpclient、robotframework+httplibrary等1、什么是接口接口就是内部模块对模块,外部系统对其他服务提供的一种可调用或者连接的能力的标准接口的种类和分类:webservice和http api接口1)webservice接口是走soap协议通过http传输,请求报文和返回报文都是xm格式,可以通过jme、soapui工具进行测试;2)http api接口是走http协议通过路径来区分调用的方法,请求报文格式都是key-value形式,返回报文一般是json串,常见的请求方式有get、...
            1 1 1682
            分享
          • 1、什么是TDD我第一次接触TDD这个概念,是在《代码整洁之道》中,作者鲍勃大叔在书中,写了一些关于测试代码的代码规范,其实就提到了有关TDD三定律:定律一: 在编写不能通过的单元测试前,不可编写生产代码 定律二: 只可编写刚好无法通过的单元测试,不能编译也算不能通过 定律三:只可编写刚好足以通过当前失败测试的生存代码我第一次读到这三个定律时,不能说是毫无头绪,只能说是一脸懵逼。完全不知道作者想表达啥意思,也没有案例代码。对此,我不得不网上查阅的很多相关文章,最后总结出来。TDD测试驱动开发,就是先写测试用例,再去开发功能。 这里测试驱动开发里的驱动是做动词,不是名词好了,...
            1 1 1997
            分享
      • 51testing软件测试圈微信