性能測試-JMeter參數化(1)CSV Data Set Config

一、參數化的定義

所謂參數化,就是將客戶端發送給服務器處理的數據預先保存到一個參數中的過程。

一般來說,對於功能測試,當用不同的數據測試相同的功能時,我們可以使用參數化來精簡測試;

對於性能測試,爲了真實模擬多個用戶的操作行爲或應對系統對多個用戶同時操作的特殊限制(比如數據唯一性要求),需要使用參數化來解決這些問題。

JMeter提供了非常多的參數化的方式和手段,常見有:

1.配置元件 CSV_Data_Set_Config

2.內置參數化函數,比如__CSVRead()

這1節我們主要講下CSV_Data_Set_Config參數化。

配置項

Configure the CSV Data Source:

1.Filename:

要讀取的數據文件的路徑或名稱。可以使用絕對路徑或相對路徑。

當使用相對路徑表示文件路徑時,測試計劃所在目錄爲當前目錄。

當JMeter以分佈式模式運行時,參數化的數據文件需要複製到每臺Slave中,並且要設置相同的目錄結構。

2.File Encoding:

若沒有設置則以操作系統的字符編碼去讀取數據文件。可以指定以何種編碼去讀取數據文件,以防止出現亂碼。

比如操作系統默認字符編碼爲GBK,而數據文件(CSV文件)的編碼爲UTF-8,則讀出來的數據肯定爲亂碼,在此情況下要設置File Encoding爲“UTF-8”才能讀取成功。

3.Variable Names(comma-delimited):

用於保存數據文件列值的變量名列表。變量名之間用,(逗號)分隔。若變量名列表爲空,JMeter則將數據文件的第一行各字段值作爲各個變量名(不論是否忽略第一行)。

比如數據文件中有如下兩行值:

張三,男,25

李四,女,20

在沒有設置變量名列表的情況下,會將第一行的三個值當做變量名:

張三,男,25

${張三},${男},${20}的值分別是:李四,女,20

4.Ignore first line (only used if Variable Names is not empty):

是否忽略數據文件的第一行。這個選項只有在設置了參數名列表時才起作用。

選擇True表示忽略第一行,選擇False表示不忽略第一行。一般用在數據文件中有列標題時,因爲標題不是值,故考慮可以忽略

第一行。

比如數據文件中有如下值:

name,sex,age

張三,男,25

李四,女,20

若此項設置爲False,則會將name,sex,age當做變量的值讀取,設置爲True會忽略此行,從第二行開始讀取。

5.Delimiter (use'\t'for tab):

數據文件中字段的分隔符。根據分隔符將記錄拆分保存到定義的變量中。默認值爲,(逗號)分隔。

6.Allow quoted data?:

數據文件中的值是否允許使用雙引號。True表示允許,False表示不允許。

一般用於當值中包含分隔符時,可考慮將值用雙引號括起來,屏蔽分隔符的特殊含義。

比如記錄了商品編號,名稱,價格的數據文件:

goods_id,goods_name,price

1,Watch_wanguo,"1,500,000"

若沒有使用雙引號,商品價格爲1,使用了雙引號,商品價格爲

1,500,000

7.Recycle on EOF?:

讀取到達數據文件結束(EOF即end of file)處,是否回到文件開始出重新讀取。

True循環讀取,False不循環讀取。

8.Stop thread on EOF?:

讀取到達數據文件結束處,是否停止線程。True停止線程,測試不再進行;

False不停止線程,繼續循環取值運行測試。

9.Sharing mode:

共享模式。All threads所有線程,Current thread group當前線程組,Current thread當前線程。

1)All threads:

所有線程共享同一個文件。在測試中數據文件只打開一次,每個線程讀取不同行的參數值。

每個線程讀取的值與線程啓動的先後順序相關;不論線程引用參數與否,每個線程都會分配一個參數值。

2)Current thread group:

當前線程組。測試計劃下的每個線程組都單獨打開一個參數文件。

3)Current thread:

當前線程。每個線程都單獨打開一個參數文件。在此模式下,若每個線程需要從不同的值集中取值,

可以設置一組參數化數據文件,每個線程對應一個文件。將線程編號與數據文件名關聯起來將可以了。

比如一組文件爲:

testdata1.csv,testdata2.csv,... ,

testdatan.csv

線程編號可以通過內置函數${threadNum}來獲取,則數據文件名可設置爲: testdata${threadNum}.csv。

舉個例子:

這裏以前面介紹過的查詢被購買商品總金額接口爲例來講解:

參數化步驟:

1.確定接口參數中哪些請求參數需要進行參數化

在設計測試用例時,我們針對商品編號,商品規格,商品數量來準備數據,

故對id,attr,number參數化

2.將測試數據放在外部一個文檔保存,文件類型爲csv或txt -->

.csv or .txt

新建一個testdata.csv,一行寫一個用例,多個參數值默認用,分隔:

case_name,id,attr,number

case1,9,226,3

case2,,226,1

case3,9,,1

case4,9,226,

3.添加並配置CSV Data Set Config配置元件

4.在請求中將寫死的數據用第3步中定義的變量進行替換

data --> ${varName}

比如 ${attr}

5.配置參數化

5.1 將線程數設置爲用例的個數

5.2 循環控制請求的次數

a.添加一個循環控制器,設置其循環次數爲測試用例個數

b.將CSV Data Set Config配置元件與請求移到循環控制器下面

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章