1、自主研發框架整體設計
1.1、什么是測試框架?
在了解什么是自動化測試框架之前,先了解一下什么叫框架?框架是整個或部分系統的可重用設計,表現為一組抽象構件及構件實例間交互的方法;另一種定義認為,框架是可被應用開發者定制的應用骨架。前者是從應用方面,而后者是從目的方面給出的定義。從框架的定義可以了解,框架可以是被重用的基礎平臺;框架也可以是組織架構類的東西。其實后者更為貼切,因為框和架本來就是組織和歸類所用的。
所以自動化測試框架的定義為:由一個或多個自動化測試基礎模塊、自動化測試管理模塊自動化測試統計模塊等組成的工具集合。
框架的定義來分,自動化測試框架可以分為:基礎功能測試框架、管理執行框架;按不同的測試類型來分,可以分為:功能自動化測試框架、性能自動化測試框架;按測試階段來分,可以分為:單元自動化測試框架、接口自動化測試框架、系統自動化測試框架;按組成結構來分,可以分為:單一自動化測試框架、綜合自動化測試框架;按部署方式來分,可以分為:單機自動化測試框架、分布式自動化測試框架。
看到這里,也許大家看完也不清楚上面到底講的是什么。因為沒有實際接觸過,不知道具體功用,只是用一種抽象解釋另一種抽象,另外只是描述了結論,沒有描述推演的過程。
1.2、那么如何打破阻礙呢?
方法如下:
1、工作遇到了什么問題,需要使用XX技術?
2、這個技術能解決當下的工作問題嗎?解決到什么程度呢?
3、這個技術能做什么,不能做什么?
4、具體如何實現的過程?
當前有下面的腳本需要接入到框架中。
要有以終為始的逆向思維方式,從最下面往上面分析。
1.3、框架測試報告初期規劃:
執行時間,執行人,執行環境..
XXX時間:執行了XXX接口,接口執行結果
XXX時間:腳本報錯信息
框架腳本整體執行情況統計
把框架測試結果發給相關責任人
1.4測試框架驅動設計
1、設置全局環境數據結構
2、讀取測試框架配置文件
3、按照配置文件制定內容執行對應的測試腳本
4、創建測試報告,并寫入總體初始化內容
5、若執行完所有的測試腳本,輸出最終的測試報告,否則繼續執行下一個腳本
6、寫入新的測試報告內容
7、保存測試報告。
1.5 測試框架整體結構
本次測試框架分為三個層。分別為驅動層test_driver,報告層test_report,測試腳本層test_script。
其中config.csv是存放的測試腳本及路徑 。
driverV1.py是驅動的執行程序。
report1.py存放的是測試報告
testcase_report1.txt存放的是單個用例不同數據的執行結果。
2、登錄接口自研框架實踐_global+csv+system文件
driver通過讀取config.csv里面的信息,讀取腳本名,再到test_script下面去找對應的腳本執行。
驅動讀取框架配置文件
3、自研框架類圖及流程圖設計梳理
框架整體流程圖:
config.csv內容
3.1 驅動類設計
進行實例化對象
#導入類庫
import csv,os
import datetime
# 試驗1:普通全局變量的使用
import pymysqlglobal glob_url
glob_url='https://svr-6-9009.share.51env.net/prod-api'
print(glob_url)
# 封裝成一個驅動類
class driver_run():#讀取配置文件,獲取py文件名def run_testpy(self):# 設置腳本程序對應的路徑path = "..\\test_script\\"csvfile=open("config.csv",'r')rows=csv.reader(csvfile)# 跳過標題行next(rows)# 逐行讀取配置文件內容for row in rows:print(row[2])self.number=row[0]self.name = row[1]# 判斷是否創建測試用例報告頭部if row[4]=='Y':if row[3] == '1':self.create_testcase_report()# 調用指定的接口腳本文件os.system("python "+path+row[2])# return row[0],row[1] 不能用面向過程的方法,要用面向對象的方法# 調用報告寫入內容方法self.write_report()self.endtime=datetime.datetime.now()# 獲取當前框架程序運行的總時長,如果時長已經大于50分鐘了,# 主動調用登錄接口,重新更新tokenrtime = self.endtime - self.starttime# 判斷時間差是否超過50分鐘if (rtime.seconds // 60) >= 50:# 調用登錄接口os.system("..\\test_script\\loginV4.py")# 定義創建測試報告并寫入頭部公共信息def create_report(self):self.starttime = datetime.datetime.now()# print(self.starttime)# 時間進行格式化starttime = self.starttime.strftime("%Y-%m-%d %H:%M:%S")print(starttime)# 將時間戳寫入txt文件txtReport = open('..\\test_report\\report1.txt', "w")txtReport.write("*****************************************************************""\n")txtReport.write("智慧物業系統接口測試框架"+"\n")txtReport.write(starttime+" shangshang"+" "+"\n")txtReport.write("接口測試執行環境說明:"+glob_url+"\n")txtReport.write("*****************************************************************"+"\n")txtReport.close()# 定義創建測試用例報告并寫入頭部公共信息def create_testcase_report(self):starttime = datetime.datetime.now()print(starttime)# 時間進行格式化starttime = starttime.strftime("%Y-%m-%d %H:%M:%S")print(starttime)# 將時間戳寫入txt文件txttestReport = open('..\\test_report\\testcase_report1.txt', "w")txttestReport.write("*****************************************************************""\n")txttestReport.write("該測試用例運行開始時間:"+starttime+"\n")txttestReport.write("接口編號"+self.number+" ")txttestReport.write('接口名稱'+self.name+"\n")txttestReport.write("*****************************************************************"+"\n")txttestReport.close()def write_report(self):txtReport = open('..\\test_report\\report1.txt', "a")txtReport.write("接口編號:"+self.number+" 接口名稱:"+self.name)# 讀取comresult文件中的測試結果comfile=open("commonresult.txt", 'r')for result in comfile:txtReport.write(" 接口測試結果:"+result+"\n")comfile.close()txtReport.close()def write_commonresult(self,result):# 寫入接口測試結果到公共文件中comfile = open("..\\test_driver\\commonresult.txt", 'w')# 把result存入data文件中comfile.write(result)comfile.close()#取出token文件中的token的值def get_token(self):tokenfile=open("..\\test_driver\\token.txt","r")for token in tokenfile:tokenvalue=tokenreturn tokenvalue#連接數據庫進行查詢返回查詢結果def db_connect(self,sql):# 打開數據庫連接db=pymysql.connect(host='vip.51env.net',user='readonly',password='******',port=30001,db='******',charset='utf8')# 用cursor()方法獲取操作游標cursor = db.cursor()# 使用execute方法執行SQL語句cursor.execute(sql)# 使用fetchall()方法獲取一條數據db_result=cursor.fetchall()# 關閉數據庫連接db.close()# 返回查詢結果return db_resultif __name__ == '__main__':#實例化驅動類的對象objdriver=driver_run()# 創建測試報告頭部objdriver.create_report()# 調用接口文件objdriver.run_testpy()
3.2 登錄類
實例化登錄類
# ********************************************************************************
# 登錄接口V5.0腳本實現
# 功能:1、調用圖片驗證碼接口獲取uuid
# 2、將獲取到的uuid傳入登錄接口中
# 3、分別對兩個功能進行面向對象封裝
# 修改內容: 增加token屬性,為其他接口提供驗證
# ********************************************************************************
# 導入類庫
import requests
import json
# 定義一個類:包含兩個方法和一個屬性
from test_driver.driverV1 import driver_run,glob_urlclass login_interface():# 定義一個屬性def __init__(self):self.uuid=''#增加token屬性self.token=''#方法1:獲取驗證碼對應的uuiddef getuuid(self):# 取驗證碼圖片接口uuid# 定義獲取驗證碼接口地址CaptchaURL = 'https://svr-6-9009.share.51env.net/prod-api/captchaImage'# 發送請求response = requests.get(CaptchaURL).json()# 獲取uuid# print(type(response))# 全局uuid引用說明# global uuidself.uuid = response['uuid']# print(self.uuid)# return uuid# 執行登錄接口的測試def login_test(self):# 定義接口地址url = "https://svr-6-9009.share.51env.net/prod-api/login"# 定義接口參數# print("登錄方法中", self.uuid)userinfo = {"username": "admin","password": "admin123","code": "51testing","uuid": self.uuid}# print(type(userinfo))# 將字典類型轉化為json類型userjson = json.dumps(userinfo)# print(type(userjson))# 發送接口請求response = requests.post(url, data=userjson, headers={"Content-Type": "application/json"}).json()# print(response)# print(response["msg"])# 對比實際和預期結果if response["msg"] == '操作成功' and response["username"] == 'admin':result="登錄接口成功"self.token=response["token"]tokenfile=open("..\\test_driver\\token.txt","w")tokenfile.write(self.token)tokenfile.close()else:result="登錄接口失敗"return result# 進行實例化調用
if __name__ == '__main__':# 實例化對象loginObj=login_interface()# 調用其中的方法loginObj.getuuid()result=loginObj.login_test()print(result)# 實例化驅動類對象objdriver=driver_run()# 調用寫入公共文件方法objdriver.write_commonresult(result)
3.3 獲取用戶信息接口
代碼:
# **********************************************************
# 獲取登錄用戶信息接口V3.0腳本實現
# 功能:常量參數傳遞
# 問題1:引用登錄接口類
# 問題2:運行登錄接口類,并獲取最新的token
# 問題3:用面向對象的方法將獲取到的最新的token傳入獲取用戶信息接口
# ***********************************************************
# 引入登錄接口類
from test_driver.driverV1 import glob_url,driver_run
# 導入類庫
import requests# **************************************************class GetUserInfo():def getuser_test(self,token):# 定義接口地址url=glob_url+'/getInfo'header={'Authorization':'Bearer '+token}# 發送請求并獲取self.response=requests.get(url,headers=header).json()print(self.response)def getuser_check(self):# 進行檢查點的驗證# 提取msgmsg=self.response['msg']# print(msg)# 通過assert斷言進行msg的驗證# 提取電話phone=self.response['user']['phonenumber']# print(phone)# 提取郵箱email=self.response['user']['email']# print(email)# 提取用戶名username=self.response['user']['userName']# print(username)#對assert進行異常捕獲try:assert msg == '操作成功'assert phone=='13800138000'assert email=='13800138000@139.com'assert username=='admin'except:result="獲取用戶信息接口測試失敗"else:result = "獲取用戶信息接口測試成功"return resultif __name__ == '__main__':objdriver=driver_run()token=objdriver.get_token()print(token)#實例化獲取用戶信息對象類objgetuser=GetUserInfo()objgetuser.getuser_test(token)result=objgetuser.getuser_check()# 將測試執行結論放入comresult.txt中objdriver.write_commonresult(result)
3.4 創建商鋪接口
#創建商鋪接口V1.0接口腳本實現
#功能:常量參數傳遞
#*************************************************************************
# 導入類庫
import datetime
import jsonimport requests
import pymysqlfrom test_driver.driverV1 import glob_url, driver_runclass createhouse_interface():def createhouse_test(self,token):# 打開測試用例報告文件txttestReport = open('..\\test_report\\testcase_report1.txt', "a")# 定義接口地址url=glob_url+'/baseconfig/House'for i in range(1,3):# 傳入接口參數,獲取實際返回值self.code='05-09-'+str(i)housedata={"block": "01","code": self.code,"buildingsquare": "100","usesquare": "50","state": "empty","floor": "12","rentFee": "12000","remark": "test"}housejson=json.dumps(housedata)# 傳入token參數header = {'Authorization': 'Bearer ' + token,"Content-Type":"application/json"}# 比對結果1:接口返回值response=requests.post(url,data=housejson,headers=header).json()print(response['msg'])# 比對結果:直接比對接口返回msgself.msg=response['msg']if self.msg=='新建成功':result='創建商鋪接口測試用例'+self.code+"接口測試用例成功"else:result = '創建商鋪接口測試用例' + self.code + "接口測試用例失敗"# 將接口測試用例的執行結果及數據內容寫入對應的測試用例報告中# 寫入是第幾次測試,測試商鋪編號,測試結論txttestReport.write('測試用例編號:'+str(i))txttestReport.write(" 創建商鋪的編號為:"+self.code)txttestReport.write(" 測試用例執行結果:"+result+"\n")txttestReport.write("*****************************************************************" + "\n")#共執行多少條數據txttestReport.write("共執行" + str(i) +"條測試用例"+ "\n")# 獲取系統時間,來寫入結束時間endtime = datetime.datetime.now()# 時間進行格式化endtime = endtime.strftime("%Y-%m-%d %H:%M:%S")# 時間格式進行格式化txttestReport.write('該接口測試執行結束時間:'+endtime+"\n")txttestReport.close()#連接后臺數據庫進行ID的檢查,并給出測試結論def createhouse_checkCode(self):id='5c7100ce60d044768223daf1546b3b61'sql="SELECT * FROM `config_house` WHERE id ='"+id+"'"dbresult=objdriver.db_connect(sql)print(dbresult)db_code=dbresult[0][1]print(db_code)# #判斷是否執行成功if db_code==self.code and self.msg=='新建成功':result="創建商鋪列表接口測試通過"print(self.code)else:result="創建商鋪列表接口測試失敗"print(self.code)return resultif __name__ == '__main__':objdriver = driver_run()token = objdriver.get_token()print(token)# 實例化創建商鋪接口類對象objcreatehouse = createhouse_interface()objcreatehouse.createhouse_test(token)# 調用數據庫檢查點result=objcreatehouse.createhouse_checkCode()# 將測試執行結論放入comresult.txt中objdriver.write_commonresult(result)
4、框架報告+測試用例報告
愿每個測試都能成為測試開發,提高職業技能,成為前1%的存在,為社會創造更大的價值,為公司節約更多的成本,為自己和家庭謀求更高的收入,所有人不受職業年齡限制,越老越吃香,直至財富自由;愿測試技術越來越進步,軟件質量進一步得到提高,效率提高。愿祖國更加美好,人民更加幸福。多喜樂,常安寧。