教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

如何使用moco框架搭建接口mock服務(wù)?

更新時間:2020年07月14日16時18分 來源:傳智播客 瀏覽次數(shù):

1、什么是接口Mock測試?

應(yīng)用場景思考?
1.在前后端分離的項目中,假如后端代碼還未開發(fā)完,前端代碼需要調(diào)用后端接口進(jìn)行調(diào)試,該怎么辦?
2.本公司的電商平臺需要對接第三方支付接口,如何測試支付失敗的場景?

1.1 概念

Mock:模擬的、仿制的、虛假的

Mock測試:在測試過程中,對于某些不容易構(gòu)造或者不容易獲取的對象,可以用一個虛擬的對象來代替的測試方法。

接口Mock測試:在接口測試過程中,對于某些不容易構(gòu)造或者不容易獲取的接口,可以用一個模擬接口來代替。

1.2 作用

可以用來解除測試對象對外部服務(wù)的依賴,使得測試用例可以獨立運行

替換外部服務(wù)調(diào)用或一些速度較慢的操作,提升測試用例的運行速度

模擬異常邏輯,異常邏輯往往很難觸發(fā),通過Mock可以人為的控制觸發(fā)異常邏輯

團(tuán)隊可以并行工作

1.3 實現(xiàn)方式

接口mock實現(xiàn)的核心思想是搭建一個Mock Server,通過該服務(wù)提供mock接口。常見的實現(xiàn)方式有:

使用第三方mock平臺

自己開發(fā)mock服務(wù)

使用mock框架搭建mock服務(wù)

2. Moco框架

2.1 Moco簡介

Moco是一個簡單搭建模擬服務(wù)器的框架(工具),可以模擬http、https、socket等協(xié)議

基于Java開發(fā)的開源項目,Github地址:https://github.com/dreamhead/moco

原理:Moco會根據(jù)一些配置,啟動一個真正的HTTP服務(wù)(會監(jiān)聽本地的某個端口)。當(dāng)發(fā)起的請求滿足某個條件時,就會返回指定的響應(yīng)數(shù)據(jù)。

2.2 環(huán)境搭建

Moco運行時所需環(huán)境包括:

Java運行環(huán)境

安裝JDK,并配置環(huán)境變量

moco-runner-1.1.0-standalone.jar

下載地址:https://repo1.maven.org/maven2/com/github/dreamhead/moco-runner/1.1.0/moco-runner-1.1.0-standalone.jar


2.3 如何運行Moco

1>創(chuàng)建配置文件

創(chuàng)建配置文件test.json,并輸入如下內(nèi)容:

[

    {

        "description": "首頁",

        "request": {

            "uri": "/index"

        },

        "response": {

            "text": "hello world"

        }

    }

]

2>啟動http服務(wù)

啟動命令:

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

示例:

java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -c test.json

3>接口訪問

打開瀏覽器,在瀏覽器地址欄中輸入:http://localhost:9090/index

1594714262878_接口Mock測試01.jpg


2.4 Moco常用配置參數(shù)

1.定義請求方式,通過method參數(shù)定義

[

    {

        "description": "首頁",

        "request": {

            "uri": "/index",

            "method": "post"

    },

        "response": {

            "text": "hello world"

        }

    }

]

2.定義請求參數(shù),通過queries參數(shù)定義

[

    {

        "description": "首頁",

        "request": {

            "uri": "/index",

            "method": "get",

            "queries": {

                "area": "010",

                "kw": "hello"

            }

    },

    "response": {

        "text": "hello world"

    }

    }

]


3.定義請求頭,通過headers參數(shù)定義

[

    {

        "description": "登錄",

        "request": {

            "uri": "/login",

            "method": "post",

            "headers": {

                "area": "010"

            }

        },

        "response": {

            "text": "hello world"

        }

    }

]

4、定義表單請求體,通過`forms`參數(shù)定義

[

    {

        "description": "登錄",

        "request": {

            "uri": "/login",

            "method": "post",

            "forms": {

                "username": "tom",

                "password": "123456"

        }

    },

    "response": {

        "text": "login success"

        }

    }

]

5、定義JSON請求體,通過`json`參數(shù)定義

[

    {

        "description": "登錄",

        "request": {

            "uri": "/login",

            "method": "post",

            "headers": {

                "Content-Type": "application/json"

            },

            "json": {

                "username": "tom",

                "password": "123456"

            }

        },

        "response": {

            "text": "hello world66666"

        }

    }

]


6、定義HTTP響應(yīng)狀態(tài)碼,通過`status`參數(shù)定義

[

    {

        "description": "首頁",

        "request": {

            "uri": "/index2"

        },

        "response": {

            "status": 500,

            "text": "error"

        }

    }

]

7、定義JSON響應(yīng)數(shù)據(jù),通過json參數(shù)定義

[

    {

        "description": "登錄",

        "request": {

            "uri": "/login"

        },

        "response": {

            "headers": {

                "Content-Type": "application/json;charset=UTF-8"

            },

        "json": {

            "code": "10000",

            "msg": "操作成功",

            "data": {

                "uid": 2,

                "token": "xxx"

            }

        }

    }

    }

]

2.5 Moco引入配置文件

moco支持在配置文件中引入其他配置文件,這樣可以分服務(wù)/模塊定義配置文件,便于對配置文件的管理。

實現(xiàn)步驟:

1.分服務(wù)/模塊定義配置文件,如分別定義index.json和login.json文件

[

    {

        "description": "首頁",

        "request": {

            "uri": "/index"

        },

        "response": {

            "text": "hello world"

        }

    }

]

[

    {

        "description": "登錄",

        "request": {

            "uri": "/login"

        },

        "response": {

            "text": "success"

        }

    }

]

2.定義啟動配置文件,如config.json并引入其他配置文件

[

    {"include": "index.json"},

    {"include": "login.json"}

]

3.啟動服務(wù)

java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -g config.json

注意:通過"-g config.json"指定配置文件

猜你喜歡:
軟件測試培訓(xùn)課程
什么是關(guān)系型數(shù)據(jù)庫?看這張圖就懂了
最全的軟件測試面試題(含答案)

0 分享到:
和我們在線交談!