溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

發(fā)布時(shí)間:2021-07-20 11:52:35 來源:億速云 閱讀:928 作者:chen 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作”吧!

相信很多初中級(jí)測試同學(xué)可能都碰到過,那怎么做斷言驗(yàn)證是高效準(zhǔn)確的?今天筆者圍繞jmeter接口測試分享利用BeanShell斷言:將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

一、首先配置Jmeter連接Mysql數(shù)據(jù)庫

去mysql官網(wǎng)下載mysql-connector-java-bin.jar,我這邊下載了5.1.46版本:

鏈接: https://pan.baidu.com/s/1fW76mABU0mh5NkXJEC-zTQ 密碼: 6miq 

1.1在Jmeter中配置JDBC Connection Configuration

Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

1.2JDBC Request請求:

Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

1.3將已經(jīng)下載的jdbc驅(qū)動(dòng)加載到Jmeter工具中,這樣就使得mysql與Jmeter連接起來。選擇 測試計(jì)劃 —? 進(jìn)入頁面,點(diǎn)擊 瀏覽按鈕,如圖所示

Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

1.4點(diǎn)擊綠色箭頭進(jìn)行腳本運(yùn)行,查看結(jié)果樹得到我們的SQL值

Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

至此,jmeter鏈接數(shù)據(jù)庫已經(jīng)完成了

二、利用BeanShell斷言進(jìn)行驗(yàn)證

2.1API返回值中的字段值可以通過正則表達(dá)式提取器進(jìn)行提取 

Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作

2.2將數(shù)據(jù)庫中查詢到的值以變量的形式命名(假設(shè)a),下次該值就可以通過$a_1獲取到。那如何比對?附上代碼:

if (!"${identifyCode}".equals("${validate_code_1}")) {

    Failure = true;

    FailureMessage = "error,check error";

} else {

    FailureMessage = "ok,check current";

代碼說明:identifyCode是我正則表達(dá)式提取出來的值引用的變量

                  validate_code_1是我通過SQL語句查詢到的值引用的變量

只有當(dāng)API返回的值與數(shù)據(jù)庫查詢到的值一致時(shí),才認(rèn)為當(dāng)前case是pass,否則為Fail。

到此,相信大家對“Jmeter中如何將API返回值與數(shù)據(jù)庫查詢值進(jìn)行比對斷言操作”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI