使用mockserver来进行http接口mock

转载自:https://blog.csdn.net/heymysweetheart/article/details/52227379;(注,这个不是很符合我的要求,它主要的作用是可以通过简单的代码就能filter对方的请求options,然后做出对应的响应;而我需要的是一个能够开启为http服务端来测试客户端发来的http请求的工具,然后顺便看到了这篇感觉以后可能也会用到)

前言

进行单元测试时,必须要mock掉第三方的依赖调用,而mockserver提供了足够的api来支持这种http的mock,现在简单介绍如何使用mockserver进行http接口mock。

依赖

  • mockserver依赖

    
    
    1. <dependency>
    2.  <groupId>org.mock-server</groupId>
    3.  <artifactId>mockserver-netty</artifactId>
    4.  <version>3.10.4</version>
    5. </dependency>
  • httpclient依赖

  1. <dependency>
  2.  <groupId>org.apache.httpcomponents</groupId>
  3.  <artifactId>httpclient</artifactId>
  4.  <version>4.3.3</version>
  5. </dependency>
  6. <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpcore -->
  7. <dependency>
  8.  <groupId>org.apache.httpcomponents</groupId>
  9.  <artifactId>httpcore</artifactId>
  10.  <version>4.3.2</version>
  11. </dependency>

httpclient的版本可能会出现不一致的情况,抛出异常,以上的这个版本匹配是没有异常的组合。

举例


  1. package com.yuliang.dubbo.service;
  2. import org.apache.http.client.methods.CloseableHttpResponse;
  3. import org.apache.http.client.methods.HttpGet;
  4. import org.apache.http.impl.client.CloseableHttpClient;
  5. import org.apache.http.impl.client.HttpClients;
  6. import org.junit.Rule;
  7. import org.junit.Test;
  8. import org.mockserver.client.server.MockServerClient;
  9. import org.mockserver.junit.MockServerRule;
  10. import java.io.BufferedReader;
  11. import java.io.IOException;
  12. import java.io.InputStream;
  13. import java.io.InputStreamReader;
  14. import static org.hamcrest.CoreMatchers.equalTo;
  15. import static org.hamcrest.MatcherAssert.assertThat;
  16. import static org.mockserver.model.HttpRequest.request;
  17. import static org.mockserver.model.HttpResponse.response;
  18. /**
  19. * Created by leo on 16/8/16.
  20. */
  21. public class MockServerTest {
  22.  @Rule
  23.  public MockServerRule server = new MockServerRule(this, 5000);
  24.  @Test
  25.  public void testMockServer() throws IOException {
  26.  MockServerClient mockClient = new MockServerClient("localhost", 5000);
  27.  String expected = "{ message: ‘incorrect username and password combination‘ }";
  28. mockClient.when(
  29. request()
  30.  .withPath("/hello/John")
  31.  .withMethod("GET")
  32. // .withHeader(new Header(HttpHeaders.ACCEPT, MediaType.TEXT_PLAIN))
  33. // .withQueryStringParameter(new Parameter("my-token", "12345"))
  34.  ).respond(
  35. response()
  36.  .withStatusCode(200)
  37.  .withBody(expected)
  38.  );
  39.  CloseableHttpClient client = HttpClients.createDefault();
  40.  HttpGet httpGet = new HttpGet("http://localhost:5000/hello/John");
  41.  CloseableHttpResponse response = client.execute(httpGet);
  42.  //验证输出是否是正确
  43.  InputStream content = response.getEntity().getContent();
  44.  InputStreamReader inputStreamReader = new InputStreamReader(content);
  45.  BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
  46.  String responseText = bufferedReader.readLine();
  47. assertThat(responseText, equalTo(expected));
  48.  }
  49. }
  • mock http post请求

    
    
    1. @Test
    2.  public void testPostMockServer() throws IOException {
    3.  MockServerClient mockClient = new MockServerClient("localhost", 5000);
    4.  String expected = "You have logged in successfully.";
    5. mockClient.when(
    6. request()
    7.  .withPath("/hello/John")
    8.  .withMethod("POST")
    9.  .withHeader(new Header(HttpHeaders.ACCEPT, MediaType.TEXT_PLAIN))
    10. // .withQueryStringParameter(new Parameter("my-token", "12345"))
    11.  .withBody("username=foo&password=123456")
    12.  ).respond(
    13. response()
    14.  .withStatusCode(200)
    15.  .withBody(expected)
    16.  );
    17.  CloseableHttpClient client = HttpClients.createDefault();
    18.  HttpPost httpPost = new HttpPost("http://localhost:5000/hello/John");
    19. httpPost.addHeader("Accept", "text/plain");
    20.  ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
    21. nameValuePairs.add(new BasicNameValuePair("username", "foo"));
    22. nameValuePairs.add(new BasicNameValuePair("password", "123456"));
    23. httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
    24.  CloseableHttpResponse response = client.execute(httpPost);
    25.  //验证输出是否是正确
    26.  InputStream content = response.getEntity().getContent();
    27.  InputStreamReader inputStreamReader = new InputStreamReader(content);
    28.  BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
    29.  String responseText = bufferedReader.readLine();
    30. assertThat(responseText, equalTo(expected));
    31.  }

原文地址:https://www.cnblogs.com/silentdoer/p/9023074.html

时间: 2024-10-03 21:49:01

使用mockserver来进行http接口mock的相关文章

