我来介绍通过代码逐步实现接口自动化测试框架的设计过程。先不要着急,框架设计我们只是介绍基本的组件,而且框架设计没有想象那么难,一步一步跟着做就会了。这篇我们来演示,如果通过Java代码来实现一个用纯代码实现Http中的Get请求过程。

1.Get请求API举例

浏览器打开网址https://reqres.in,然后下拉一屏,我们就可以看到这个网站的API举例,我们来看看显示用户的get接口。

通过这个图,我们能够获取这些信息

1)网站host地址:https://reqres.in/

2)用户展示请求方式是: Get

3)接口的url 是: /api/users

4)接口的响应状态码是200,还可以看到响应body的JSON内容。

 获取上面这些接口信息之后,我们在本地postman上来测试一下,如果没有postman请安装一个和postman差不多的能做接口手工测试的图形化界面工具,例如jmeter等。

 

这个接口,我们通过postman手动测试,发现和网站提供的是一样结果,说明这get请求的接口测试通过。那么如果我们想通过Java代码实现,需要怎么做呢?接下来,才是本篇的重点内容。

 2.代码过程

前面一篇文章,我们介绍了基础环境的搭建过程,这里,接着前面的环境来逐步完成一个Get请求的设计和测试过程。

2.1 设计配置文件

 我们这个序列是要教会大家设计接口自动化测试框架的目的,所以我们一些设计和组织项目结构的方式,需要参考框架的思维。写一个配置文件,很简单,意义就是方便测试多套环境下的接口测试。我们工作中,一个项目,分测试环境,预发布环境和线上生产环境,这三套环境,接口肯定是一样,只不过服务器地址不同,所以,我们框架设计需要支持写一套接口测试用例,在三套环境上可以跑得同。

在src/main/java下新建一个包:com.qa.config,然后在新包下新建一个config.properties文件,文件内容如下。

然后在src/main/java下新建一个包:com.qa.base,新建一个TestBase.java,这个类作为所有接口请求测试的父类,都需要继承这个父类,目前我们就写一个构造方法,实现加载读取properties文件。

TestBase.java 代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

package com.qa.base;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.util.Properties;

public class TestBase {

     

    public Properties prop;

     

    //写一个构造函数

    public TestBase() {

         

        try {

            prop = new Properties();

            FileInputStream fis = new FileInputStream(System.getProperty("user.dir")+

 "/src/main/java/com/qa/config/config.properties");

            prop.load(fis);

        } catch (FileNotFoundException e) {

            e.printStackTrace();

        } catch (IOException e) {

            e.printStackTrace();

        }      

    }  

}

这里来复习下构造函数的作用,上面我们把加载配置文件的代码写在空参构造里,好处就是,每初始化这个类的对象就会执行构造函数的代码,即执行读取配置文件这么一个作用。关于上面配置文件路径是否拼接正确,你可以新建一个main方法的类,执行打印语句:System.out.println(System.getProperty("user.dir"));

目前,项目结构图如下

2.2 Get请求方法代码实现

在src/main/java下新建一个包:com.qa.restclient,然后新建一个RestClient.java文件,下面是具体代码,实现了get请求,和得到相应状态码和响应头信息,以及响应主体的json内容。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

package com.qa.restclient;

  

import java.io.IOException;

import java.util.HashMap;

import org.apache.http.Header;

import org.apache.http.client.ClientProtocolException;

import org.apache.http.client.methods.CloseableHttpResponse;

import org.apache.http.client.methods.HttpGet;

import org.apache.http.impl.client.CloseableHttpClient;

import org.apache.http.impl.client.HttpClients;

import org.apache.http.util.EntityUtils;

  

import com.alibaba.fastjson.JSON;

import com.alibaba.fastjson.JSONObject;

  

public class RestClient {

     

     

    //1. Get 请求方法

