前情介紹:
接口測試通常是系統(tǒng)之間交互的接口,或者某個系統(tǒng)對外提供的一些接口服務(wù)役电,目前公司里大部分的接口都是RESTful赚爵,還有一些webservice接口。現(xiàn)在大家也越來越多的關(guān)注接口測試了法瑟,因為有時候可能界面上的功能還沒有實現(xiàn)冀膝,我們可以先一步對接口進行驗證,提早發(fā)現(xiàn)一些和預(yù)期不一致的錯誤霎挟。做接口測試的工具很多窝剖,本質(zhì)上是基于協(xié)議的測試,而最常見的接口測試基本是基于于http協(xié)議中的GET和POST請求酥夭。
在上一個列子中赐纱,我們已經(jīng)了解到基于RF的協(xié)議測試庫我們首推requests和requestsLibrary脊奋,所以在這個接口API測試中我們也選取requestsLibrary庫。
練習(xí)環(huán)境配置
實例1(UI自動化-百度搜索)
實例2(有效登錄)
實例3(無效登錄)
實例4 (Appium)
實例5 (連接mysql數(shù)據(jù)庫)
實例6 (GET/POST請求)
Appium Error總結(jié)
robotframework Error總結(jié)
測試需求:
測試被測系統(tǒng)中的兩個接口(一個為GET疙描,一個為POST)
測試設(shè)計:
測試接口的思路主要是針對于不同的輸入?yún)?shù)是否有對應(yīng)的正確返回值的一個檢查诚隙。
此例中我們僅實現(xiàn)輸入?yún)?shù)合法的GET接口和輸入?yún)?shù)不合法的POST接口作為示例。剩下的以此類推了起胰。
此例中的GET接口輸入?yún)?shù)需要為eid或者name久又,我們先選取已有的eid=1的數(shù)據(jù)作為輸入,正常返回值為status 200待错,message:success
返回的是一個json數(shù)據(jù)籽孙。
POST接口需要的輸入?yún)?shù)較多,從不合法角度出發(fā)火俄,可以考慮只輸入一個參數(shù)的情況下犯建,返回值應(yīng)該為status 10021,message:parameter error
測試實現(xiàn)
1 . 導(dǎo)入必須的庫requestsLibrary和Collections
2 . 先Create Session創(chuàng)建一個連接到服務(wù)器的host瓜客,然后通過Get Request發(fā)起請求适瓦,請求的返回是個Request對象${r},所以在這里的變量是個對象谱仪,而對象的屬性值的有${r.status_code}和${r.content}玻熙,使用了To Json后,就把返回的content格式化成Json串疯攒,然后就可以用Dictionary的方法獲取其中的值了嗦随。
3 .將 Dictionary中的值取出和預(yù)期值進行對比。
腳本如圖所示:
4.如果要測試的是post的接口敬尺,也很方便枚尼。同理可得先Create Session創(chuàng)建一個連接到服務(wù)器的host,然后通過Post Request發(fā)起請求砂吞,請求的返回是個Request對象${r}署恍,所以在這里的變量是個對象,而對象的屬性值的有${r.status_code}和${r.content}蜻直,使用了To Json后盯质,就把返回的content格式化成Json串,然后就可以用Dictionary的方法獲取其中的值后做斷言概而。
腳本如圖所示:
在這里主要是添加了在headers里面的Content-Type=application/x-www-form-urlencoded呼巷,這是最常見的post提交數(shù)據(jù)的方式,其它方式在之后的案例中會介紹赎瑰。
CC先生說:接口測試維護成本比起UI測試來說要低一些王悍,在接口定義穩(wěn)定的情況下變更不多,就算變更也能很快進行修改乡范。所以推薦大家在考慮自動化策略的時候?qū)⒔涌谧詣踊瘻y試優(yōu)先做起來配名,一定要在上線前跑接口自動化回歸測試,某些時候能夠避免一些接口變更導(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)鍵字的用法:
第一個格子為返回的response對象渠脉,可以賦值給一個變量
第二個格子為post requests關(guān)鍵字
第三個格子之后為可以帶的參數(shù) [ alias | uri | data=None | params=None | headers=None | files=None | allow_redirects=None | timeout=None ](如果不寫的情況下自動留空)
alias:將用于標(biāo)識緩存中的Session對象的別名,也就是上面create session時建的別名
uri:發(fā)送GET請求到的地址瓶佳,可帶參數(shù)
data:數(shù)據(jù),格式為一個鍵值對的字典將作為POST數(shù)據(jù)或作為原始主體內(nèi)容發(fā)送的二進制數(shù)據(jù)或作為多部分表單數(shù)據(jù)傳遞的POST數(shù)據(jù)或二進制數(shù)據(jù)發(fā)送芋膘,也可以用作multipart的數(shù)據(jù)的文件來發(fā)送
params:發(fā)送的消息體中的參數(shù)(也為字典對象)
heards:報文頭,方便修改霸饲,比如content-Type (為字典對象)
file:傳送到server上的文件的名稱
allow_redirects:允許重定向的布爾值为朋。 如果POST / PUT / DELETE重定向以下是允許的,請設(shè)置為True厚脉。
timeout:設(shè)置的超時時間