5.1 參數(shù)化的定義
所謂參數(shù)化担猛,就是將客戶端發(fā)送給服務(wù)器處理的數(shù)據(jù)預(yù)先保存到一個參數(shù)中的過程兴想。
一般來說,對于功能測試雄人,當(dāng)用不同的數(shù)據(jù)測試相同的功能時,我們可以使用參數(shù)化來精簡測試念赶;對于性能測試础钠,為了真實模擬多個用戶的操作行為或應(yīng)對系統(tǒng)對多個用戶同時操作的特殊限制(比如數(shù)據(jù)唯一性要求),需要使用參數(shù)化來解決這些問題叉谜。
JMeter提供了非常多的參數(shù)化的方式和手段旗吁,常見有:
- 配置元件 CSV_Data_Set_Config
- 內(nèi)置參數(shù)化函數(shù),比如__CSVRead()
5.2 CSV_Data_Set_Config
配置項
1.Filename:
要讀取的數(shù)據(jù)文件的路徑或名稱停局『艿觯可以使用絕對路徑或相對路徑。
當(dāng)使用相對路徑表示文件路徑時董栽,測試計劃所在目錄為當(dāng)前目錄码倦。
當(dāng)JMeter以分布式模式運行時,參數(shù)化的數(shù)據(jù)文件需要復(fù)制到每臺Slave中锭碳,并且要設(shè)置相同的目錄結(jié)構(gòu)袁稽。
2.File Encoding:
若沒有設(shè)置則以操作系統(tǒng)的字符編碼去讀取數(shù)據(jù)文件。
可以指定以何種編碼去讀取數(shù)據(jù)文件擒抛,以防止出現(xiàn)亂碼推汽。
比如操作系統(tǒng)默認(rèn)字符編碼為GBK蝗柔,而數(shù)據(jù)文件(CSV文件)的編碼為UTF-8,
則讀出來的數(shù)據(jù)肯定為亂碼民泵,在此情況下要設(shè)置File Encoding為“UTF-8”才能讀取成功癣丧。
3.Variable Names(comma-delimited):
用于保存數(shù)據(jù)文件列值的變量名列表。變量名之間用,(逗號)分隔栈妆。
若變量名列表為空胁编,JMeter則將數(shù)據(jù)文件的第一行各字段值作為各個變量名(不論是否忽略第一行)。
比如數(shù)據(jù)文件中有如下兩行值:
張三,男,25
李四,女,20
在沒有設(shè)置變量名列表的情況下鳞尔,會將第一行的三個值當(dāng)做變量名:
張三,男,25
${張三}嬉橙,${男},${20}的值分別是:李四寥假,女市框,20
4.Ignore first line (only used if Variable Names is not empty):
是否忽略數(shù)據(jù)文件的第一行。這個選項只有在設(shè)置了參數(shù)名列表時才起作用糕韧。
選擇True表示忽略第一行枫振,選擇False表示不忽略第一行。
一般用在數(shù)據(jù)文件中有列標(biāo)題時萤彩,因為標(biāo)題不是值粪滤,故考慮可以忽略第一行。
比如數(shù)據(jù)文件中有如下值:
name,sex,age
張三,男,25
李四,女,20
若此項設(shè)置為False雀扶,則會將name杖小,sex,age當(dāng)做變量的值讀取愚墓,
設(shè)置為True會忽略此行予权,從第二行開始讀取。
5.Delimiter (use'\t'for tab):
數(shù)據(jù)文件中字段的分隔符浪册。
根據(jù)分隔符將記錄拆分保存到定義的變量中扫腺。
默認(rèn)值為逗號分隔。
6.Allow quoted data?:
數(shù)據(jù)文件中的值是否允許使用雙引號议经。True表示允許斧账,F(xiàn)alse表示不允許。
一般用于當(dāng)值中包含分隔符時煞肾,可考慮將值用雙引號括起來咧织,屏蔽分隔符的特殊含義。
比如記錄了商品編號籍救,名稱习绢,價格的數(shù)據(jù)文件:
goods_id,goods_name,price
1,Watch_wanguo,"1,500,000"
若沒有使用雙引號,商品價格為1闪萄,使用了雙引號梧却,商品價格為1,500,000
7.Recycle on EOF?:
讀取到達數(shù)據(jù)文件結(jié)束(EOF即end of file)處,是否回到文件開始出重新讀取败去。
True循環(huán)讀取放航,F(xiàn)alse不循環(huán)讀取。
8.Stop thread on EOF?:
讀取到達數(shù)據(jù)文件結(jié)束處圆裕,是否停止線程广鳍。
True停止線程,測試不再進行吓妆;False不停止線程赊时,繼續(xù)循環(huán)取值運行測試。
9.Sharing mode:共享模式行拢。
All threads所有線程祖秒,
Current thread group當(dāng)前線程組,
Current thread當(dāng)前線程舟奠。
All threads:
所有線程共享同一個文件竭缝。在測試中數(shù)據(jù)文件只打開一次,每個線程讀取不同行的參數(shù)值鸭栖。
每個線程讀取的值與線程啟動的先后順序相關(guān)歌馍;不論線程引用參數(shù)與否握巢,每個線程都會分配一個參數(shù)值晕鹊。
Current thread group:
當(dāng)前線程組。每個線程組都單獨打開一個參數(shù)文件暴浦,不論該線程組內(nèi)的線程是否引用參數(shù)化變量溅话。
Current thread:
當(dāng)前線程。每個線程都單獨打開一個參數(shù)文件歌焦。
在此模式下飞几,若每個線程需要從不同的值集中取值,可以設(shè)置一組參數(shù)化數(shù)據(jù)文件独撇,每個線程對應(yīng)一個文件屑墨。
將線程編號與數(shù)據(jù)文件名關(guān)聯(lián)起來將可以了。
比如一組文件為: testdata1.csv纷铣,testdata2.csv卵史,... ,testdatan.csv
線程編號可以通過內(nèi)置函數(shù)${__threadNum}來獲取搜立,
則數(shù)據(jù)文件名可設(shè)置為: testdata${__threadNum}.csv
5.3 應(yīng)用案例
這里以前面介紹過的查詢被購買商品總金額接口為例來講解以躯。
參數(shù)化步驟
1.確定接口參數(shù)中哪些請求參數(shù)需要進行參數(shù)化**
在設(shè)計測試用例時,我們針對商品編號,商品規(guī)格忧设,商品數(shù)量來準(zhǔn)備數(shù)據(jù)刁标,
故對id,attr址晕,number參數(shù)化
2.將測試數(shù)據(jù)放在外部一個文檔保存膀懈,文件類型為csv或txt --> *.csv or *.txt
新建一個testdata.csv,一行寫一個用例谨垃,多個參數(shù)值默認(rèn)用,分隔:
case_name,id,attr,number
case1,9,226,3
case2,,226,1
case3,9,,1
case4,9,226,
3.添加并配置CSV Data Set Config配置元件
4.在請求中將寫死的數(shù)據(jù)用第3步中定義的變量進行替換
data --> ${varName}
比如 ${attr}
5.配置參數(shù)化
5.1 將線程數(shù)設(shè)置為用例的個數(shù)
5.2 循環(huán)控制請求的次數(shù)
- a.添加一個循環(huán)控制器吏砂,設(shè)置其循環(huán)次數(shù)為測試用例個數(shù)
- b.將CSV Data Set Config配置元件與請求移到循環(huán)控制器下面