前言
今天呢,筆者想和大家聊聊python+pytest接口自動化中將代碼進行封裝,只有將測試代碼進行封裝,才能被測試框架識別執(zhí)行。
例如單個接口的請求代碼如下:
import requests
headers = {
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36"
}
url = "https://mp.toutiao.com/profile_v4/"
res = requests.get(url=h_url, headers=headers)
假設我們需要將上面這段代碼編寫成測試框架能執(zhí)行的測試用例,僅僅只是這樣寫代碼顯然是不夠的,還需要進行如下補充:
- 需要將代碼封裝成單元測試框架 (pytest或unittest) 能識別的測試函數(shù)或測試類,否則將不會被識別執(zhí)行。
- 需要加上斷言,即結(jié)果與期望之間的對比,單元測試框架才能判定該用例執(zhí)行結(jié)果是否通過,結(jié)果==期望則說明通過,否則失敗。
python中函數(shù)以及類的封裝這里不做過多說明,這篇文章的目的是讓大家明白在接口自動化測試中一般怎樣封裝測試代碼。
一、測試用例封裝的一般規(guī)則
測試用例的封裝有兩種,測試函數(shù)和測試類,封裝的一般規(guī)則如下:
- 一個測試函數(shù)對應一條測試用例。
- 測試類中可定義多個測試方法,一個測試方法對應一條測試用例,測試類可以看作是一個測試用例集。
- pytest中測試函數(shù)或測試方法的命名必須以test開頭,測試類名必須以Test開頭。具體命名規(guī)則可以參考我之前的文章pytest(3)-測試命名規(guī)則。
- 對于單接口的測試校驗,一個單接口的測試用例只包含一個接口請求,即將一個接口請求封裝成一個測試函數(shù)或測試方法。
- 對于場景(多接口) 的測試校驗,一條場景測試用例需請求多個接口,因此需要將多個接口請求封裝在同一個測試函數(shù)或方法中。
- 一般封裝一個接口的正向校驗、異常校驗封裝成不同的方法,并封裝在同一個測試類中。如定義一個登陸的測試類,正確用戶名、密碼請求封裝成一個方法 (即一條測試用例),正確用戶名、錯誤密碼請求封裝成另一個方法 (即另一條測試用例)。
- 也可以將某個功能點或功能相關(guān)聯(lián)的接口用例封裝在同一個測試類中。比如個人中心涉及到的接口,可以封裝在同一個測試類中
二、測試函數(shù)的封裝
一般而言,一個測試函數(shù)對應一條用例。上面的代碼編寫成一條測試用例,示例如下:
強調(diào),pytest中測試函數(shù)命名必須以test開頭,如test_get_home。
三、測試類/方法的封裝
一個測試類相當于一個測試用例集,類中的每個方法對應一條測試用例。以登錄接口為例,封裝成測試類,示例如下:
強調(diào),pytest中測試類命名需要以Test開頭,如TestLogin,且測試類中不能有init方法。測試類中測試方法必須以test開頭,如test_login_normal。
四、示例代碼
pytest中可以使用命令行或者使用代碼方式即 pytest.main() 執(zhí)行用例,具體可參考文章pytest(1)-簡介。
完整的示例代碼如下:
import requests
import pytest
import json
def test_get_home():
'''
請求首頁接口
:return:
'''
headers = {
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36"
}
url = "https://www.cnblogs.com/lfr0123/"
res = requests.get(url=url, headers=headers)
# 斷言,判斷返回結(jié)果的code是否等于200,當然實際接口測試中一般返回結(jié)果中還會有別的字段需要斷言
assert res.status_code == 200
class TestLogin:
'''
登錄接口校驗
'''
url = "http://127.0.0.1:5000/login"
headers = {"Content-Type": "application/json;charset=utf8"}
def test_login_normal(self):
'''正確用戶名、正確密碼登錄'''
data = {
"username": "AndyLiu",
"password": "123456"
}
res = requests.post(url=self.url, json=data, headers=self.headers)
# 斷言
assert res.status_code == 200
assert json.loads(res.text)["token"]
def test_login_error(self):
'''正確用戶名、錯誤密碼登錄'''
data = {
"username": "AndyLiu",
"password": "111111"
}
res = requests.post(url=self.url, json=data, headers=self.headers)
# 斷言
assert res.status_code == 200
assert not json.loads(res.text)["token"]
if __name__ == '__main__':
pytest.main()
總結(jié)
- 測試函數(shù)、測試類/測試方法的封裝,其實不管是什么單元測試框架,遵循的方式都一樣。
- 而在命名方式上各有自己的要求,比如pytest與unittest中測試命名方法有一定的區(qū)別。
- 把一個有自己斷言的函數(shù)或方法看成是一條測試用例,那么測試類其實就是一個含有一條或者多條測試用例的測試用例集,類中的每個方法對應一條測試用例。
- 一個測試類中放置哪些測試方法,換句話說一個測試用例集中應該包含哪些測試用例,這個可以按照項目自身情況而定,也可按照測試人員自己的想法而定,主旨就是要清晰明了
最后這篇文章就到這里了,喜歡的小伙伴可以點贊收藏加關(guān)注喲,關(guān)注我每天給你不同的驚喜。
最后感謝每一個認真閱讀我文章的人,禮尚往來總是要有的,這些資料,對于【軟件測試】的朋友來說應該是最全面最完整的備戰(zhàn)倉庫,雖然不是什么很值錢的東西,如果你用得到的話可以直接拿走:文章來源:http://www.zghlxwxcb.cn/news/detail-837729.html
文章來源地址http://www.zghlxwxcb.cn/news/detail-837729.html
如果你想學習軟件測試和需要軟件測試資料,歡迎加入扣扣交流群:731789136,里面可以免費領取軟件測試+自動化測試資料+軟件測試面試寶典+簡歷模版+實戰(zhàn)項目+面試刷題工具和大佬答疑解惑,我們一起交流一起學習!
到了這里,關(guān)于python+pytest接口自動化之測試函數(shù)、測試類/測試方法的封裝的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!