本篇仍是迴歸到咱們最初始的話題,想必你們都忘記了,不要緊看這裏:傳送門 沒錯最初的話題就是登陸,因爲博客園的登陸機制改變了,本篇以我找到的開源免費的登陸API爲案例,結合 unittest 框架寫 2 個用例。一樣咱們先來看一下接口文檔。html
請求方式:POSTweb
請求地址:https://api.apiopen.top/developerLoginjson
Query參數名 | 類型 | 必需 | 描述 | 示例 e.g. |
---|---|---|---|---|
name | string | 是 | 用戶名 | peakchao |
passwd | string | 是 | 密碼 | 123456 |
返回示例:api
{
"code": 200,
"message": "成功!",
"result": {
"apikey": "b9b3a96f7554e3bead2eccf16506c13e"
}
}
一、針對以上接口文檔,設計這個登陸接口的測試用例app
二、參考代碼框架
1 # coding=utf-8 2 #1.先設置編碼,utf-8可支持中英文,如上,通常放在第一行 3 4 #2.註釋:包括記錄建立時間,建立人,項目名稱。 5 ''' 6 Created on 2019-4-28 7 @author: 北京-宏哥 8 Project:學習和使用unittest框架設計登陸測試用例和斷言-下篇 9 ''' 10 #3.導入requests和unittest模塊 11 import requests 12 import unittest 13 #4.編寫測試用例和斷言 14 class Blog_login(unittest.TestCase): 15 def login(self, username, psw): 16 '''兩個個參數:帳號:username,密碼:psw''' 17 url = "https://api.apiopen.top/developerLogin" 18 par = {"name": username, 19 "passwd": psw 20 } 21 res = requests.post(url, params=par) 22 # result1 = res.text # 字節輸出 23 # print(result1) 24 return res.json() 25 26 def test_login1(self): 27 '''測試登陸:正確帳號,正確密碼''' 28 username = "peakchao", # 正確帳號,抓包得到的加密字符串 29 psw = "123456", # 正確密碼,抓包得到的加密字符串 30 result = self.login(username, psw) 31 self.assertEqual(200,result['code']) 32 print(result['message']) 33 34 def test_login2(self): 35 '''測試登陸:正確帳號,錯誤密碼;反之也能夠設計用例''' 36 username = "peakchao",#正確帳號 37 psw = "122222",#錯誤密碼 38 result = self.login(username, psw) 39 self.assertEqual(result['code'], 400) 40 print(result['message']) 41 def test_login3(self): 42 '''測試登陸:帳號爲空,正確密碼;反之也能夠設計用例''' 43 username = "", # 錯誤帳號 44 psw = "123456", # 正確密碼 45 result = self.login(username, psw) 46 self.assertEqual(result['code'], 400) 47 print(result['message']) 48 if __name__ == "__main__": 49 unittest.main()
一、在實際工做中因爲某些緣由開發人員不能按時給出接口文檔,可是接口已經開發好了,須要測試人員提早介入,此時你又不能等接口文檔寫好了再開始測試,那樣黃花菜都涼了,還有就是接口文檔有是有,可是沒有人更新和維護,若是你按post
照舊文檔保證是會出錯,或者接口不通。因此咱們必須採用另外一種方式開始測試接口。學習
二、那就是咱們本身經過fiddler抓包獲取url和接口的參數以及返回結果等等,仍是因爲博客園的登陸機制的改變,我在這了一jenkins登陸接口爲例給小夥伴們演示一下。測試
三、大體流程:web頁面jenkins點擊登陸—>fiddler抓包獲取登陸接口URL和參數—>從fiddler查看登陸接口返回的結果—>代碼模擬登陸接口並獲取接口登陸返回結果—>設計登陸接口測試用例—>斷言並執行用例編碼
四、web頁面jenkins點擊登陸
五、fiddler抓包獲取登陸接口URL和參數
六、從fiddler查看登陸接口返回的結果
七、代碼模擬登陸接口並獲取接口登陸返回結果
八、設計登陸接口測試用例
九、斷言並執行用例
十、參考代碼
1 # coding=utf-8 2 #1.先設置編碼,utf-8可支持中英文,如上,通常放在第一行 3 4 #2.註釋:包括記錄建立時間,建立人,項目名稱。 5 ''' 6 Created on 2019-4-28 7 @author: 北京-宏哥 8 Project:學習和使用unittest框架設計jenkins登陸測試用例和斷言-下篇 9 ''' 10 #3.導入requests和unittest模塊 11 import requests 12 import unittest 13 #4.編寫測試用例和斷言 14 class Jenkins_login(unittest.TestCase): 15 def login(self, username, psw): 16 '''從fiddler抓包看到事個參數: 17 帳號:j_username,密碼:j_password,from,Submit,remember_me 18 ''' 19 url = "http://localhost.:8080/jenkins/j_acegi_security_check" 20 headers = { 21 "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0" 22 } # get方法其它加個ser-Agent就能夠了 23 par = {"j_username": username, 24 "j_password": psw, 25 "from": "", 26 "Submit": u"登陸", 27 "remember_me": "on" 28 } 29 res = requests.post(url, headers=headers, data=par) 30 result = res.url # 字節輸出 31 print(result) 32 result1 = res.status_code 33 print(result1) 34 return res.status_code 35 36 def test_login1(self): 37 '''測試登陸:正確帳號,正確密碼''' 38 username = "admin", # 正確帳號,抓包得到的加密字符串 39 psw = "111111", # 正確密碼,抓包得到的加密字符串 40 result = self.login(username, psw) 41 self.assertEqual(200,result) 42 43 def test_login2(self): 44 '''測試登陸:正確帳號,錯誤密碼;反之也能夠設計用例''' 45 username = "admin",#正確帳號 46 psw = "122222",#錯誤密碼 47 result = self.login(username, psw) 48 self.assertEqual(result, 404) 49 50 def test_login3(self): 51 '''測試登陸:帳號爲空,正確密碼;反之也能夠設計用例''' 52 username = "", # 錯誤帳號 53 psw = "111111", # 正確密碼 54 result = self.login(username, psw) 55 self.assertEqual(result, 404) 56 57 if __name__ == "__main__": 58 unittest.main()
一、fiddler抓取本地部署的jenkins登陸請求時,抓取不到,可是百度能夠抓取到,解決方法:
(1)使用http://localhost.fiddler 代替http://localhost
(2)使用用 http://localhost. 在locahost後面加一個點號
(3)使用 http://127.0.0.1. 在127.0.0.1後面加一個點號
(4)使用 http://machinename 使用機器名
(5)打開Fiddler,菜單>Fiddler Options>General>Enable IPv6(if avaible)去掉該選項。
(6)在hosts文件中加入127.0.0.1 localsite這樣也能夠被捕獲到。
二、一些免費開源的接口,能夠提供給你們進行練習
隨機推薦熱門段子(包含文字、圖片、GIF、視頻):
https://www.apiopen.top/satinApi?type=1&page=1
隨機推薦熱門段子【神評版本】(包含文字、圖片、GIF、視頻):
https://www.apiopen.top/satinGodApi?type=1&page=1
隨機推薦熱門段子【神評版本】評論列表:
https://www.apiopen.top/satinCommentApi?id=27610708&page=1
熱門小說推薦列表
https://www.apiopen.top/novelApi
小說搜索接口
https://www.apiopen.top/novelSearchApi?name=盜墓筆記
小說詳情接口
https://www.apiopen.top/novelInfoApi?name=盜墓筆記
天氣獲取接口
https://www.apiopen.top/weatherApi?city=成都
美圖獲取接口
https://www.apiopen.top/meituApi?page=1
個性網名獲取接口
https://www.apiopen.top/femaleNameApi?page=1
建立應用接口
https://www.apiopen.top/createUserKey?appId=com.chat.peakchao&passwd=123456
增長統計信息接口
https://www.apiopen.top/addStatistics?appKey=00d91e8e0cca2b76f515926a36db68f5&type=點擊統計&typeId=1&count=2
查詢統計信息接口
https://www.apiopen.top/findStatistics?appKey=00d91e8e0cca2b76f515926a36db68f5
用戶註冊接口
https://www.apiopen.top/createUser?key=00d91e8e0cca2b76f515926a36db68f5&phone=13594347817&passwd=123654
用戶登錄接口
https://www.apiopen.top/login?key=00d91e8e0cca2b76f515926a36db68f5&phone=13594347817&passwd=123456