目錄
- Mock概念
- Mock類
- 簡單的例子體驗下 Mock 的功能特點
- 一個相對正式的 Mock 例子
- 一個完整的測試例子
- 斷言方法
Mock概念
mock 的意思是模擬,也就是模擬接口返回的信息,用已有的信息替換它需要返回的信息,從實現(xiàn)對所依賴的模塊的測試。
一般有兩種場景:
- 前端對后端接口的 mock,
- 后端服務(wù)之間的測試中涉及的mock,常常發(fā)生在單元測試的時候。
前端mock可以通過一些工具來完成:
- 使用抓包工具Fiddler,Charles 來實現(xiàn),通過修改代理返回的數(shù)據(jù),實現(xiàn)多種場景的測試。
- 使用一些API管理工具來模擬,比如yapi,Easy Mock 等
- 當(dāng)然有編碼能力的,也可以使用node.js,python的fastAPI來模擬
后端的 Mock 則是從接口的角度,如果一個接口A返回的數(shù)據(jù)需要依賴于另一個接口B,當(dāng)敏捷開發(fā)中B接口還未開發(fā)完全時候這里會需要用到 Mock。
對于測試人員,對接口測試的時候,部分接口尚未開發(fā)完成,在約定了接口定義之后,也可以使用 Mock 來模擬。
在 python3.X 中 Mock 模塊已經(jīng)被集成到unittest里面。
Mock類
class Mock(spec=None,side_effect=None,return_value=DEFAULT,name=None)
- spec:定義Mock對象的屬性值,可以是一個列表,字符串,一個對象的實例
- side_effect:可以用來拋出異?;蛘邉討B(tài)改變返回值,可以覆蓋return_value
- return_value:定義mock的返回值
- name:作為mock對象的標識可以在print時候看到
簡單的例子體驗下 Mock 的功能特點
from unittest import mock
def add(num1,num2):
return num1 + num2 # pass
add = mock.Mock(return_value=200) # 創(chuàng)建mock對象
print( add(10,20) )
你會發(fā)現(xiàn)無論輸入的參數(shù)是什么,輸出結(jié)果都是200。等于方法被 Mock 攔截處理了。
一個相對正式的 Mock 例子
正常情況:
import requests
def request_scm():
# res = requests.get('http://www.mysx-scm.com')
res = requests.get('http://baidu.com')
return res.status_code
import unittest
from unittest import mock
class TestScmApi(unittest.TestCase):
def testUrl(self):
# request_scm = mock.Mock(return_value=200)
self.assertEqual(request_scm(), 200, msg='testUrl 出現(xiàn)錯誤')
if __name__ == '__main__':
unittest.main()
可以分別把兩個 # 注釋移到下一句試試。
一個完整的測試例子
import requests
class scmapi():
def request_scm():
res = requests.get('http://www.mysx-scm.com')
# res = requests.get('http://baidu.com')
return res.status_code
def pay_alipay():
'''
待實現(xiàn)
return 200
'''
return 0
import unittest
from unittest import mock
class TestScmApi(unittest.TestCase):
needmock = True
def setUpClass():
print("setUpClass():所有方法之前執(zhí)行")
def tearDownClass():
print("tearDownClass():所有方法之后執(zhí)行")
def setUp(self):
self.scmapi = scmapi()
print("setUp():每個方法之前執(zhí)行")
def tearDown(self):
print("teardown():每個方法之后執(zhí)行")
def test_request_scm(self):
if self.needmock:
scmapi.request_scm = mock.Mock(return_value=200)
self.assertEqual(scmapi.request_scm(), 200, msg='test_request_scm 出現(xiàn)錯誤')
def test_pay_alipay(self):
if self.needmock:
scmapi.pay_alipay = mock.Mock(return_value=200)
self.assertEqual(scmapi.pay_alipay(), 200, msg='test_pay_alipay 出現(xiàn)錯誤')
if __name__ == '__main__':
unittest.main()
斷言方法
基本的斷言方法提供了測試結(jié)果是True還是False。所有的斷言方法都有一個msg參數(shù),如果指定msg參數(shù)的值,則將該信息作為失敗的錯誤信息返回。
序號 |
斷言方法 |
斷言描述 |
1 |
assertEqual(arg1, arg2, msg=None) |
驗證arg1=arg2,不等則fail |
2 |
assertNotEqual(arg1, arg2, msg=None) |
驗證arg1 != arg2, 相等則fail |
3 |
assertTrue(expr, msg=None) |
驗證expr是true,如果為false,則fail |
4 |
assertFalse(expr,msg=None) |
驗證expr是false,如果為true,則fail |
5 |
assertIs(arg1, arg2, msg=None) |
驗證arg1、arg2是同一個對象,不是則fail |
6 |
assertIsNot(arg1, arg2, msg=None) |
驗證arg1、arg2不是同一個對象,是則fail |
7 |
assertIsNone(expr, msg=None) |
驗證expr是None,不是則fail |
8 |
assertIsNotNone(expr, msg=None) |
驗證expr不是None,是則fail |
9 |
assertIn(arg1, arg2, msg=None) |
驗證arg1是arg2的子串,不是則fail |
10 |
assertNotIn(arg1, arg2, msg=None) |
驗證arg1不是arg2的子串,是則fail |
11 |
assertIsInstance(obj, cls, msg=None) |
驗證obj是cls的實例,不是則fail |
12 |
assertNotIsInstance(obj, cls, msg=None) |
驗證obj不是cls的實例,是則fail |
以上就是python 如何在測試中使用 Mock的詳細內(nèi)容,更多關(guān)于python 測試中使用Mock的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- python測試框架unittest和pytest區(qū)別
- python使用pytest接口自動化測試的使用
- python 如何用 Hypothesis 來自動化單元測試
- python 基于DDT實現(xiàn)數(shù)據(jù)驅(qū)動測試
- Python自動化測試基礎(chǔ)必備知識點總結(jié)
- Python3 + Appium + 安卓模擬器實現(xiàn)APP自動化測試并生成測試報告
- 基于Python的接口自動化unittest測試框架和ddt數(shù)據(jù)驅(qū)動詳解
- Appium+Python實現(xiàn)簡單的自動化登錄測試的實現(xiàn)
- python如何進行基準測試