web如何做接口层面自动化测试?

98 阅读2分钟

接口层面约等于集成化测试,且需要启动web容器

一般web项目的,代码都是按照分层开发的,业务主要是集中在service和dao层,而我们如果仅仅是利用之前的单元测试,然后把依赖的代码直接mock掉,仅仅测试controller这一块是没有太大的意义。

那么接口层面测试一般是集成测试,需要整体测试到web-->service-->dao层的业务,是需要完完整整的启动web项目,甚至像正式环境一样,测接口,从业务层到数据库层面都正常测试。

如何避免测试的时候导致脏数据的问题。

1、直接使用测试环境

2、出现加入事务管理,每次运行测试之后,都需要rollback数据库。

接口层面如何快速的写断言和测试逻辑。

我们大部分web项目,都是前后端分离的,大部分都是rest接口,返回结果是json。那么强类型的Java,肯定不如动态语言,像ruby 和 js一样,直接操作json。而是需要映射成实体来操作。

引入一个rest-assured框架来解决问题。

<dependency>
      <groupId>io.rest-assured</groupId>
      <artifactId>rest-assured</artifactId>
      <version>5.3.1</version>
      <scope>test</scope>
</dependency>
{
   "lotto":{
      "lottoId":5,
      "winning-numbers":[2,45,34,23,7,5,3],
      "winners":[
         {
            "winnerId":23,
            "numbers":[2,45,34,23,3,5]
         },
         {
            "winnerId":54,
            "numbers":[52,3,12,11,18,22]
         }
      ]
   }
}
@Test 
public void lotto_resource_returns_200_with_expected_id_and_winners() {

    when().
            get("/lotto/{id}", 5).
    then().
            statusCode(200).
            body("lotto.lottoId", equalTo(5),
                 "lotto.winners.winnerId", hasItems(23, 54));

}

接口测试案例

  • 启动web容器(spring容器)
  • 指定测试环境
  • 写接口测试逻辑

思考一个问题:测试接口的输入,就是测试用例。输出是测试报告。

1、如果是在ci层面做,就是在构建完成之后,跑单元测试,然后集成测试,然后输出报告,测试是在每次编译的时候,或者是手动CI触发。

如果我们通过代码层面来写测试用例,需要mock一些东西,且操作后的数据还需要rollback,每次测试的时候,还要不断的启动web容器,既然输入是测试用例,为什么不直接搭建一个环境,然后直接通过测试用例的管理项目,来直接真实跑,数据报告更好。

还可以结合postman 或者其他技术,把测试用例,通过表格来管理。直接导入导出到系统,然后自己跑就行。

gitee.com/amazingTest…

gitee.com/season-fan/…