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

1、參數化的定義

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

通常來講,對於功能測試,當用不一樣的數據測試相同的功能時,咱們能夠使用參數化來精簡測試;分佈式

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

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配置元件與請求移到循環控制器下面

相關文章
相關標籤/搜索