JMeter學習-015-JMeter 斷言之-Bean Shell Assertion


前面的博文中有對 JMeter 中的 響應斷言 進行了講解並實例演示,詳情敬請參閱博文:JMeter學習-007-JMeter 斷言實例之一 - 響應斷言

 

在 JMeter 中總計提供了如下幾種 BeanShell 組件:

Beanshell Sampler:單獨的采樣器。

Beanshell PreProcessor:針對其他采樣器的前置處理器。可以在采樣器執行之前進行預處理操作,生成相關測試數據供采樣器使用,相當於 TestNG 中的 before annotation。

Beanshell PostProcessor:針對其他采樣器的后置處理器。可以在采樣器執行之后進行測試環境恢復或數據清理等操作,相當於 TestNG 中的 after annotation。

Beanshell Assertion:JMeter 中的高級斷言,可直接調用 JMeter API 進行相關的腳本操作,同時可進行斷言結果的設定,實現對腳本測試結果報告的定制輸出等。

_Beanshell function:JMeter 中的調用函數,允許在采樣器等的執行過程中調用已存在的擴展腳本中的函數方法。

 

此文主要講述 JMeter 斷言中的 Bean Shell Asserttion。其對應的路徑為:【 添加 / 斷言 / Bean Shell Assertion】,其配置頁面如下所示:

配置參數列表說明如下:

配置項屬性 詳細描述 是否必填
名稱 腳本目錄樹顯示當前 Bean Shell Assertion 的概要描述性名稱。該名稱存儲在腳本變量標簽中。
注釋 對當前項更加詳細的描述。例如相關業務描述等等。
Reset bsh.Interpreter before each calll 若選擇此項,則將為每個樣本創建對應的解釋器。一般用不到。
參數

傳遞到腳本的參數,有如下兩種參數傳遞方式:

  1. String Parameters:作為單一的變量參數傳遞
  2. String[] bash.args:作為數組的字符串數組參數,參數之間通過空格進行分割
Script file 包含 BeanShell 腳本的運行文件。將重寫當前腳本 Script,其文件名存儲在腳本變量名中。
Script BeanShell 腳本。當包含了 BeanShell 腳本文件時,Script 可為空。

 

 

 

 

 

 

 

 

BeanShell 獲取變量的兩種方法如下所示(假定需獲取的變量分別為 exp_sysNo、sysNo):

// get compare data
exp = vars.get("exp_sysNo").toString();
act = String.valueOf( ${sysNo});

 

修改 exp_sysNo 的方法如下所示(修改 exp_sysNo 數據后,原來獲取的 exp 需要重新獲取):

vars.put("exp_sysNo", "exp_sysNo");

 

