EasyMock

1 什么是EasyMock

​ Easy Mock 是杭州大搜车无线团队出品的一个极其简单、高效、可视化、并且能快速生成模拟数据的在线 mock 服务。以项目管理的方式组织 Mock List,能帮助我们更好的管理 Mock 数据。

地址:https://www.easy-mock.com

在线文档:https://www.easy-mock.com/docs

2 EasyMock基本入门

2.1初始设置

(1)登录或注册。

浏览器打开https://www.easy-mock.com 输出用户名和密码,如果不存在会自动注册。注意:请牢记密码,系统没有找回密码功能!

在这里插入图片描述

登录后进入主界面

在这里插入图片描述

(2)创建项目:点击右下角的加号

在这里插入图片描述

填写项目名称,点击创建按钮

在这里插入图片描述

创建完成后可以在列表中看到刚刚创建的项目

2.2接口操作

(1)创建接口。点击列表中的项目

在这里插入图片描述

进入项目工作台页面

在这里插入图片描述

点击“创建接口” ,左侧区域输出mock数据,右侧定义Method 、 Url 、描述等信息。

在这里插入图片描述

我们可以将我们在Mock.js入门案例中的对象放入左侧的编辑窗口

{
  'list|10': [{
    "id|+1": 1,
    "name": "@cname",
    "cfirst": "@cfirst",
    "Last": "@Last",
    "point": "@integer",
    "birthday": "@date",
    "pic": "@image",
    "content": "@cword(30,200)",
    "url": "@url",
    "ip": "@ip",
    "email": "@email",
    "region": "@region",
    "county": "@county"
  }]
}

填写url Method 和描述 ,点击创建按钮

(2)克隆接口和修改接口

(3)预览接口和复制接口地址

(4)删除接口

3 本地部署EasyMock

3.1 Centos部署node.js

(1)将node官网下载的node-v8.11.1-linux-x64.tar.xz 上传至服务器

(2)解压xz文件

xz -d node-v8.11.1-linux-x64.tar.xz

(3)解压tar文件

tar -xvf node-v8.11.1-linux-x64.tar

(4)目录重命名

mv node-v8.11.1-linux-x64 node

(5)移动目录到/usr/local下

mv node /usr/local/

(6)配置环境变量

vi /etc/profile

填写以下内容

#set for nodejs  
export NODE_HOME=/usr/local/node  
export PATH=$NODE_HOME/bin:$PATH

执行命令让环境变量生效

source /etc/profile

查看node版本看是否安装成功

node -v

3.2 MongoDB安装与启动

我们使用yum方式安装mongoDb

(1)配置yum

vi /etc/yum.repos.d/mongodb-org-3.2.repo

编辑以下内容:

[mongodb-org-3.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.2/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.2.asc

(2)安装MongoDB

yum install -y mongodb-org

(3)启动MongoD

systemctl start mongod

3.3 Redis安装与启动

(1)下载fedora的epel仓库

yum install epel-release

(2)下载安装redis

yum install redis

(3)启动redis服务

systemctl start redis

3.4 本地部署easy-mock

(1)项目下载地址: https://github.com/easy-mock/easy-mock

(2)将easy-mock-dev.zip上传至服务器

(3)安装zip 和unzip

yum install zip unzip

(4)解压

unzip easy-mock-dev.zip

(3)进入其目录,安装依赖

npm install

(4)执行构建

npm run build

(5)启动

npm run start

(6)打开浏览器 http://192.168.184.131:7300

在这里插入图片描述

导入SwaggerAPI文档

(1)将我们的SwaggerAPI文档扩展名改为yml

(2)在easyMock中点击“设置”选项卡

(3)SwaggerDocs API 选择Upload

在这里插入图片描述

(4)将SwaggerAPI文档拖动到上图的虚线区域,点击保存

(5)回到主界面后点击“同步Swagger”

### Easymock 使用指南及示例 #### 创建 Mock 对象 为了创建 mock 对象,可以使用 `@TestSubject` 和 `@Mock` 注解来简化这一过程。这使得测试类能够自动识别并替换被测对象及其依赖项[^1]。 ```java import org.easymock.EasyMockRunner; import org.junit.runner.RunWith; @RunWith(EasyMockRunner.class) public class ExampleTest { @TestSubject private ClassUnderTest systemUnderTest = new ClassUnderTest(); @Mock private Dependency dependency; } ``` #### 设置预期行为 通过定义方法调用的期望结果来进行设置。对于每一个要模拟的方法调用,都需要指定其返回值或异常抛出情况,并且可以通过 `expect()` 方法链式调用来实现这一点。 ```java @Test public void shouldReturnExpectedValue() { // Arrange expect(dependency.someMethod()).andReturn("expected value"); // Act & Assert replay(dependency); assertEquals(systemUnderTest.methodToTest(), "expected value"); verify(dependency); } ``` #### 验证交互 完成动作之后,应该验证所有已记录的行为确实发生过一次而且仅有一次;如果某些特定条件下的操作未被执行,则应确保这些情形也被适当处理了。此步骤通常放在断言之前执行以确认所有的预设都被满足。 ```java verify(dependency); // Verifies that all expected interactions occurred. ``` #### 控制重复次数 除了简单的单次匹配外,还可以利用 `times(int)` 或者其他类似的限定符来自定义某个行为发生的频率范围。这对于那些需要多次触发相同逻辑的情况特别有用。 ```java // Expecting method to be called exactly twice. expect(dependency.anotherMethod()).andReturn(true).times(2); ``` #### 处理参数变化 当面对具有不同输入值得函数时,可借助于捕获器(Capture)机制收集实际传入的数据以便后续分析,或是采用更为灵活的方式——即允许任意类型的实参传递给目标方法而不限定具体形式。 ```java // Using anyInt() matcher for integer parameters. dependency.processData(anyInt()); expectLastCall().once(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值