JMeter必知必會(huì)系列(5) JMeter參數(shù)化之CSV Data Set Config

? ? 5.1 參數(shù)化的定義

? ? 所謂參數(shù)化芽偏,就是將客戶端發(fā)送給服務(wù)器處理的數(shù)據(jù)預(yù)先保存到一個(gè)參數(shù)中的過程。

? ? 一般來說弦讽,對于功能測試污尉,當(dāng)用不同的數(shù)據(jù)測試相同的功能時(shí),我們可以使用參數(shù)化來精簡測試往产;對于性能測試被碗,為了? ? ? 真實(shí)模擬多個(gè)用戶的操作行為或應(yīng)對系統(tǒng)對多個(gè)用戶同時(shí)操作的特殊限制(比如數(shù)據(jù)唯一性要求),需要使用參數(shù)化來? ? ? 解決這些問題仿村。

? ? JMeter提供了非常多的參數(shù)化的方式和手段锐朴,常見有:

? ? 1.配置元件 CSV_Data_Set_Config

? ? 2.內(nèi)置參數(shù)化函數(shù),比如__CSVRead()

? ? 5.2 CSV_Data_Set_Config

  配置項(xiàng)

  1.Filename:

  要讀取的數(shù)據(jù)文件的路徑或名稱蔼囊》僦荆可以使用絕對路徑或相對路徑。

  當(dāng)使用相對路徑表示文件路徑時(shí)畏鼓,測試計(jì)劃所在目錄為當(dāng)前目錄酱酬。

  當(dāng)JMeter以分布式模式運(yùn)行時(shí),參數(shù)化的數(shù)據(jù)文件需要復(fù)制到每臺(tái)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ù)文件的第一行各字段值作為各個(gè)變量名(不論是否忽略第一行)缀皱。

  比如數(shù)據(jù)文件中有如下兩行值:

  張三,男,25

  李四,女,20

  在沒有設(shè)置變量名列表的情況下斗这,會(huì)將第一行的三個(gè)值當(dāng)做變量名:張三,男,25

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

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

  是否忽略數(shù)據(jù)文件的第一行钮莲。這個(gè)選項(xiàng)只有在設(shè)置了參數(shù)名列表時(shí)才起作用免钻。

  選擇True表示忽略第一行,選擇False表示不忽略第一行崔拥。

  一般用在數(shù)據(jù)文件中有列標(biāo)題時(shí)极舔,因?yàn)闃?biāo)題不是值,故考慮可以忽略第一行链瓦。

  比如數(shù)據(jù)文件中有如下值:

  name,sex,age

  張三,男,25

  李四,女,20

  若此項(xiàng)設(shè)置為False拆魏,則會(huì)將name,sex慈俯,age當(dāng)做變量的值讀取渤刃,

  設(shè)置為True會(huì)忽略此行,從第二行開始讀取贴膘。

  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í)喊递,可考慮將值用雙引號括起來,屏蔽分隔符的特殊含義阳似。

  比如記錄了商品編號骚勘,名稱,價(jià)格的數(shù)據(jù)文件:

  goods_id,goods_name,price

  1,Watch_wanguo,"1,500,000"

  若沒有使用雙引號俏讹,商品價(jià)格為1当宴,使用了雙引號,商品價(jià)格為1,500,000

  7.Recycle on EOF?:

  讀取到達(dá)數(shù)據(jù)文件結(jié)束(EOF即end of file)處泽疆,是否回到文件開始出重新讀取户矢。

  True循環(huán)讀取,F(xiàn)alse不循環(huán)讀取殉疼。

  8.Stop thread on EOF?:

  讀取到達(dá)數(shù)據(jù)文件結(jié)束處梯浪,是否停止線程。

  True停止線程瓢娜,測試不再進(jìn)行;False不停止線程挂洛,繼續(xù)循環(huán)取值運(yùn)行測試。

  9.Sharing mode:

  共享模式眠砾。All threads所有線程虏劲,Current thread group當(dāng)前線程組,Current thread當(dāng)前線程褒颈。

  All threads:

  所有線程共享同一個(gè)文件柒巫。在測試中數(shù)據(jù)文件只打開一次,每個(gè)線程讀取不同行的參數(shù)值谷丸。

  每個(gè)線程讀取的值與線程啟動(dòng)的先后順序相關(guān);不論線程引用參數(shù)與否吻育,每個(gè)線程都會(huì)分配一個(gè)參數(shù)值。

  Current thread group:

  當(dāng)前線程組淤井。對于包含該參數(shù)的每個(gè)線程組布疼,每個(gè)參數(shù)文件都僅打開一次;

  不包含參數(shù)的線程組不會(huì)打開參數(shù)化文件,自然也就不會(huì)分配參數(shù)值币狠。

  Current thread:

  當(dāng)前線程游两。每個(gè)線程都單獨(dú)打開一個(gè)參數(shù)文件。

  在此模式下漩绵,若每個(gè)線程需要從不同的值集中取值贱案,可以設(shè)置一組參數(shù)化數(shù)據(jù)文件,每個(gè)線程對應(yīng)一個(gè)文件止吐。

  將線程編號與數(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ù)需要進(jìn)行參數(shù)化

  在設(shè)計(jì)測試用例時(shí)厉膀,我們針對商品編號溶耘,商品規(guī)格,商品數(shù)量來準(zhǔn)備數(shù)據(jù)服鹅,

  故對id凳兵,attr,number參數(shù)化

  2.將測試數(shù)據(jù)放在外部一個(gè)文檔保存企软,文件類型為csv或txt --> *.csv or *.txt

  新建一個(gè)testdata.csv庐扫,一行寫一個(gè)用例,多個(gè)參數(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步中定義的變量進(jìn)行替換

  data --> ${varName}

  比如 ${attr}

  5.配置參數(shù)化

  5.1 將線程數(shù)設(shè)置為用例的個(gè)數(shù)

  5.2 循環(huán)控制請求的次數(shù)

  a.添加一個(gè)循環(huán)控制器仗哨,設(shè)置其循環(huán)次數(shù)為測試用例個(gè)數(shù)

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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末形庭,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子藻治,更是在濱河造成了極大的恐慌,老刑警劉巖巷挥,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件桩卵,死亡現(xiàn)場離奇詭異,居然都是意外死亡倍宾,警方通過查閱死者的電腦和手機(jī)雏节,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來高职,“玉大人钩乍,你說我怎么就攤上這事≌浚” “怎么了寥粹?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長埃元。 經(jīng)常有香客問我涝涤,道長,這世上最難降的妖魔是什么岛杀? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任阔拳,我火速辦了婚禮,結(jié)果婚禮上类嗤,老公的妹妹穿的比我還像新娘糊肠。我一直安慰自己,他們只是感情好遗锣,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布砰苍。 她就那樣靜靜地躺著,像睡著了一般桑逝。 火紅的嫁衣襯著肌膚如雪钓觉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天,我揣著相機(jī)與錄音墓阀,去河邊找鬼毡惜。 笑死,一個(gè)胖子當(dāng)著我的面吹牛斯撮,可吹牛的內(nèi)容都是我干的经伙。 我是一名探鬼主播,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼勿锅,長吁一口氣:“原來是場噩夢啊……” “哼帕膜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起溢十,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤垮刹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后张弛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體荒典,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年吞鸭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寺董。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,932評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡刻剥,死狀恐怖遮咖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情造虏,我是刑警寧澤御吞,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站漓藕,受9級特大地震影響魄藕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜撵术,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一背率、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嫩与,春花似錦寝姿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至处坪,卻和暖如春根资,著一層夾襖步出監(jiān)牢的瞬間架专,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工玄帕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留部脚,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓裤纹,卻偏偏與公主長得像委刘,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子鹰椒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容