草庐IT

接口Mock测试结合postman运用

飞天娃娃鱼 2023-04-22 原文

目录

一、接口Mock测试

1.1 基本概念

1.2实现方式

二、Moco框架

2.1 Moco介绍

2.1.1 环境搭建

2.1.2  Moco运行

2.2常用参数配置

2.2.1定义请求方法

2.2.2 定义查询参数

2.2.3 定义请求头

2.2.4 定义form格式的请求体

2.2.5 定义json格式的请求体

2.2.6 设置响应状态码:

2.2.7 设置返回json格式的响应体数据  

2.2.8 解决中文乱码问题

2.3 Moco引入配置文件


一、接口Mock测试

1)在前后端分离的项目中,后端代码尚为开发完毕,前端需要调用后端接口进行调试该怎么办?

2)在电商企业中,调用第三方接口,如何测试支付失败的场景?

1.1 基本概念

mock:模拟的、仿制的、虚假的

Mock测试:在测试过程中, 对于某些不容易构造或者不容易获取的对象,可以用一个虚拟的对象来代替的测试方法。

接口Mock测试:在接口测试中,对于某些不容易构造或者不容易获取的接口,可以用一个模拟接口来代替。

作用:

        1)可以用来接触而是对象对外部服务的依赖,使得测试用例可以独立运行。

        2)替代外部服务调用或一些速度较慢的操作,提升测试用例的运行速度。

        3)模拟异常逻辑,异常逻辑往往很难触发,通过Mock可以认为的触发异常逻辑。

        4)团队可以并行工作

1.2实现方式

核心实现:搭建一个Mock Server,通过该服务提供mock接口。

具体实现: 

        1)使用第三方mock平台,Fiddler、postman...

        2)自己开发mock服务,python+Flask开发的mock服务;

拓展:Flask是一个用python编写的轻量级Web应用程序框架,使用该框架可以非常方便的开发web项目。

下载安装:pip install flask

验证:flask --version 或者:pip show flask

        3)使用moco框架搭建moco服务

二、Moco框架

2.1 Moco介绍

介绍:Moco是一个简单搭建模拟服务器的框架(工具),可以模拟http、https、socket等协议。

基于java开发的开源项目,Github地址:https://github.com/dreamhead/moco;

原理:Moco会根据一些配置,启动一个真正的HTTP服务(会监听本地的某个端口),当发起的请求满足某个条件时,就会返回指定的响应数据。

2.1.1 环境搭建

1)前提:java运行环境

2)安装:moco-runner -1.1.0-standalone.jar

3)运行Moco:

2.1.2  Moco运行

1)创建配置文件,命名为test.json

[ 
{ 
"description": "首页", 
"request": { 
"uri": "/index" 
},
"response": {
 "text": "hello world" 
}
 } 
]

2)启动http服务,参数为

java -jar <path-to-moco-runner>http -p<monitor -port>-c <configuration -fie>

<path-to-moco-runner>:jar 包的路径

<monitor -port>:http 服务监听端口

<configuration -fie>:配置文件路径

示例:java -jar moco-runner-1.1.0-standalone.jar http -p 9999 -c test.json

3)接口访问:输入命令后打开服务器,看到对应的模拟服务器响应。

2.2常用参数配置

2.2.1定义请求方法

在requests中通过method指定请求方法

[
{
"description": "首页",
"request": {
"uri": "/index",
"method": "post"
},
"response": {
"text": "post请求的hello world"
}
}
]

2.2.2 定义查询参数

通过queries来定制查询参数

[
{
"description": "首页",
"request": {
"uri": "/index",
"method": "get",
"queries": {
"area": "010",
"kw": "hello"
}
},
"response": {
"text": "query params: hello world"
}
}
]

每次修改配置文件时,只要终端没关闭,会自动更新文件,直接刷新网页就会看到返回数据变化。

2.2.3 定义请求头

通过headers参数定义

[
{
"description": "登录",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"area": "010",
"kw":"hello"
}
},
"response": {
"text": "set headers: hello world"
}
}
]

post请求可以在postman中建立mock用例集实现,具体结果如下:

 

2.2.4 定义form格式的请求体

