在做介面測試的時候,我們經常會遇到一種情況就是要對介面的參數進行各種可能的校驗,手動修改很麻煩,尤其是那些介面參數有幾十個甚至更多的,有沒有一種方法可以批量的對指定參數做生成處理呢。 答案是肯定的! python的jinja2模板庫可以很好的滿足我們的需求,通過維護一個原始數據模板,將我們想要動態生 ...
在做介面測試的時候,我們經常會遇到一種情況就是要對介面的參數進行各種可能的校驗,手動修改很麻煩,尤其是那些介面參數有幾十個甚至更多的,有沒有一種方法可以批量的對指定參數做生成處理呢。
答案是肯定的!
python的jinja2模板庫可以很好的滿足我們的需求,通過維護一個原始數據模板,將我們想要動態生成的變數模板化,就可以實現需求。
現在我們有這樣的一個請求數據
{
"abc":"123",
"p2p":"123",
"smid":"20180807220733939b66d80092eea34ce9e77f30bedff12345b7d5a3faa11b",
"test":{
"test1":"1",
"test2":"2"
},
"test3":"3"
}
如果想對其中的smid欄位進行批量修改並生成新的請求數據就可以進行如下操作:
1、首先新建一個名為fp_template.txt的文本文件;
2、將上面的介面請求數據複製粘貼進這個txt文件中,我們以此作為“模板文件”;
3、新建一個predata文件夾用來存放生成後的數據文件;
4、對smid欄位進行模板化(模板格式可以參考jinja2的語法,這裡不做贅述),於是上面的請求參數就變成了下麵這樣:
{
"abc":"123",
"p2p":"123",
"smid":"{{ smid }}",
"test":{
"test1":"1",
"test2":"2"
},
"test3":"3"
}
實現代碼代碼如下:
# -*- coding: UTF-8 -*-
from jinja2 import Environment,FileSystemLoader
import os
class DataTemplateFaker:
def __init__(self):
self.aesPath = os.getcwd()#獲取啟動路徑
self.resultPath = self.aesPath + "/predata/"#指定用來保存生成數據的路徑
self.templateFile = "fp_template.txt"
#修改我們要批量生成smid的格式
def init_smid(self,start,end):
smidArg = [x for x in range(start, end)]
re = []
for n in smidArg:
re.append("20180807220733939b66d80092eea34ce9e77f30bedff" + str(n) + "b7d5a3faa11b")
return re
#操作模板文件
def preContent(self,arg):
env = Environment(loader=FileSystemLoader('./'))
tpl = env.get_template(self.templateFile)
renderContent = tpl.render(smid=arg)
return renderContent
#通過修改的smid列表批量替換模板文件並寫入指定文件中
def makeContent(self,preList):
x = 0
for i in preList:
x = x + 1
filename = str(self.resultPath) + 'data_' + str(x) + '.txt' #用以區分存放新生成的請求數據(也可以寫到一個文件中)
renderContent = self.preContent(i)
with open(filename, 'w') as f:
f.writelines(renderContent)
f.close()
if __name__ == "__main__":
AT = DataTemplateFaker()
reList = AT.init_smid(1,10)#控制生成數據的範圍
AT.makeContent(reList)
運行程式,就能得到新生成的數據
當然,我們也可以對其他的參數進行指定修改,如修改p2p,只需要修改模板文件:
{
"abc":"123",
"p2p":"{{ p2p }}",
"smid":"20180807220733939b66d80092eea34ce9e77f30bedff12345b7d5a3faa11b",
"test":{
"test1":"1",
"test2":"2"
},
"test3":"3"
}
然後在代碼中加入一個方法init_p2p()
# -*- coding: UTF-8 -*-
from jinja2 import Environment,FileSystemLoader
import os
class DataTemplateFaker:
def __init__(self):
self.aesPath = os.getcwd()#獲取啟動路徑
self.resultPath = self.aesPath + "/predata/"#指定用來保存生成數據的路徑
self.templateFile = "fp_template.txt"
#修改我們要批量生成smid的格式
def init_smid(self,start,end):
smidArg = [x for x in range(start, end)]
re = []
for n in smidArg:
re.append("20180807220733939b66d80092eea34ce9e77f30bedff" + str(n) + "b7d5a3faa11b")
return re
#修改我們要批量生成p2p的格式
def init_p2p(self,start,end):
p2pArg = [x for x in range(start, end)]
return p2pArg
#操作模板文件
def preContent(self,arg):
env = Environment(loader=FileSystemLoader('./'))
tpl = env.get_template(self.templateFile)
renderContent = tpl.render(smid=arg)
return renderContent
#通過修改的smid列表批量替換模板文件並寫入指定文件中
def makeContent(self,preList):
x = 0
for i in preList:
x = x + 1
filename = str(self.resultPath) + 'data_' + str(x) + '.txt' #用以區分存放新生成的請求數據(也可以寫到一個文件中)
renderContent = self.preContent(i)
with open(filename, 'w') as f:
f.writelines(renderContent)
f.close()
if __name__ == "__main__":
AT = DataTemplateFaker()
reList = AT.init_p2p(1,10)#控制生成數據的範圍
AT.makeContent(reList)
這隻是一個很簡單的demo,當然還有很多可優化的地方,比如多欄位同時修改、引入faker庫進行關聯生成偽造數據等,越是複雜且參數繁多的介面越適用,其他的方法就可以天馬行空,任君發揮了。