下面為 BeanShell Assert 的簡單應用實例,敬請參閱!

  1 <?xml version="1.0" encoding="UTF-8"?>
  2 <jmeterTestPlan version="1.2" properties="2.8" jmeter="2.13 r1665067">
  3   <hashTree>
  4     <TestPlan guiclass="TestPlanGui" testclass="TestPlan" testname="接口自動化測試實例 - BeanShell Assertion 簡單實例演示" enabled="true">
  5       <stringProp name="TestPlan.comments"></stringProp>
  6       <boolProp name="TestPlan.functional_mode">false</boolProp>
  7       <boolProp name="TestPlan.serialize_threadgroups">false</boolProp>
  8       <elementProp name="TestPlan.user_defined_variables" elementType="Arguments" guiclass="ArgumentsPanel" testclass="Arguments" testname="用戶定義的變量" enabled="true">
  9         <collectionProp name="Arguments.arguments"/>
 10       </elementProp>
 11       <stringProp name="TestPlan.user_define_classpath"></stringProp>
 12     </TestPlan>
 13     <hashTree>
 14       <ThreadGroup guiclass="ThreadGroupGui" testclass="ThreadGroup" testname="008-搜索商品" enabled="true">
 15         <stringProp name="ThreadGroup.on_sample_error">continue</stringProp>
 16         <elementProp name="ThreadGroup.main_controller" elementType="LoopController" guiclass="LoopControlPanel" testclass="LoopController" testname="循環控制器" enabled="true">
 17           <boolProp name="LoopController.continue_forever">false</boolProp>
 18           <stringProp name="LoopController.loops">1</stringProp>
 19         </elementProp>
 20         <stringProp name="ThreadGroup.num_threads">1</stringProp>
 21         <stringProp name="ThreadGroup.ramp_time">0</stringProp>
 22         <longProp name="ThreadGroup.start_time">1419232321000</longProp>
 23         <longProp name="ThreadGroup.end_time">1419232321000</longProp>
 24         <boolProp name="ThreadGroup.scheduler">false</boolProp>
 25         <stringProp name="ThreadGroup.duration"></stringProp>
 26         <stringProp name="ThreadGroup.delay"></stringProp>
 27       </ThreadGroup>
 28       <hashTree>
 29         <Arguments guiclass="ArgumentsPanel" testclass="Arguments" testname="用戶定義的變量 - 商品編號 101-006-78945" enabled="true">
 30           <collectionProp name="Arguments.arguments">
 31             <elementProp name="goodsNo" elementType="Argument">
 32               <stringProp name="Argument.name">goodsNo</stringProp>
 33               <stringProp name="Argument.value">101-006-78945</stringProp>
 34               <stringProp name="Argument.desc">商品編號</stringProp>
 35               <stringProp name="Argument.metadata">=</stringProp>
 36             </elementProp>
 37             <elementProp name="districtId" elementType="Argument">
 38               <stringProp name="Argument.name">districtId</stringProp>
 39               <stringProp name="Argument.value">29313</stringProp>
 40               <stringProp name="Argument.desc">配送區域</stringProp>
 41               <stringProp name="Argument.metadata">=</stringProp>
 42             </elementProp>
 43             <elementProp name="areacode" elementType="Argument">
 44               <stringProp name="Argument.name">areacode</stringProp>
 45               <stringProp name="Argument.value">1</stringProp>
 46               <stringProp name="Argument.desc">倉庫大區</stringProp>
 47               <stringProp name="Argument.metadata">=</stringProp>
 48             </elementProp>
 49             <elementProp name="exp_sysNo" elementType="Argument">
 50               <stringProp name="Argument.name">exp_sysNo</stringProp>
 51               <stringProp name="Argument.value">2169256</stringProp>
 52               <stringProp name="Argument.desc">商品系統編號,用於校驗搜索結果</stringProp>
 53               <stringProp name="Argument.metadata">=</stringProp>
 54             </elementProp>
 55             <elementProp name="skuid" elementType="Argument">
 56               <stringProp name="Argument.name">skuid</stringProp>
 57               <stringProp name="Argument.value">489349159815</stringProp>
 58               <stringProp name="Argument.desc">單品SKU,用戶校驗搜索結果</stringProp>
 59               <stringProp name="Argument.metadata">=</stringProp>
 60             </elementProp>
 61             <elementProp name="appSource" elementType="Argument">
 62               <stringProp name="Argument.name">appSource</stringProp>
 63               <stringProp name="Argument.value">android</stringProp>
 64               <stringProp name="Argument.desc">平台</stringProp>
 65               <stringProp name="Argument.metadata">=</stringProp>
 66             </elementProp>
 67             <elementProp name="appVersion" elementType="Argument">
 68               <stringProp name="Argument.name">appVersion</stringProp>
 69               <stringProp name="Argument.value">45</stringProp>
 70               <stringProp name="Argument.desc">版本</stringProp>
 71               <stringProp name="Argument.metadata">=</stringProp>
 72             </elementProp>
 73           </collectionProp>
 74           <stringProp name="TestPlan.comments">,,,,,,</stringProp>
 75         </Arguments>
 76         <hashTree/>
 77         <HTTPSamplerProxy guiclass="HttpTestSampleGui" testclass="HTTPSamplerProxy" testname="008-01-搜索商品 【${goodsNo} | ${districtId}】" enabled="true">
 78           <elementProp name="HTTPsampler.Arguments" elementType="Arguments" guiclass="HTTPArgumentsPanel" testclass="Arguments" enabled="true">
 79             <collectionProp name="Arguments.arguments">
 80               <elementProp name="q" elementType="HTTPArgument">
 81                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
 82                 <stringProp name="Argument.value">${goodsNo}</stringProp>
 83                 <stringProp name="Argument.metadata">=</stringProp>
 84                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
 85                 <stringProp name="Argument.name">q</stringProp>
 86               </elementProp>
 87               <elementProp name="districtId" elementType="HTTPArgument">
 88                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
 89                 <stringProp name="Argument.value">${districtId}</stringProp>
 90                 <stringProp name="Argument.metadata">=</stringProp>
 91                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
 92                 <stringProp name="Argument.name">districtId</stringProp>
 93               </elementProp>
 94               <elementProp name="areacode" elementType="HTTPArgument">
 95                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
 96                 <stringProp name="Argument.value">${areacode}</stringProp>
 97                 <stringProp name="Argument.metadata">=</stringProp>
 98                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
 99                 <stringProp name="Argument.name">areacode</stringProp>