通过forms定义表单格式请求体
[
{
"description": "登录",
"request": {
"uri": "/login",
"method": "post",
"forms": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "login success"
}
}

2.2.5 定义json格式的请求体

可以通过json参数定义请求体

[
{
"description": "登录",
"request": {
"uri": "/login"
},
"response": {
"headers": {
"Content-Type": "application/json;charset=UTF-8"
},
"json": {
"code": "10000",
"msg": "操作成功",
"data": {
"uid": 2,
"token": "xxx"
}
}
}
}
]

2.2.6 设置响应状态码:

[
{
"description": "首页",
"request": {
"uri": "/index2"
},
"response": {
"status": 500,
"text": "error"
}
}
]

在postman中输入对应的uri与请求方式,可以得到相应的响应。

2.2.7 设置返回json格式的响应体数据  

[
{
"description": "登录",
"request": {
"uri": "/login"
},
"response": {
"headers": {
"Content-Type": "application/json;charset=UTF-8"
},
"json": {
"code": "10000",
"msg": "操作成功",
"data": {
"uid": 2,
"token": "xxx"
}
}
}
}
]

2.2.8 解决中文乱码问题

[
{
"description": "登录",
"request": {
"uri": "/login"
},
"response": {
"headers": {
"Content-Type": "application/json;charset=gbk"
},
"json": {
"code": "10000",
"msg": "操作成功",
"data": {
"uid": 2,
"token": "xxx"
}
}
}
}
] 

2.3 Moco引入配置文件

可以对多个接口进行测试,只需要在postman中对url进行切换即可实现。

首先需要定义被依赖的多个配置文件 ,login.json的文件
[
{
"description": "登录",
"request": {
"uri": "/login"
},
"response": {
"text": "success"
}
}
]

index.json文件

[
{
"description": "首页",
"request": {
"uri": "/index"
},
"response": {
"text": "hello world"
}
}
]

定义config.json配置文件

[
{
"include": "index.json"
},
{
"include": "login.json"
}
]

把三个数据文件放在一起,重新使用java命令通过-g参数指定config.json,完整命令是:

java -jar moco-runner-0.11.0-standalone.jar http -p 8092 -g config.json

原来-c改成-g实现多接口测试。

有关接口Mock测试结合postman运用的更多相关文章

  1. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  2. ruby-on-rails - 结合 meta_search 与 acts_as_taggable_on - 2

    我在开发的Rails3网站的一些搜索功能上遇到了一个小问题。我有一个简单的Post模型,如下所示:classPost我正在使用acts_as_taggable_on来更轻松地向我的帖子添加标签。当我有一个标记为“rails”的帖子并执行以下操作时,一切正常:@posts=Post.tagged_with("rails")问题是,我还想搜索帖子的标题。当我有一篇标题为“Helloworld”并标记为“rails”的帖子时,我希望能够通过搜索“hello”或“rails”来找到这篇帖子。因此,我希望标题列的LIKE语句与acts_as_taggable_on提供的tagged_with方法

  3. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  4. ruby - Ruby 的 Hash 在比较键时使用哪种相等性测试? - 2

    我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。

  5. ruby - RSpec - 使用测试替身作为 block 参数 - 2

    我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere

  6. ruby - Sinatra:运行 rspec 测试时记录噪音 - 2

    Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/

  7. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test

  8. ruby - 即使失败也继续进行多主机测试 - 2

    我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r

  9. ruby-on-rails - 如何使辅助方法在 Rails 集成测试中可用? - 2

    我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel

  10. ruby-on-rails - Cucumber 是否只是 rspec 的包装器以帮助将测试组织成功能? - 2

    只是想确保我理解了事情。据我目前收集到的信息,Cucumber只是一个“包装器”,或者是一种通过将事物分类为功能和步骤来组织测试的好方法,其中实际的单元测试处于步骤阶段。它允许您根据事物的工作方式组织您的测试。对吗? 最佳答案 有点。它是一种组织测试的方式,但不仅如此。它的行为就像最初的Rails集成测试一样,但更易于使用。这里最大的好处是您的session在整个Scenario中保持透明。关于Cucumber的另一件事是您(应该)从使用您的代码的浏览器或客户端的角度进行测试。如果您愿意,您可以使用步骤来构建对象和设置状态,但通常您

随机推荐