python如何構(gòu)建mock接口服務(wù)
引言
Mock 即模擬,就是在測試過程中,對于某些不容易構(gòu)造或者不容易獲取的對象,用一個(gè)虛擬的對象來創(chuàng)建以便測試的測試方法,其最大的優(yōu)勢就是降級前后端耦合度,使前端工程師可以不依賴后端返回?cái)?shù)據(jù),先開發(fā)前端樣式以及邏輯處理 簡單來說: Mock是用了解決依賴問題的,將復(fù)雜的/不穩(wěn)定的/還未建立的依賴對象用一個(gè)簡單的假對象來代替。
Mock Server 即Mock接口服務(wù)器,可以通過配置快速M(fèi)ock出新的接口
Mock Server的使用范圍:
- 前后端分離項(xiàng)目
- 所測接口依賴第三方系統(tǒng)(還未具備)
- 所測接口依賴復(fù)雜或依賴的接口不穩(wěn)定,并不作為主要驗(yàn)證對象
- 同時(shí)在接口還未開發(fā)好時(shí),提供Mock接口(假接口)會比只有接口文檔更直觀,并能有效減少溝通成本和一些文檔理解
在進(jìn)行接口測試時(shí),往往被測系統(tǒng)需要對接第三方系統(tǒng),然而沒有現(xiàn)成的第三方系統(tǒng)環(huán)境,此時(shí)我們就需要使用mock來解決這種依賴關(guān)系,而python就提供了一個(gè)可以方便構(gòu)建mock api接口服務(wù)的模塊:flask。Flask 是一個(gè)簡單且十分強(qiáng)大的Python web 框架。它被稱為微框架,“微”并不是意味著把整個(gè)Web應(yīng)用放入到一個(gè)Python文件,微框架中的“微”是指Flask旨在保持代碼簡潔且易于擴(kuò)展,F(xiàn)lask框架的主要特征是核心構(gòu)成比較簡單,但具有很強(qiáng)的擴(kuò)展性和兼容性,程序員可以使用Python語言快速實(shí)現(xiàn)一個(gè)網(wǎng)站或 Web服務(wù)。因此flask能很方便構(gòu)建一個(gè)web服務(wù),給外部也可以叫做客戶端提供web服務(wù),針對flask框架這種特點(diǎn)我們可以很容易構(gòu)建API接口,供客戶端訪問。
Flask mock接口開發(fā)示例
首先安裝需要的Flask模塊,如果你的環(huán)境已經(jīng)安裝了pip則鍵入:pip install flask即可安裝完成
或者直接在pycharm中檢索安裝:
1.1 構(gòu)建GET請求方法的接口
在Pycharm中新建py文件,編輯如下代碼
# -*- coding: utf-8 -*- import flask,json import time server = flask.Flask(__name__) # 創(chuàng)建一個(gè)服務(wù),把當(dāng)前這個(gè)python文件當(dāng)做一個(gè)服務(wù) @server.route('/VIID/System/Time', methods=['get']) # @server.route()可以將普通函數(shù)轉(zhuǎn)變?yōu)榉?wù)、接口的路徑、請求方式,如果不寫methods則默認(rèn)get方法 def Time(): '''查詢字符串:無,消息體:無,返回結(jié)果:SystemTime''' response_data = { "SystemTimeObject": { "VIIDServerID": "123", "TimeMode": "1", "LocalTime": time.strftime('%Y%m%d%H%M%S', time.localtime(time.time())), } } return json.dumps(response_data, ensure_ascii=False) if __name__ == '__main__': server.run(debug=True, port=5000, host='10.82.25.11') # 指定訪問端口、host
然后運(yùn)行該py文件,則該文件運(yùn)行在本地就是一個(gè)web服務(wù),用瀏覽器或者postman嘗試訪問該服務(wù)的URL即可
瀏覽器訪問:
postman發(fā)請求訪問:
瀏覽器或者postman請求完成后,在Pycharm的輸出欄會輸出如下:
其它的請求如POST、PUT、DELETE等方法,在methods參數(shù)中指明即可,不過POST、PUT、DELETE等方法不能由瀏覽器直接訪問,因?yàn)闉g覽器默認(rèn)訪問時(shí)是get方法,可以用postman按指定的方法發(fā)請求
1.2 獲取帶json格式請求體的接口
有時(shí)客戶端發(fā)送的請求是帶json格式的,這時(shí)需要獲取請求的json,編輯代碼如下:
@server.route('/data',methods=['post']) def post_json(): if flask.request.is_json: print(flask.request.json) name = flask.request.json.get('name') # 獲取json請求體的第一個(gè)參數(shù)的值 age = flask.request.json.get('age') # 獲取json請求體的第二個(gè)參數(shù)的值 data = {'name':name,'age':age} return json.dumps(data,ensure_ascii=False) else: return json.dumps({'msg':'請傳json格式參數(shù)'},ensure_ascii=False)
使用postman作為客戶端發(fā)送帶json請求體的請求,如下圖:
1.3 獲取get請求中發(fā)送的參數(shù)
flask提供的方法是:
value = flask.request.args.get('name') # 獲取get請求參數(shù)name的值
1.4 構(gòu)建動(dòng)態(tài)URL以及響應(yīng)體的重定向
很多時(shí)候,客戶端請求的url是變化的,也就是帶有動(dòng)態(tài)參數(shù)的,flask也是可以輕松的構(gòu)建提供動(dòng)態(tài)參數(shù)的url資源服務(wù)并重定向響應(yīng)體,代碼如下:
# -*- coding: utf-8 -*- import flask,json from flask import url_for,redirect server = flask.Flask(__name__) # 創(chuàng)建一個(gè)服務(wù),把當(dāng)前這個(gè)python文件當(dāng)做一個(gè)服務(wù) @server.route('/data') def data(): # 返回data data = { 'VideoSliceInfoObject': { 'VideoID': 'esse elit', 'AudioCodeFormat': 'commodo' } } return json.dumps(data, ensure_ascii=False) @server.route('/data/<ID>/Info', methods=['post']) def data_redirect(ID): return redirect(url_for('data', guest=ID)) if __name__ == '__main__': server.run(debug=True, port=5000, host='10.82.25.11') # 指定訪問端口、host
后面無論postman或者客戶端發(fā)送的url中的ID參數(shù)是啥,都可以響應(yīng)
1.5 重新構(gòu)建響應(yīng)頭和響應(yīng)狀態(tài)碼
有時(shí)在與第三方系統(tǒng)對接時(shí),需要返回?cái)y帶響應(yīng)頭消息和指定的響應(yīng)狀態(tài)碼,在flask中也是可以構(gòu)建自定義的響應(yīng)消息的
# -*- coding: utf-8 -*- import flask,json server = flask.Flask(__name__) # 創(chuàng)建一個(gè)服務(wù),把當(dāng)前這個(gè)python文件當(dāng)做一個(gè)服務(wù) @server.route('/data',methods=['post']) def post_json(): if flask.request.is_json: print(flask.request.json) name = flask.request.json.get('name') # 獲取json請求體的第一個(gè)參數(shù)的值 age = flask.request.json.get('age') # 獲取json請求體的第二個(gè)參數(shù)的值 data = {'name':name,'age':age} # 構(gòu)建響應(yīng)頭域和狀態(tài)碼 resp = flask.make_response(json.dumps(data, ensure_ascii=False)) resp.status = "666" resp.headers[ "python"] = "python flask" return resp else: return json.dumps({'msg':'請傳json格式參數(shù)'},ensure_ascii=False) if __name__ == '__main__': server.run(debug=True, port=5000, host='10.82.25.11') # 指定訪問端口、host
運(yùn)行該py文件,在postman中發(fā)送請求,查看響應(yīng)信息,如下圖,變成的我們自定義設(shè)置的響應(yīng)頭和狀態(tài)碼
這樣我們就完全自定義了響應(yīng)的頭和狀態(tài)碼
以上就是python如何構(gòu)建mock接口服務(wù)的詳細(xì)內(nèi)容,更多關(guān)于python 構(gòu)建mock接口服務(wù)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
深入flask之異步非堵塞實(shí)現(xiàn)代碼示例
這篇文章主要介紹了深入flask之異步非堵塞實(shí)現(xiàn)代碼示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07Python利用folium實(shí)現(xiàn)地圖可視化
Folium是建立在Python生態(tài)系統(tǒng)的數(shù)據(jù)整理(Datawrangling)能力和Leaflet.js庫的映射能力之上的開源庫。這篇文章主要給大家介紹了關(guān)于如何Python利用folium實(shí)現(xiàn)地圖可視化的相關(guān)資料,需要的朋友可以參考下2021-05-05Python線性擬合實(shí)現(xiàn)函數(shù)與用法示例
這篇文章主要介紹了Python線性擬合實(shí)現(xiàn)函數(shù)與用法,結(jié)合實(shí)例形式分析了Python使用線性擬合算法與不使用線性擬合算法的相關(guān)算法操作技巧,需要的朋友可以參考下2018-12-12基于python中pygame模塊的Linux下安裝過程(詳解)
下面小編就為大家?guī)硪黄趐ython中pygame模塊的Linux下安裝過程(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11Python寫了個(gè)疫情信息快速查看工具實(shí)例代碼
本次使用PyQt5開發(fā)了一款疫情信息快速查看工具,實(shí)現(xiàn)了多個(gè)數(shù)據(jù)源的查看,代碼量不大,功能相當(dāng)于瀏覽器,只是限定了一些特定網(wǎng)址,這篇文章主要介紹了Python寫了個(gè)疫情信息快速查看工具,需要的朋友可以參考下2022-11-11windows下的pycharm安裝及其設(shè)置中文菜單
這篇文章主要介紹了windows下的pycharm安裝及其設(shè)置中文菜單,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04在Python的Django框架中實(shí)現(xiàn)Hacker News的一些功能
這篇文章主要介紹了在Python的Django框架中實(shí)現(xiàn)Hacker News的一些功能,包括投票“頂”評論等功能,需要的朋友可以參考下2015-04-04python回溯法實(shí)現(xiàn)數(shù)組全排列輸出實(shí)例分析
這篇文章主要介紹了python回溯法實(shí)現(xiàn)數(shù)組全排列輸出,以實(shí)例形式較為詳細(xì)的分析了全排列的定義及回溯法的實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-03-03centos+nginx+uwsgi+Django實(shí)現(xiàn)IP+port訪問服務(wù)器
這篇文章主要介紹了centos+nginx+uwsgi+Django實(shí)現(xiàn)IP+port訪問服務(wù)器,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11