100               </elementProp>
101               <elementProp name="dtype" elementType="HTTPArgument">
102                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
103                 <stringProp name="Argument.value">list|page|classes</stringProp>
104                 <stringProp name="Argument.metadata">=</stringProp>
105                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
106                 <stringProp name="Argument.name">dtype</stringProp>
107               </elementProp>
108               <elementProp name="districtId" elementType="HTTPArgument">
109                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
110                 <stringProp name="Argument.name">districtId</stringProp>
111                 <stringProp name="Argument.value">${districtId}</stringProp>
112                 <stringProp name="Argument.metadata">=</stringProp>
113                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
114               </elementProp>
115               <elementProp name="exAppTag" elementType="HTTPArgument">
116                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
117                 <stringProp name="Argument.name">exAppTag</stringProp>
118                 <stringProp name="Argument.value">2045191607</stringProp>
119                 <stringProp name="Argument.metadata">=</stringProp>
120                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
121               </elementProp>
122               <elementProp name="appSource" elementType="HTTPArgument">
123                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
124                 <stringProp name="Argument.value">${appSource}</stringProp>
125                 <stringProp name="Argument.metadata">=</stringProp>
126                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
127                 <stringProp name="Argument.name">appSource</stringProp>
128               </elementProp>
129               <elementProp name="appVersion" elementType="HTTPArgument">
130                 <boolProp name="HTTPArgument.always_encode">false</boolProp>
131                 <stringProp name="Argument.value">${appVersion}</stringProp>
132                 <stringProp name="Argument.metadata">=</stringProp>
133                 <boolProp name="HTTPArgument.use_equals">true</boolProp>
134                 <stringProp name="Argument.name">appVersion</stringProp>
135               </elementProp>
136             </collectionProp>
137           </elementProp>
138           <stringProp name="HTTPSampler.domain">mb.51buy.com</stringProp>
139           <stringProp name="HTTPSampler.port"></stringProp>
140           <stringProp name="HTTPSampler.connect_timeout"></stringProp>
141           <stringProp name="HTTPSampler.response_timeout"></stringProp>
142           <stringProp name="HTTPSampler.protocol">http</stringProp>
143           <stringProp name="HTTPSampler.contentEncoding">GB2312</stringProp>
144           <stringProp name="HTTPSampler.path">/json.php?mod=Search&amp;act=page&amp;p=1&amp;pp=20</stringProp>
145           <stringProp name="HTTPSampler.method">POST</stringProp>
146           <boolProp name="HTTPSampler.follow_redirects">true</boolProp>
147           <boolProp name="HTTPSampler.auto_redirects">false</boolProp>
148           <boolProp name="HTTPSampler.use_keepalive">true</boolProp>
149           <boolProp name="HTTPSampler.DO_MULTIPART_POST">false</boolProp>
150           <boolProp name="HTTPSampler.monitor">false</boolProp>
151           <stringProp name="HTTPSampler.embedded_url_re"></stringProp>
152         </HTTPSamplerProxy>
153         <hashTree>
154           <HeaderManager guiclass="HeaderPanel" testclass="HeaderManager" testname="HTTP信息頭管理器" enabled="true">
155             <collectionProp name="HeaderManager.headers">
156               <elementProp name="Charset" elementType="Header">
157                 <stringProp name="Header.name">Charset</stringProp>
158                 <stringProp name="Header.value">UTF-8</stringProp>
159               </elementProp>
160               <elementProp name="Content-Type" elementType="Header">
161                 <stringProp name="Header.name">Content-Type</stringProp>
162                 <stringProp name="Header.value">application/x-www-form-urlencoded</stringProp>
163               </elementProp>
164               <elementProp name="Accept-Encoding" elementType="Header">
165                 <stringProp name="Header.name">Accept-Encoding</stringProp>
166                 <stringProp name="Header.value">gzip</stringProp>
167               </elementProp>
168               <elementProp name="User-Agent" elementType="Header">
169                 <stringProp name="Header.name">User-Agent</stringProp>
170                 <stringProp name="Header.value">Dalvik/1.6.0 (Linux; U; Android 4.4.2; GT-I9502 Build/KOT49H)</stringProp>
171               </elementProp>
172             </collectionProp>
173           </HeaderManager>
174           <hashTree/>
175           <RegexExtractor guiclass="RegexExtractorGui" testclass="RegexExtractor" testname="獲取商品的系統編號" enabled="true">
176             <stringProp name="RegexExtractor.useHeaders">false</stringProp>
177             <stringProp name="RegexExtractor.refname">sysNo</stringProp>
178             <stringProp name="RegexExtractor.regex">&quot;sysNo&quot;:&quot;(.+?)&quot;,&quot;</stringProp>
179             <stringProp name="RegexExtractor.template">$1$</stringProp>
180             <stringProp name="RegexExtractor.default">ERROR</stringProp>
181             <stringProp name="RegexExtractor.match_number">1</stringProp>
182           </RegexExtractor>
183           <hashTree/>
184         </hashTree>
185         <BeanShellAssertion guiclass="BeanShellAssertionGui" testclass="BeanShellAssertion" testname="BeanShell Assertion - 簡單示例" enabled="true">
186           <stringProp name="BeanShellAssertion.query">import org.apache.jmeter.util.JMeterUtils;
187 import org.apache.jmeter.samplers.SampleResult;
188 import org.apache.jmeter.assertions.AssertionResult;
189 
190 String exp = vars.get(&quot;exp_sysNo&quot;);
191 String act = vars.get(&quot;sysNo&quot;);
192 
193 if (exp.equals(act)) {
194     log.info(exp);
195     log.info(act);
196     log.info(&quot;Test passed.&quot;);
197 } else {
198     log.info(exp);
199     log.info(act);
200     log.info(&quot;Test failed to assert : Expected &lt;&quot; + exp + &quot;&gt;, but &lt;&quot; + act + &quot;&gt;.&quot;);
201 }
202 
203 ac = &quot;a&quot;;
204 
205 if (exp.equals(ac)) {
206     log.info(exp);
207     log.info(ac);
208     log.info(&quot;Test passed.&quot;);
209 } else {
210     log.info(exp);
211     log.info(ac);
212     log.info(&quot;Test failed to assert : Expected &lt;&quot; + exp + &quot;&gt;, but &lt;&quot; + ac + &quot;&gt;.&quot;);
213 }
214 
215 </stringProp>
216           <stringProp name="BeanShellAssertion.filename"></stringProp>
217           <stringProp name="BeanShellAssertion.parameters"></stringProp>
218           <boolProp name="BeanShellAssertion.resetInterpreter">true</boolProp>
219         </BeanShellAssertion>
220         <hashTree/>
221         <BeanShellAssertion guiclass="BeanShellAssertionGui" testclass="BeanShellAssertion" testname="BeanShell Assertion - 常用方法" enabled="true">
222           <stringProp name="BeanShellAssertion.query">
223 log.info(&quot;\n01.獲取請求響應數據:SampleResult.getResponseData()&quot; + SampleResult.getResponseData() + &quot;\n\n&quot;);
224 log.info(&quot;\n02.獲取請求響應返回碼:SampleResult.getResponseCode()\n&quot; + SampleResult.getResponseCode() + &quot;\n\n&quot;);
225 log.info(&quot;\n03.獲取請求響應信息:SampleResult.getResponseMessage()\n&quot; + SampleResult.getResponseMessage() + &quot;\n\n&quot;);
226 log.info(&quot;\n04.獲取請求響應頭信息:SampleResult.getResponseHeaders()\n&quot; + SampleResult.getResponseHeaders() + &quot;\n\n&quot;);
227 
228 log.info(&quot;\n05.獲取請求的頭信息:SampleResult.getRequestHeaders()\n&quot; + SampleResult.getRequestHeaders() + &quot;\n\n&quot;);
229 log.info(&quot;\n06.獲取請求的標簽:SampleResult.getSampleLabel()\n&quot; + SampleResult.getSampleLabel() + &quot;\n\n&quot;);
230 
231 log.info(&quot;\n07.獲取請求執行結果:SampleResult.isSuccessful()\n&quot; + SampleResult.isSuccessful() + &quot;\n\n&quot;);
232 log.info(&quot;\n08.設置請求響應的返回碼:SampleResult.setResponseCode(\&quot;502\&quot;)\n&quot; + SampleResult.setResponseCode(&quot;502&quot;) + &quot;\n\n&quot;);
233 log.info(&quot;\n09.設置請求響應的信息:SampleResult.setResponseMessage(\&quot;SampleResult.setResponseMessage\&quot;)\n&quot; + SampleResult.setResponseMessage(&quot;設置響應信息:SampleResult.setResponseMessage&quot;) + &quot;\n\n&quot;);
234 log.info(&quot;\n10.獲取請求的返回碼:SampleResult.getResponseCode()\n&quot; + SampleResult.getResponseCode() + &quot;\n\n&quot;);
235 log.info(&quot;\n11.獲取請求的響應信息:SampleResult.getResponseMessage()\n&quot; + SampleResult.getResponseMessage() + &quot;\n\n&quot;);
236 
237 log.info(&quot;\n12.獲取請求的頭信息:vars.toString()\n&quot; + vars.toString() + &quot;\n\n&quot;);
238 
239 log.info(&quot;\n13.獲取請求的頭信息:props.toString()\n&quot; + props.toString() + &quot;\n\n&quot;);
240 log.info(&quot;\n14.獲取請求的頭信息:ctx.toString()\n&quot; + ctx.toString() + &quot;\n\n&quot;);
241 
242 </stringProp>
243           <stringProp name="BeanShellAssertion.filename"></stringProp>
244           <stringProp name="BeanShellAssertion.parameters"></stringProp>
245           <boolProp name="BeanShellAssertion.resetInterpreter">false</boolProp>
246         </BeanShellAssertion>
247         <hashTree/>
248       </hashTree>
249       <ResultCollector guiclass="AssertionVisualizer" testclass="ResultCollector" testname="斷言結果" enabled="true">
250         <boolProp name="ResultCollector.error_logging">false</boolProp>
251         <objProp>
252           <name>saveConfig</name>
253           <value class="SampleSaveConfiguration">
254             <time>true</time>
255             <latency>true</latency>
256             <timestamp>true</timestamp>
257             <success>true</success>
258             <label>true</label>
259             <code>true</code>
260             <message>true</message>
261             <threadName>true</threadName>
262             <dataType>true</dataType>
263             <encoding>false</encoding>
264             <assertions>true</assertions>
265             <subresults>true</subresults>
266             <responseData>false</responseData>
267             <samplerData>false</samplerData>
268             <xml>false</xml>
269             <fieldNames>false</fieldNames>
270             <responseHeaders>false</responseHeaders>
271             <requestHeaders>false</requestHeaders>
272             <responseDataOnError>false</responseDataOnError>
273             <saveAssertionResultsFailureMessage>false</saveAssertionResultsFailureMessage>
274             <assertionsResultsToSave>0</assertionsResultsToSave>
275             <bytes>true</bytes>
276             <threadCounts>true</threadCounts>
277           </value>
278         </objProp>
279         <stringProp name="filename"></stringProp>
280       </ResultCollector>
281       <hashTree/>
282       <ResultCollector guiclass="ViewResultsFullVisualizer" testclass="ResultCollector" testname="察看結果樹" enabled="true">
283         <boolProp name="ResultCollector.error_logging">false</boolProp>
284         <objProp>
285           <name>saveConfig</name>
286           <value class="SampleSaveConfiguration">
287             <time>true</time>
288             <latency>true</latency>
289             <timestamp>true</timestamp>
290             <success>true</success>
291             <label>true</label>
292             <code>true</code>
293             <message>true</message>
294             <threadName>true</threadName>
295             <dataType>true</dataType>
296             <encoding>false</encoding>
297             <assertions>true</assertions>
298             <subresults>true</subresults>
299             <responseData>false</responseData>
300             <samplerData>false</samplerData>
301             <xml>false</xml>
302             <fieldNames>false</fieldNames>
303             <responseHeaders>false</responseHeaders>
304             <requestHeaders>false</requestHeaders>
305             <responseDataOnError>false</responseDataOnError>
306             <saveAssertionResultsFailureMessage>false</saveAssertionResultsFailureMessage>
307             <assertionsResultsToSave>0</assertionsResultsToSave>
308             <bytes>true</bytes>
309             <threadCounts>true</threadCounts>
310           </value>
311         </objProp>
312         <stringProp name="filename">${__property(JmeterAuto_LogFile)}</stringProp>
313       </ResultCollector>
314       <hashTree/>
315     </hashTree>
316   </hashTree>
317 </jmeterTestPlan>
BeanShell Assertion 簡單實例源碼

 