    public void get(String url) throws ClientProtocolException, IOException {

         

        //创建一个可关闭的HttpClient对象

        CloseableHttpClient httpclient = HttpClients.createDefault();

        //创建一个HttpGet的请求对象

        HttpGet httpget = new HttpGet(url);

        //执行请求,相当于postman上点击发送按钮,然后赋值给HttpResponse对象接收

        CloseableHttpResponse httpResponse = httpclient.execute(httpget);

         

        //拿到Http响应状态码,例如和200,404,500去比较

        int responseStatusCode = httpResponse.getStatusLine().getStatusCode();

        System.out.println("response status code -->"+responseStatusCode);

         

        //把响应内容存储在字符串对象

        String responseString = EntityUtils.toString(httpResponse.getEntity(),"UTF-8");

         

        //创建Json对象,把上面字符串序列化成Json对象

        JSONObject responseJson = JSON.parseObject(responseString);

        System.out.println("respon json from API-->" + responseJson);

         

        //获取响应头信息,返回是一个数组

        Header[] headerArray = httpResponse.getAllHeaders();

        //创建一个hashmap对象,通过postman可以看到请求响应头信息都是Key和value得形式,所以我们想起了HashMap

        HashMap<String, String> hm = new HashMap<String, String>();

        //增强for循环遍历headerArray数组,依次把元素添加到hashmap集合

        for(Header header : headerArray) {

            hm.put(header.getName(), header.getValue());

        }

         

        //打印hashmap

        System.out.println("response headers -->"+ hm);

         

    }

}

上面的get方法代码写得比较乱,需要认真看注释,不然层次不清晰。这段代码肯定需要以后重构的,我们刚开始,方便我们测试就先这样去写就好。目前,项目结构图如下

2.3 TestNG用例测试Get方法

在src/test/java下新建一个包:com.qa.tests,然后新建一个GetApiTest.java类,写一个TestNG的测试用例来测试下我们上面写的Get请求方法。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

package com.qa.tests;

  

import java.io.IOException;

  

import org.apache.http.client.ClientProtocolException;

import org.testng.annotations.BeforeClass;

import org.testng.annotations.Test;

  

import com.qa.base.TestBase;

import com.qa.restclient.RestClient;

  

public class GetApiTest extends TestBase{

    TestBase testBase;

    String host;

    String url;

    RestClient restClient;

     

     

    @BeforeClass

    public void setUp() {

        testBase = new TestBase();

        host = prop.getProperty("HOST");

        url = host + "/api/users";

         

    }

     

    @Test

    public void getAPITest() throws ClientProtocolException, IOException {

        restClient = new RestClient();

        restClient.get(url);

    }

}

选择run as testng,运行,输出结果如下:

1

2

3

4

5

[RemoteTestNG] detected TestNG version 6.14.3

response status code -->200

respon json from API-->{"per_page":3,"total":12,"data":[{"last_name":"Bluth","id":1,"avatar":"https://s3.amazonaws.com/uifaces/faces/twitter/calebogden/128.jpg","first_name":"George"},{"last_name":"Weaver","id":2,"avatar":"https://s3.amazonaws.com/uifaces/faces/twitter/josephstein/128.jpg","first_name":"Janet"},{"last_name":"Wong","id":3,"avatar":"https://s3.amazonaws.com/uifaces/faces/twitter/olegpogodaev/128.jpg","first_name":"Emma"}],"page":1,"total_pages":4}

response headers -->{Transfer-Encoding=chunked, Server=cloudflare, CF-RAY=41e822894b39336d-HKG, Access-Control-Allow-Origin=*, ETag=W/"1bb-D+c3sZ5g5u/nmLPQRl1uVo2heAo", Connection=keep-alive, Set-Cookie=__cfduid=d9d93dc43c046707f916670ef491f4c8e1526917157; expires=Tue, 21-May-19 15:39:17 GMT; path=/; domain=.reqres.in; HttpOnly, Date=Mon, 21 May 2018 15:39:17 GMT, Content-Type=application/json; charset=utf-8, X-Powered-By=Express, Expect-CT=max-age=604800, report-uri="https://report-uri.cloudflare.com/cdn-cgi/beacon/expect-ct"}

PASSED: getAPITest

接下来,我们把响应内容的的body的json内容拷贝到一个在线的Josn格式化显示网站(https://www.json.cn/),看看效果如下。

 

这个结果和postman上一样,数据都对得上,本篇关于Java代码基于Httpclient开源库实现Get请求的过程就介绍到这里。

​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:485187702【暗号:csdn11】

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 希望能帮助到你!【100%无套路免费领取】

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