高级Mock

    在测试时,很多时候需要根据不同的请求参数、IP 返回不同的 HTTP Code、HTTP 头和 JSON 数据。

    Mock 期望就是根据设置的请求过滤规则,返回期望数据。

    1. 进入接口详情页,点击『高级 Mock』选项。

    2. 点击『添加期望』,填写过滤规则以及期望返回数据,点击『确定』保存。

    高级Mock - 图1

    高级Mock - 图2

    期望填写

    基本信息

    • 期望名称:给此条期望命名
    • 参数过滤:请求必须包含设置的参数,并且值相等才可能返回期望。参数可以在 Body 或 Query 中。

    响应

    • HTTP Code:期望响应的 HTTP 状态码
    • 延时:期望响应的延迟时间
    • HTTP 头:期望响应带有的 HTTP 头
    • 返回 JSON:期望返回的 JSON 数据

    在前端开发阶段,对于某些接口,业务相对复杂,而 UI 端也需要根据接口返回的不同内容去做相应的处理。

    YApi 提供了写 JS 脚本方式处理这一问题,可以根据用户请求的参数修改返回内容。

    请求

    • header 请求的 HTTP 头
    • params 请求参数,包括 Body、Query 中所有参数
    • cookie 请求带的 Cookies
    • mockJson 接口定义的响应数据 Mock 模板

    • 响应的 HTTP 头

    • httpCode 响应的 HTTP 状态码

    • Random Mock.Random 方法,可以添加自定义占位符,详细使用方法请查看

    使用方法

    1. 首先开启此功能
    2. Mock 脚本就是用 JavaScript 对 mockJson 变量修改,请避免被全局变量(httpCode, resHeader, delay)的修改

    示例2, 生成高度自定义数据内容

    1. var a = [1,1,1,1,1,1,1,1,1,1]
    2. mockJson = {
    3. errcode: 0,
    4. email: Random.email('qq.com'),
    5. data: a.map(function(item){
    6. return Random.city() + '银行'

    请求 Mock 数据时,规则匹配优先级:Mock 期望 > 自定义 Mock 脚本 > 项目全局 mock 脚本 > 普通 Mock。