執行結果如下所示:

2015/09/02 17:22:35 INFO  - jmeter.engine.StandardJMeterEngine: Running the test! 
2015/09/02 17:22:35 INFO  - jmeter.samplers.SampleEvent: List of sample_variables: [] 
2015/09/02 17:22:35 INFO  - jmeter.gui.util.JMeterMenuBar: setRunning(true,*local*) 
2015/09/02 17:22:35 INFO  - jmeter.engine.StandardJMeterEngine: Starting ThreadGroup: 1 : 008-搜索商品 
2015/09/02 17:22:35 INFO  - jmeter.engine.StandardJMeterEngine: Starting 1 threads for group 008-搜索商品. 
2015/09/02 17:22:35 INFO  - jmeter.engine.StandardJMeterEngine: Thread will continue on error 
2015/09/02 17:22:35 INFO  - jmeter.threads.ThreadGroup: Starting thread group number 1 threads 1 ramp-up 0 perThread 0.0 delayedStart=false 
2015/09/02 17:22:35 INFO  - jmeter.threads.ThreadGroup: Started thread group number 1 
2015/09/02 17:22:35 INFO  - jmeter.engine.StandardJMeterEngine: All thread groups have been started 
2015/09/02 17:22:35 INFO  - jmeter.threads.JMeterThread: Thread started: 008-搜索商品 1-1 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 2169256 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 2169256 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: Test passed. 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 2169256 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: a 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: Test failed to assert : Expected <2169256>, but <a>. 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
01.獲取請求響應數據:SampleResult.getResponseData()[B@652fd11d

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
02.獲取請求響應返回碼:SampleResult.getResponseCode()
200

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
03.獲取請求響應信息:SampleResult.getResponseMessage()
OK

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
04.獲取請求響應頭信息:SampleResult.getResponseHeaders()
HTTP/1.1 200 OK
Server: nginx
Date: Wed, 02 Sep 2015 09:19:43 GMT
Content-Type: text/html; charset=GB2312
Transfer-Encoding: chunked
Connection: keep-alive
Vary: Accept-Encoding
Vary: Accept-Encoding
Cache-Control: max-age=0
Pragma: no-cache
Expires: Wed, 02 Sep 2015 09:19:43 GMT
X-Cache: HIT-LT
Content-Encoding: gzip


 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
05.獲取請求的頭信息:SampleResult.getRequestHeaders()
Connection: keep-alive
Charset: UTF-8
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip
User-Agent: Dalvik/1.6.0 (Linux; U; Android 4.4.2; GT-I9502 Build/KOT49H)
Content-Length: 140
Host: mb.51buy.com


 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
06.獲取請求的標簽:SampleResult.getSampleLabel()
008-01-搜索商品 【101-006-78945 | 29313】

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
07.獲取請求執行結果:SampleResult.isSuccessful()
true

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
08.設置請求響應的返回碼:SampleResult.setResponseCode("502")
void

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
09.設置請求響應的信息:SampleResult.setResponseMessage("SampleResult.setResponseMessage")
void

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
10.獲取請求的返回碼:SampleResult.getResponseCode()
502

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
11.獲取請求的響應信息:SampleResult.getResponseMessage()
設置響應信息:SampleResult.setResponseMessage

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
12.獲取請求的頭信息:vars.toString()
org.apache.jmeter.threads.JMeterVariables@6e6e7861

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
13.獲取請求的頭信息:props.toString()
{not_in_menu=org.apache.jmeter.protocol.http.modifier.gui.ParamModifierGui, HTTP User Parameter Modifier, org.apache.jmeter.protocol.http.control.gui.WebServiceSamplerGui, xml.parser=org.apache.xerces.parsers.SAXParser, cookies=cookies, wmlParser.className=org.apache.jmeter.protocol.http.parser.RegexpHTMLParser, START.YMD=20150902, HTTPResponse.parsers=htmlParser wmlParser, view.results.tree.renderers_order=.RenderAsText,.RenderAsRegexp,.RenderAsCssJQuery,.RenderAsXPath,.RenderAsHTML,.RenderAsHTMLWithEmbedded,.RenderAsDocument,.RenderAsJSON,.RenderAsXML, remote_hosts=127.0.0.1, system.properties=system.properties, beanshell.server.file=../extras/startup.bsh, jmeter.version=2.13 r1665067, log_level.jmeter.junit=DEBUG, sampleresult.timestamp.start=true, START.HMS=170201, jmeter.laf.mac=System, log_level.jorphan=INFO, classfinder.functions.contain=.functions., user.properties=user.properties, wmlParser.types=text/vnd.wap.wml , log_level.jmeter=INFO, TESTSTART.MS=1441185755385, START.MS=1441184521097, classfinder.functions.notContain=.gui., htmlParser.types=text/html application/xhtml+xml application/xml text/xml, upgrade_properties=/bin/upgrade.properties}

 
2015/09/02 17:22:35 INFO  - jmeter.util.BeanShellTestElement: 
14.獲取請求的頭信息:ctx.toString()
org.apache.jmeter.threads.JMeterContext@349e3c2b

 
2015/09/02 17:22:35 INFO  - jmeter.threads.JMeterThread: Thread is done: 008-搜索商品 1-1 
2015/09/02 17:22:35 INFO  - jmeter.threads.JMeterThread: Thread finished: 008-搜索商品 1-1 
2015/09/02 17:22:35 INFO  - jmeter.engine.StandardJMeterEngine: Notifying test listeners of end of test 
2015/09/02 17:22:35 INFO  - jmeter.gui.util.JMeterMenuBar: setRunning(false,*local*) 

 

 

PS:BeanShell 是一個 Java 輕量化腳本語言,詳細信息請參閱: BeanShell官方網址

至此, JMeter學習-015-JMeter 斷言之-Bean Shell Assertion 順利完結,希望此文能夠給初學 JMeter 的您一份參考。

最后,非常感謝親的駐足,希望此文能對親有所幫助。熱烈歡迎親一起探討,共同進步。非常感謝! ^_^

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM