robotframework-自動化測試-實(shí)例7(接口API測試)

前情介紹:
接口測試通常是系統(tǒng)之間交互的接口,或者某個(gè)系統(tǒng)對外提供的一些接口服務(wù),目前公司里大部分的接口都是RESTful,還有一些webservice接口。現(xiàn)在大家也越來越多的關(guān)注接口測試了,因?yàn)橛袝r(shí)候可能界面上的功能還沒有實(shí)現(xiàn),我們可以先一步對接口進(jìn)行驗(yàn)證,提早發(fā)現(xiàn)一些和預(yù)期不一致的錯誤。做接口測試的工具很多,本質(zhì)上是基于協(xié)議的測試,而最常見的接口測試基本是基于于http協(xié)議中的GET和POST請求。
在上一個(gè)列子中,我們已經(jīng)了解到基于RF的協(xié)議測試庫我們首推requests和requestsLibrary,所以在這個(gè)接口API測試中我們也選取requestsLibrary庫。

練習(xí)環(huán)境配置
實(shí)例1(UI自動化-百度搜索)
實(shí)例2(有效登錄)
實(shí)例3(無效登錄)
實(shí)例4 (Appium)
實(shí)例5 (連接mysql數(shù)據(jù)庫)
實(shí)例6 (GET/POST請求)
Appium Error總結(jié)
robotframework Error總結(jié)

測試需求:
測試被測系統(tǒng)中的兩個(gè)接口(一個(gè)為GET,一個(gè)為POST)

get.png

post.png

測試設(shè)計(jì):
測試接口的思路主要是針對于不同的輸入?yún)?shù)是否有對應(yīng)的正確返回值的一個(gè)檢查。

Paste_Image.png

此例中我們僅實(shí)現(xiàn)輸入?yún)?shù)合法的GET接口和輸入?yún)?shù)不合法的POST接口作為示例。剩下的以此類推了。

此例中的GET接口輸入?yún)?shù)需要為eid或者name,我們先選取已有的eid=1的數(shù)據(jù)作為輸入,正常返回值為status 200,message:success

get返回.png

返回的是一個(gè)json數(shù)據(jù)。

POST接口需要的輸入?yún)?shù)較多,從不合法角度出發(fā),可以考慮只輸入一個(gè)參數(shù)的情況下,返回值應(yīng)該為status 10021,message:parameter error

測試實(shí)現(xiàn)
1 . 導(dǎo)入必須的庫requestsLibrary和Collections
2 . 先Create Session創(chuàng)建一個(gè)連接到服務(wù)器的host,然后通過Get Request發(fā)起請求,請求的返回是個(gè)Request對象${r},所以在這里的變量是個(gè)對象,而對象的屬性值的有${r.status_code}和${r.content},使用了To Json后,就把返回的content格式化成Json串,然后就可以用Dictionary的方法獲取其中的值了。
3 .將 Dictionary中的值取出和預(yù)期值進(jìn)行對比。
腳本如圖所示:

get.png

4.如果要測試的是post的接口,也很方便。同理可得先Create Session創(chuàng)建一個(gè)連接到服務(wù)器的host,然后通過Post Request發(fā)起請求,請求的返回是個(gè)Request對象${r},所以在這里的變量是個(gè)對象,而對象的屬性值的有${r.status_code}和${r.content},使用了To Json后,就把返回的content格式化成Json串,然后就可以用Dictionary的方法獲取其中的值后做斷言。
腳本如圖所示:

post.png

在這里主要是添加了在headers里面的Content-Type=application/x-www-form-urlencoded,這是最常見的post提交數(shù)據(jù)的方式,其它方式在之后的案例中會介紹。

CC先生說:接口測試維護(hù)成本比起UI測試來說要低一些,在接口定義穩(wěn)定的情況下變更不多,就算變更也能很快進(jìn)行修改。所以推薦大家在考慮自動化策略的時(shí)候?qū)⒔涌谧詣踊瘻y試優(yōu)先做起來,一定要在上線前跑接口自動化回歸測試,某些時(shí)候能夠避免一些接口變更導(dǎo)致的問題。

參考:
post requests的官方的幫助文檔:

Source:
RequestsLibrary <test library>
Arguments:
[ alias | uri | data=None | params=None | headers=None | files=None | allow_redirects=None | timeout=None ]
Send a POST request on the session object found using the given `alias` 
alias that will be used to identify the Session object in the cache 
uri to send the POST request to 
data a dictionary of key-value pairs that will be urlencoded and sent as POST data or binary data that is sent as the raw body content or passed as such for multipart form data if files is also defined 
params url parameters to append to the uri 
headers a dictionary of headers to use with the request 
files a dictionary of file names containing file data to POST to the server 
allow_redirects Boolean. Set to True if POST/PUT/DELETE redirect following is allowed. 
timeout connection timeout

中文:

Post requests關(guān)鍵字的用法:
第一個(gè)格子為返回的response對象,可以賦值給一個(gè)變量
第二個(gè)格子為post requests關(guān)鍵字
第三個(gè)格子之后為可以帶的參數(shù) [ alias | uri | data=None | params=None | headers=None | files=None | allow_redirects=None | timeout=None ](如果不寫的情況下自動留空)
alias:將用于標(biāo)識緩存中的Session對象的別名,也就是上面create session時(shí)建的別名
uri:發(fā)送GET請求到的地址,可帶參數(shù)
data:數(shù)據(jù),格式為一個(gè)鍵值對的字典將作為POST數(shù)據(jù)或作為原始主體內(nèi)容發(fā)送的二進(jìn)制數(shù)據(jù)或作為多部分表單數(shù)據(jù)傳遞的POST數(shù)據(jù)或二進(jìn)制數(shù)據(jù)發(fā)送,也可以用作multipart的數(shù)據(jù)的文件來發(fā)送
params:發(fā)送的消息體中的參數(shù)(也為字典對象)
heards:報(bào)文頭,方便修改,比如content-Type (為字典對象)
file:傳送到server上的文件的名稱
allow_redirects:允許重定向的布爾值。 如果POST / PUT / DELETE重定向以下是允許的,請?jiān)O(shè)置為True。
timeout:設(shè)置的超時(shí)時(shí)間
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,545評論 19 139
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程,因...
    小菜c閱讀 7,324評論 0 17
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,001評論 25 709
  • 今天和孩子商量,自己放學(xué)回家,孩子答應(yīng)嘗試。事情的起因是后期我可能會比較忙,會有不能及時(shí)趕回來接孩子的情況,孩子也...
    sanyaojing閱讀 402評論 0 1
  • 好天氣,適合約會的一天,早安,上海!早安,Jun~ Thanks-given by you!
    帶風(fēng)走路deFENG閱讀 596評論 0 1

友情鏈接更多精彩內(nèi)容