日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Jmeter常用断言实战详解

發布時間:2023/12/31 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Jmeter常用断言实战详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

斷言:依靠軟件程序自動判斷操作結果的正確性,用于檢查測試中得到的響應數據等是否符合預期。在接口測試用例中沒有斷言的接口用例是無效的,一個接口的斷言有三個層面,一個是HTTP狀態碼的斷言,另外一個是業務狀態碼的斷言,最后是某一接口請求后服務端響應數據的斷言

Jmeter最常用斷言:Response Assertion(響應斷言),Json斷言,beanshell斷言

一:Response Assertion(響應斷言)
響應斷言:可選擇斷言驗證的范圍(URL,響應頭,響應碼,響應體,響應附件),匹配的模式(純文本還是正則表達式匹配)

操作響應斷言:添加-斷言-響應斷言

對web請求http狀態碼的斷言
1.對http請求狀態碼的驗證
Apply to (響應斷言的應用范圍)
Main sample and sub-samples:作用于父節點取樣器及對應子節點取樣器
  Main sample only:只作用于父節點取樣器(一般的斷言都選這個)
  Sub-samples only:只作用于子節點取樣器
  JMeter Variable:只作用于jmeter變量(可寫入正則提取的響應值)

測試字段:
  響應文本:請求的響應文本信息,不包含響應頭信息。最常用的斷言字段
  響應代碼:對應http返回的響應碼
  響應信息:匹配響應信息
  響應頭:響應頭信息
  URL樣本: 請求url,如果有重定向包含重定向url
  文檔(文本):通過Apache Tika從各種的文檔中提取的文本進行驗證,包括響應文本,pdf、word等等各種格式
  忽略狀態(Ignore Status): 一個請求多項響應斷言時,忽略某一項斷言的響應結果,而繼續下一項斷言
 
  模式匹配規則
  包括:響應的結果中包含指定的文本或者字段值,支持正則表達式
  匹配:完全匹配,期望值與實際結果必須完全一致,一般結合正則表達式使用
  相等:響應結果與指定的內容完全一致,不支持正則表達式
  字符串:返回結果,包含指定的字符串,不支持正則表達式
  否:不進行匹配

2.添加斷言結果,添加-監聽器-斷言結果

3.發送請求,查看斷言結果

查看此請求實際響應結果十分與斷言一致

可看到此請求實際響應結果的status是404,與我們斷言200不一致,故fail
可對其它響應文本進行斷言,與此類似

二:Json斷言
JSON斷言可以對服務器返回的JSON文檔進行驗證。
JSON斷言有兩種使用模式:
1.根據JSONPath能否在JSON文檔中找到路徑;
2.根據JSONPath提取值并對值進行驗證。
若文檔格式為非JSON則斷言失敗;找不到路徑斷言失敗;提取值與預期值不一致斷言失敗。

1.添加-斷言-Json斷言

2.若響應數據返回是Json格式,我們可以對其進行json斷言操作,在請求的察看結構樹響應數據里提取數值對其進行斷言,示例提取data里的phone進行斷言如下

配置項
Assert JSON Path exists:
用于斷言的JSON元素的路徑(JSONPath)。
1.Additionally assert value
是否額外驗證根據JSONPath提取的值。
不勾選,驗證JSONPath能否在JSON文檔中找到路徑;
勾選,驗證根據JSONPath提取值是否預期。
2.Match as regular expression
預期值是否可以使用正則表達式。
不勾選,預期值不能使用正則表達式表示;
勾選,預期值可以使用正則表達式表示。
Expected Value:
預期值。
1.Expect null
若驗證提取的值為null,則勾選此項。
這里有兩個地方需要額外注意:
a.驗證null值,還是需要勾選“Additionally assert value”,否則驗證的是JSONPath能否找到路徑;
b.預期值不填表示空字符,與null不等價。
2.Invert assertion(will fail if above conditions met)
若勾選,表示對斷言結果取反。

注:除了null外,還有一種特殊的值,就是空數組,預期值不能不填,需要設置為:[],表示空數組。

3.查看斷言結果

可看到實際響應結果與預期不一致,故fail

三:Beanshell斷言
BeanShell斷言可以使用beanshell腳本來執行斷言檢查,可以用于更復雜的個性化需求,使用更靈活,功能更強大,但是要能夠熟練使用beanshell腳本
在這里除了可以使用beanshell的內置變量外,主要通過 Failure 和 FailureMessage來設置斷言結果

Failure = false;-----表示斷言成功 FailureMessage = “......";---自定義的成功信息 Failure = true;----表示斷言失敗 FailureMessage="......";------自定義的失敗信息

1.添加-斷言-Beanshell斷言

2.對http響應碼斷言實戰

3.查看斷言結果

可知響應結果不是200而是404

JMeter在它的BeanShell中內置了變量,用戶可以通過這些變量與JMeter進行交互,其中主要的變量及其使用方法如下:
log:寫入信息到jmeber.log文件,使用方法:log.info(“This is log info!”);
ctx:該變量引用了當前線程的上下文,使用方法可參考:org.apache.jmeter.threads.JMeterContext。
vars - (JMeterVariables):操作jmeter變量,這個變量實際引用了JMeter線程中的局部變量容器(本質上是Map),它是測試用例與BeanShell交互的橋梁,常用方法:
    a) vars.get(String key):從jmeter中獲得變量值
    b) vars.put(String key,String value):數據存到jmeter變量中
    更多方法可參考:org.apache.jmeter.threads.JMeterVariables
props - (JMeterProperties - class java.util.Properties):操作jmeter屬性,該變量引用了JMeter的配置信息,可以獲取Jmeter的屬性,它的使用方法與vars類似,但是只能put進去String類型的值,而不能是一個對象。對應于java.util.Properties。
    a) props.get(“START.HMS”);  注:START.HMS為屬性名,在文件jmeter.properties中定義
    b) props.put(“PROP1”,“1234”);
prev - (SampleResult):獲取前面的sample返回的信息,常用方法:
    a) getResponseDataAsString():獲取響應信息
    b) getResponseCode() :獲取響應code
    更多方法可參考:org.apache.jmeter.samplers.SampleResult
sampler - (Sampler):gives access to the current sampler

總結

以上是生活随笔為你收集整理的Jmeter常用断言实战详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。