使用electron开发一个h5的客户端应用创建http服务模拟后台接口mock

使用electron开发一个h5的客户端应用创建http服务模拟后端接口mock 在上一篇<electron快速开始>里讲述了如何快速的开始一个electron的应用程序,既然electron是可以直接使用node环境编写程序的,那么我们就可以有很多可以处理的事,比如我们可以做个可视化的前端构建工具,或者我们可以建一个后台的管理系统.基于这两天,我简单的做了一个模拟后端接口的http服务. 它可以完成如下功能: 它可以创建http本地服务 它可以模拟后端的多种请求方式,如get.post.pu

anyproxy-rule模块实现接口mock功能

前言 AnyProxy不仅仅可以抓包,还可以拦截请求并修改服务端响应,实现接口mock功能.面试时候经常会问到第三方支付如何测试这种,如果对接的第三方没提供测试环境,那么就需要搭建一个mock服务器,模拟支付接口返回的各种情况. rule模块 AnyProxy提供了二次开发的能力,你可以用js编写自己的规则模块(rule),来自定义网络请求的处理逻辑. 注意:引用规则前,请务必确保文件来源可靠,以免发生安全问题 拦截并修改正在发送的请求 可修改内容包括请求头(request header),请求

搭建Mock Server

1.为什么要搭建mock-server? 为了更好的分工合作,让前端能在不依赖后端环境的情况下进行开发,其中一种手段就是为前端开发者提供一个 web 容器,这个本地环境就是 mock-server. 目前很多前端 mock 数据的方案的基本流程都是使用 node.js 来模拟 http 请求,配置 router 返回 mock 数据. 一个比较好的 mock-server 该有的能力: 1.与线上环境一致的接口地址,每次构建前端代码时不需要修改调用接口的代码 2.所改即所得,具有热更新的能力,每

使用postman 实现mock测试

mock测试,源自于英文单词fake,意为假的测试 实际工作中用于模拟那些无法实时连接的后端,或是没有开发出来的后端,用于获得结果反馈的一种测试方式.通过发送请求后,模拟后台返回的响应内容来确认当前系统的正确性. 下面通过postman工具来实现mock 要求:要注册后才可以实现 策略:使用mock-server配置私有环境变量并设置相应内容,获取mock-sever的接口密钥AIP-key并创建接口名称,将mock-server的url和接口密钥API-key一并添加在环境变量中,在当前集合中

接口管理

常见的几个接口管理平台简介 年前最后一更,自从Internet服务开发以来,作为开发者阵营,我们已经在实践中证明了前端和后端分离开发模型正逐渐成为越来越多的Internet公司构建服务和应用程序的一种方式. 前端和后端分离的优点很多.一个重要的优点是,对于后台服务(系统),它只需要提供一个统一的API接口,即可被多个客户端重用,并且分工和协作更加精细.大大提高了效率.目前某些公司接口文档管理方式采用word,wiki及html形式,由于版本迭代较快.随之而来的是 接口文档管理混乱,接口描述不清:

[转] 前后端分离开发模式的 mock 平台预研

引入 mock(模拟): 是在项目测试中,对项目外部或不容易获取的对象/接口,用一个虚拟的对象/接口来模拟,以便测试. 背景 前后端分离 前后端仅仅通过异步接口(AJAX/JSONP)来编程 前后端都各自有自己的开发流程,构建工具,测试集合 关注点分离,前后端变得相对独立并松耦合 开发流程 后台编写和维护接口文档,在 API 变化时更新接口文档 后台根据接口文档进行接口开发 前端根据接口文档进行开发 开发完成后联调和提交测试 面临问题 没有统一的文档编写规范,导致文档越来越乱,无法维护和阅读 开

浅谈WireMock结合Mock+Proxy应用于异常测试

为什么需要WireMock 最近在做NCE自动化接口测试,按照尽可能覆盖逻辑的原则,写了200+用例,但实际去实现的时候,大概能做的就100不到,完成的大多是能通过传入参数去控制系统的逻辑走向和结果的case,即传入指定的参数,调用发送请求工具,对结果进行校验.那么除此之外,哪些是难以实现的呢? 从被测系统本身来说,NCE是建立在底层服务之上的一套系统,他的主要职能还是资源分配和调度,比如调云主机的接口拿两台机器,又去申请几块硬盘挂上,然后还要在机器上部署k8s的组件,调k8s创建rc和pod等

Python接口测试实战5(下) - RESTful、Web Service及Mock Server

如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战2 - 使用Python发送请求 Python接口测试实战3(上)- Python操作数据库 Python接口测试实战3(下)- unittest测试框架 Python接口测试实战4(上) - 接口测试框架实战 Python接口测试实战4(下) - 框架完善:用例基类,用例标签,重新运行上次失败用例

Python接口测试题(持续更新中)

1.json和字典的区别? Json是轻量级的数据交互格式,以key-value的键值对形式来保存数据,结构清晰,可以说是目前互联网项目开发中最常用的一种数据交互格式. 字典,同样是以key-value的键值对来保存数据,是python中的一种数据类型. 2.你做接口自动化测试时,测试数据放哪里? 1) 对于一些基础配置比如数据库配置可以放到properties文件(yaml文件,没用过就别拓展了) 2) 接口测试需要用到的数据可以放数据库表,也可以放到excel中. 3.什么是数据驱动? 数据