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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

详解JMeter函数和变量

發(fā)布時(shí)間:2024/9/5 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 详解JMeter函数和变量 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

詳解JMeter函數(shù)和變量(1)

JMeter函數(shù)可以被認(rèn)為是某種特殊的變量,它們可以被采樣器或者其他測試元件所引用。函數(shù)調(diào)用的語法如下:

  • ${__functionName(var1,var2,var3)}?
  • 其中,__functionName匹配被調(diào)用的函數(shù)名稱。用圓括號(hào)包含函數(shù)的形參,例如${__time(YMD)},不同函數(shù)要求的參數(shù)也不同。有些JMeter函數(shù)不要求參數(shù),則可以不使用圓括號(hào),例如${__threadNum}。

    如果一個(gè)函數(shù)的參數(shù)中包含逗號(hào),那么必須對(duì)逗號(hào)進(jìn)行轉(zhuǎn)義(使用"\"),否則JMeter會(huì)把逗號(hào)當(dāng)成參數(shù)分隔符。例如:

  • ${__time(EEE\,?d?MMM?yyyy)}?
  • 變量引用的語法如下:

  • ${VARIABLE}?
  • 如果測試計(jì)劃中引用了未定義的變量或者函數(shù),那么JMeter并不會(huì)報(bào)告/記錄錯(cuò)誤信息,引用返回的值就是引用自身。例如,假設(shè)字符串UNDEF沒 有被定義為變量,那么${UNDEF}返回的值就是${UNDEF}。變量、函數(shù)(包括屬性)都是大小寫敏感的。JMeter 2.3.1及其后續(xù)版本會(huì)剔除參數(shù)名中的空格,例如,${__Random(1,63, LOTTERY )}中的"LOTTERY "會(huì)被"LOTTERY"所代替。

    屬性不同于變量。變量對(duì)線程而言是局部的,所有線程都可以訪問屬性,就使用__P或者_(dá)_property函數(shù)。

    如表11-1所示為JMeter內(nèi)置函數(shù)的列表(按類型劃分)。

    表11-1? JMeter內(nèi)置函數(shù)列表

    函數(shù)類型

    函數(shù)名稱

    注釋

    Information

    threadNum

    get thread number

    Information

    machineName

    get the local machine name

    Information

    time

    return current time in various formats

    Information

    log

    log (or display) a message (and return the value)

    Information

    logn

    log (or display) a message (empty return value)

    Input

    StringFromFile

    read a line from a file

    Input

    FileToString

    read an entire file

    Input

    CSVRead

    read from CSV delimited file

    Input

    XPath

    Use an XPath expression to read from a file

    Calculation

    counter

    generate an incrementing number

    Calculation

    intSum

    add int numbers

    Calculation

    longSum

    add long numbers

    Calculation

    Random

    generate a random number

    Scripting

    BeanShell

    run a BeanShell script

    Scripting

    javaScript

    process JavaScript (Mozilla Rhino)

    Scripting

    jexl

    evaluate a Commons Jexl expression

    Properties

    property

    read a property

    Properties

    P

    read a property (shorthand method)

    Properties

    setProperty

    set a JMeter property

    Variables

    split

    Split a string into variables

    Variables

    V

    evaluate a variable name

    Variables

    eval

    evaluate a variable expression

    Variables

    evalVar

    evaluate an expression stored in a variable

    String

    regexFunction

    parse previous response using a regular expression

    String

    char

    generate Unicode char values from a list of numbers

    String

    unescape

    Process strings containing Java escapes (e.g. \n & \t)

    String

    unescapeHtml

    Decode HTML-encoded strings

    String

    escapeHtml

    Encode strings using HTML encoding

    詳解JMeter函數(shù)和變量(2)

    1.使用函數(shù)可以做些什么

    目前有兩種類型的函數(shù):用戶定義的靜態(tài)值(或者變量)和JMeter內(nèi)置函數(shù)。

    當(dāng)需要編譯測試樹或者提交運(yùn)行時(shí),用戶可以使用自定義變量來代替常用的靜態(tài)值。這種替換只在測試的開始階段執(zhí)行一次。一個(gè)典型的應(yīng)用就是使用自定義變量來替換所有HTTP請(qǐng)求的DOMAIN域,例如,做出輕微改動(dòng),就可以讓同一個(gè)測試腳本適配多個(gè)服務(wù)器。

    需要注意,目前變量不支持嵌套;例如${Var${N}}不能正常工作。但是在JMeter 2.2及其以后版本中,可以借助函數(shù)__V (variable)來達(dá)成嵌套變量的目的(如${__V(Var${N})})。在早期的JMeter版本中可以使 用${__BeanShell(vars.get("Var${N}")}。

    這種類型的替換也可以不用函數(shù)來實(shí)現(xiàn),但是就不像使用函數(shù)時(shí)那么直觀和方便。用戶可以創(chuàng)建默認(rèn)配置測試元件,它們會(huì)填充采樣器中的空白設(shè)置。

    使用JMeter內(nèi)置函數(shù),用戶可以基于前面的服務(wù)器響應(yīng)數(shù)據(jù)、函數(shù)所在線程、當(dāng)前時(shí)間或者其他資源來動(dòng)態(tài)地計(jì)算變量值。這些變量的值會(huì)在整個(gè)測試期間針對(duì)每個(gè)請(qǐng)求動(dòng)態(tài)更新。

    函數(shù)可以在多個(gè)線程間共用。在測試計(jì)劃中每次函數(shù)調(diào)用,都是采用獨(dú)立的函數(shù)實(shí)例。

    2.函數(shù)和變量可以被用在哪里

    函數(shù)和變量理論上可以被用在任何測試元件的任何輸入域之中(除了測試計(jì)劃之外,見下面的內(nèi)容)。有些輸入域不支持隨機(jī)數(shù)組,因?yàn)樗鼈冎唤邮軘?shù)字,這樣一來就不支持函數(shù)。當(dāng)然,大多數(shù)輸入域支持函數(shù)。

    將函數(shù)用于測試計(jì)劃(Test Plan)的設(shè)置時(shí),會(huì)受到一些限制。此種情況下,JMeter線程的變量在函數(shù)被處理時(shí)還沒有被設(shè)定,因此變量作為參數(shù)傳遞時(shí)沒有初始化,函數(shù)引用當(dāng)然 不會(huì)生效。如此一來,split()、regex()及變量賦值函數(shù)就都不能正常工作。函數(shù)threadNum()同樣不能正常工作,該函數(shù)在測試計(jì)劃層 沒有意義。在測試計(jì)劃中,函數(shù)intSum、longSum、machineName、BeanShell、javaScript、jexl、 random、time、property functions、log functions應(yīng)該能正常工作。

    配置元件是通過一個(gè)獨(dú)立線程處理的。因此函數(shù)(如__threadNum)不能在這些測試元件(如用戶定義的變量)之中正常工作。另外還需要注意,在用戶定義的變量(UDV)中定義的變量,在UDV被處理前是不能使用的。

    當(dāng)在SQL代碼中引用變量/函數(shù)時(shí),需要為文本字符串加上必要的引號(hào)。例如,使用:

  • SELECT?item?from?table?where?name='${VAR}'?
  • 而非:

  • SELECT?item?from?table?where?name=${VAR}?
  • (除非VAR自身就包含引號(hào))。

    3.怎樣引用函數(shù)和變量

    在測試元件中引用某個(gè)變量,可以通過使用"${"和"}"將變量名括起來實(shí)現(xiàn)。

    函數(shù)使用相同的辦法加以引用,但是依據(jù)慣例,函數(shù)名以"__"開頭,以區(qū)別于變量名。部分函數(shù)會(huì)攜帶參數(shù),參數(shù)放在圓括號(hào)中,以逗號(hào)加以分隔。如果函數(shù)沒有參數(shù),那么可以省略圓括號(hào)。

    如果參數(shù)值中包含逗號(hào),必須對(duì)其加以轉(zhuǎn)義。如果測試人員需要在參數(shù)值中包含一個(gè)逗號(hào),可以這樣轉(zhuǎn)義:"\,"。這主要影響腳本函數(shù),例如JavaScript、BeanShell、Jexl有必要對(duì)腳本方法調(diào)用中的所有逗號(hào)加以轉(zhuǎn)義。例如:

  • ${__BeanShell(vars.put("name"\,"value"))}?
  • 另外,測試人員還有一種選擇,即將腳本定義為一個(gè)變量,例如,在測試計(jì)劃中定義:

  • SCRIPT?vars.put("name","value")?
  • 腳本可以如下般引用:

  • ${__BeanShell(${SCRIPT})}?
  • 這里沒有必要對(duì)SCRIPT變量的內(nèi)容進(jìn)行轉(zhuǎn)義,因?yàn)楹瘮?shù)的調(diào)用先于變量被其值所替換。該方法適合于BSF或者BeanShell采樣器,這兩種采樣器可以用于測試JavaScript、Jexl和BeanShell腳本。

    函數(shù)可以引用變量及其他函數(shù),例如${__XPath(${__P(xpath.file),${XPATH})},使用"xpath.file"作為文件名,變量XPATH的內(nèi)容作為搜索表達(dá)式。

    JMeter提供了一個(gè)工具,用來幫助測試人員使用各種內(nèi)置函數(shù)實(shí)現(xiàn)函數(shù)調(diào)用。使用該工具,只需復(fù)制-粘貼。工具不會(huì)為測試人員自動(dòng)轉(zhuǎn)義值,因?yàn)楹瘮?shù)可以作為其他函數(shù)的參數(shù),測試人員應(yīng)該只對(duì)文本進(jìn)行轉(zhuǎn)義。

    如果一個(gè)字符串既包含反斜線("\"),又包含函數(shù)或者變量引用,那么出現(xiàn)在"$"、"," 或者"\"之前的反斜線會(huì)被移除。這個(gè)操作對(duì)于嵌套函數(shù)(被嵌套的函數(shù)表達(dá)式包含逗號(hào)或者${)是有必要的。如果字符串中不包含函數(shù)和變量引用,那么出現(xiàn) 在"$"、","或者"\"之前的反斜線就不會(huì)被移除。

    用戶可以使用__logn() 函數(shù)來報(bào)告變量或者函數(shù)的值。__logn() 函數(shù)可以在測試計(jì)劃中的任何地方被引用,前提條件是被報(bào)告的值已經(jīng)被定義。另外,Java請(qǐng)求采樣器可以被用來產(chǎn)生一個(gè)包含變量引用的采樣;輸出結(jié)果會(huì)在 合適的監(jiān)聽器中展示。JMeter 2.3及其以后版本中包含一個(gè)Debug Sampler,可以使用它來展示變量的值(如在查看結(jié)果樹中展示)。

    如果測試人員定義了一個(gè)用戶定義靜態(tài)變量,且該變量名與JMeter內(nèi)置函數(shù)名相同,那么測試人員的靜態(tài)變量就會(huì)覆蓋同名內(nèi)置函數(shù)。

    詳解JMeter函數(shù)和變量(3)

    4.函數(shù)助手對(duì)話框

    測試人員可以在JMeter的選項(xiàng)菜單中找到函數(shù)助手對(duì)話框("Function Helper"對(duì)話框),如圖11-1所示。

    圖11-1

    使用函數(shù)助手,測試人員可以從下拉列表中選擇一個(gè)函數(shù),并為其參數(shù)設(shè)定值。在圖11-1中,表格的左邊一列是函數(shù)參數(shù)的簡要描述,右邊一列是供用戶填充參數(shù)的值。不同函數(shù)要求的參數(shù)也不同。

    當(dāng)測試人員完成以上設(shè)置后,請(qǐng)單擊"Generate"按鈕,函數(shù)助手會(huì)為測試人員生成函數(shù)調(diào)用所需的字符串,測試人員所要做的只是將它復(fù)制-粘貼到測試計(jì)劃中去。

    5.常用JMeter函數(shù)

    1)__regexFunction

    正則表達(dá)式函數(shù)可以使用正則表達(dá)式(用戶提供的)來解析前面的服務(wù)器響應(yīng)(或者是某個(gè)變量值)。函數(shù)會(huì)返回一個(gè)有模板的字符串,其中攜帶有可變的值。

    __regexFunction還可以被用來保存值,以便供后續(xù)使用。在函數(shù)的第6個(gè)參數(shù)中,測試人員可以指定一個(gè)引用名。在函數(shù)執(zhí)行以后,測試人 員可以使用用戶定義值的語法來獲取同樣的值。例如,如果測試人員輸入"refName"作為第6個(gè)參數(shù),那么測試人員可以使用:

    ${refName}來引用第2個(gè)參數(shù)(Template for the replacement string)的計(jì)算結(jié)果,這依賴于函數(shù)的解析結(jié)果。

    ${refName_g0}來引用函數(shù)解析后發(fā)現(xiàn)的所有匹配結(jié)果。

    ${refName_g1}來引用函數(shù)解析后發(fā)現(xiàn)的第一個(gè)匹配組合。

    ${refName_g#}來引用函數(shù)解析后發(fā)現(xiàn)的第n個(gè)匹配組合。

    ${refName_matchNr}來引用函數(shù)總共發(fā)現(xiàn)的匹配組合數(shù)目。

    參數(shù)如表11-2所示。

    表11-2? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    第1個(gè)參數(shù)

    第1個(gè)參數(shù)是用于解析服務(wù)器響應(yīng)數(shù)據(jù)的正則表達(dá)式。

    它會(huì)找到所有匹配項(xiàng)。如果測試人員希望將表達(dá)式

    中的某部分應(yīng)用在模板字符串中,一定記得為其加

    上圓括號(hào)。例如,<a href="(.*)">。這樣就會(huì)將鏈接

    的值存放到第一個(gè)匹配組合中(這里只有一個(gè)匹配組

    合)。又如,<input type="hidden" name="(.*)"

    value="(.*)">。在這個(gè)例子中,鏈接的name作為第

    一個(gè)匹配組合,鏈接的value會(huì)作為第二個(gè)匹配組合。

    這些組合可以用在測試人員的模板字符串中

    第2個(gè)參數(shù)

    這是一個(gè)模板字符串,函數(shù)會(huì)動(dòng)態(tài)填寫字符串的部分

    內(nèi)容。要在字符串中引用正則表達(dá)式捕獲的匹配組合,

    請(qǐng)使用語法:$[group_number]$。例如$1$或者 $2$。

    測試人員的模板可以是任何字符串

    第3個(gè)參數(shù)

    第3個(gè)參數(shù)告訴JMeter使用第幾次匹配。測試人

    員的正則表達(dá)式可能會(huì)找到多個(gè)匹配項(xiàng)。對(duì)此,

    測試人員有4種選擇:

    n????????? 整數(shù),直接告訴JMeter使用第幾個(gè)匹配項(xiàng)。

    n????????? “1”對(duì)應(yīng)第一個(gè)匹配,“2”對(duì)應(yīng)第二個(gè)匹配,以此類推

    n????????? RAND,告訴JMeter隨機(jī)選擇一個(gè)匹配項(xiàng)

    n????????? ALL,告訴JMeter使用所有匹配項(xiàng),為每一

    n????????? 個(gè)匹配項(xiàng)創(chuàng)建一個(gè)模板字符串,并將它們連接在一起

    n????????? 浮點(diǎn)值0到1之間,根據(jù)公式(找到的總匹配

    n????????? 數(shù)目*指定浮點(diǎn)值)計(jì)算使用第幾個(gè)匹配項(xiàng),

    n????????? 計(jì)算值向最近的整數(shù)取整

    否,默認(rèn)值為1

    第4個(gè)參數(shù)

    如果在上一個(gè)參數(shù)中選擇了“ALL”,那么這第4個(gè)

    參數(shù)會(huì)被插入到重復(fù)的模板值之間

    第5個(gè)參數(shù)

    如果沒有找到匹配項(xiàng)返回的默認(rèn)值

    第6個(gè)參數(shù)

    重用函數(shù)解析值的引用名,參見上面內(nèi)容

    第7個(gè)參數(shù)

    輸入變量名稱。如果指定了這一參數(shù),那么該變量

    的值就會(huì)作為函數(shù)的輸入,而不再使用前面的

    采樣結(jié)果作為搜索對(duì)象

    ?

    2)__counter

    每次調(diào)用計(jì)數(shù)器函數(shù)都會(huì)產(chǎn)生一個(gè)新值,從1開始每次加1。計(jì)數(shù)器既可以被配置成針對(duì)每個(gè)虛擬用戶是獨(dú)立的,也可以被配置成所有虛擬用戶公用的。如果每個(gè)虛擬用戶的計(jì)數(shù)器是獨(dú)立增長的,那么通常被用于記錄測試計(jì)劃運(yùn)行了多少遍。全局計(jì)數(shù)器通常被用于記錄發(fā)送了多少次請(qǐng)求。

    計(jì)數(shù)器使用一個(gè)整數(shù)值來記錄,允許的最大值為2,147,483,647。

    目前計(jì)數(shù)器函數(shù)實(shí)例是獨(dú)立實(shí)現(xiàn)的(JMeter 2.1.1及其以前版本,使用一個(gè)固定的線程變量來跟蹤每個(gè)用戶的計(jì)數(shù)器,因此多個(gè)計(jì)數(shù)器函數(shù)會(huì)操作同一個(gè)值)。全局計(jì)數(shù)器(FALSE)每個(gè)計(jì)數(shù)器實(shí)例都是獨(dú)立維護(hù)的。

    參數(shù)如表11-3所示。

    表11-3? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    第1個(gè)參數(shù)

    True,如果測試人員希望每個(gè)虛擬用戶的計(jì)數(shù)

    器保持獨(dú)立,與其他用戶的計(jì)數(shù)器相區(qū)別。

    false,全局計(jì)數(shù)器

    第2個(gè)參數(shù)

    重用計(jì)數(shù)器函數(shù)創(chuàng)建值的引用名。測試人員可

    以這樣引用計(jì)數(shù)器的值:${refName}。這樣一來,

    測試人員就可以創(chuàng)建一個(gè)計(jì)數(shù)器后,在多個(gè)地方引

    用它的值(JMeter 2.1.1及其以前版本,這個(gè)參數(shù)是必需的)

    3)__threadNum

    函數(shù)__threadNum只是簡單地返回當(dāng)前線程的編號(hào)。線程編號(hào)不依賴于線程組,這就意味著從函數(shù)的角度看來,某個(gè)線程組的線程#1和另一個(gè)線程組的線程#1是沒有區(qū)別的。另外,該函數(shù)沒有參數(shù)。

    這一函數(shù)不能用在任何配置元件中(如用戶定義的變量),原因在于配置元件是由一個(gè)獨(dú)立線程運(yùn)行的。另外在測試計(jì)劃(Test Plan)中使用也是沒有意義的。

    4)__intSum

    函數(shù)__intSum可以被用來計(jì)算兩個(gè)或者更多整數(shù)值的合。

    參數(shù)如表11-4所示。

    表11-4? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    第1個(gè)參數(shù)

    第1個(gè)整數(shù)值

    第2個(gè)參數(shù)

    第2個(gè)整數(shù)值

    第n個(gè)參數(shù)

    第n個(gè)整數(shù)值

    最后一個(gè)參數(shù)

    重用函數(shù)計(jì)算值的引用名。如果用戶指定

    了這一參數(shù),那么引用名中必須包含一個(gè)非

    數(shù)字字母,否則它會(huì)被當(dāng)成另一個(gè)整數(shù)值,

    而被函數(shù)用于計(jì)算

    詳解JMeter函數(shù)和變量(4)

    JMeter 2.3.1及其以前版本,要求必須有引用名參數(shù)。后續(xù)JMeter版本中,引用名是可選的參數(shù),但是引用名不能是整數(shù)值。

    5)__longSum

    函數(shù)__ longSum可以被用來計(jì)算兩個(gè)或者更多長整型值的合。

    參數(shù)如表11-5所示。

    表11-5? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    第1個(gè)參數(shù)

    第1個(gè)長整型值

    第2個(gè)參數(shù)

    第2個(gè)長整型值

    第n個(gè)參數(shù)

    第n個(gè)長整型值

    最后一個(gè)參數(shù)

    重用函數(shù)計(jì)算值的引用名。如果用戶指

    定了這一參數(shù),那么引用名中必須包含一個(gè)

    非數(shù)字字母,否則它會(huì)被當(dāng)成另一個(gè)長整

    型值,而被函數(shù)用于計(jì)算

    6)__StringFromFile

    函數(shù)__StringFromFile可以被用來從文本文件中讀取字符串。這對(duì)于需要大量可變數(shù)據(jù)的測試很有用。例如,當(dāng)測試一個(gè)銀行應(yīng)用系統(tǒng)時(shí),測試人員可能需要100條甚至1000條賬戶信息。

    使用配置元件CSV Data Set Config ,也能達(dá)到相同的目的,而且方法更簡單。但是該配置元件目前不支持多輸入文件。

    每次調(diào)用函數(shù),都會(huì)從文件中讀取下一行。當(dāng)?shù)竭_(dá)文件末尾時(shí),函數(shù)又會(huì)從文件開始處重新讀取,直到最大循環(huán)次數(shù)。如果在一個(gè)測試腳本中對(duì)該函數(shù)有多次 引用,那么每一次引用都會(huì)獨(dú)立打開文件,即使文件名是相同的(如果函數(shù)讀取的值,在腳本其他地方也有使用,那么就需要為每一次函數(shù)調(diào)用指定不同的變量 名)。

    如果在打開或者讀取文件時(shí)發(fā)生錯(cuò)誤,那么函數(shù)就會(huì)返回字符串"**ERR**"。

    參數(shù)如表11-6所示。

    表11-6? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    文件名

    文件名(可以使用相對(duì)于JMeter啟動(dòng)

    目錄的相對(duì)路徑)。如果要在文件名中

    使用可選的序列號(hào),那么文件名必須適

    合轉(zhuǎn)成十進(jìn)制格式。參考下面的例子

    變量名

    一個(gè)引用名(refName)的目的是復(fù)

    用這一函數(shù)創(chuàng)建的值。可以使用語法

    ${refName}來引用函數(shù)創(chuàng)建的值。

    默認(rèn)值為“StringFromFile_”

    初始序列號(hào)

    初始序列號(hào)(如果省略這一參數(shù),

    終止序列號(hào)會(huì)作為一個(gè)循環(huán)計(jì)數(shù)器)

    終止序列號(hào)

    終止序列號(hào)(如果省略這一參數(shù),

    序列號(hào)會(huì)一直增加下去,不會(huì)受到限制)

    當(dāng)打開或者重新打開文件時(shí),文件名參數(shù)將會(huì)被解析。

    每次執(zhí)行函數(shù)時(shí),引用名參數(shù)(如果支持)將會(huì)被解析。

    使用序列號(hào):當(dāng)使用可選的序列號(hào)時(shí),文件名需要使用格式字符串java.text.DecimalFormat。當(dāng)前的序列號(hào)會(huì)作為唯一的參數(shù)。如果不指明可選的初始序列號(hào),就使用文件名作為起始值。一些有用的格式序列如下:

    #:插入數(shù)字,不從零開始,不包含空格。

    000:插入數(shù)字,包含3個(gè)數(shù)字組合,不從零開始。

    例如:

  • pin#'.'dat?->?pin1.dat,?...?pin9.dat,?pin10.dat,?...?pin9999.dat? ?
  • pin000'.'dat?->?pin001.dat?...?pin099.dat?...?pin999.dat?...?pin9999.dat? ?
  • pin'.'dat#?->?pin.dat1,?...?pin.dat9?...?pin.dat999 ?
  • 如果不希望某個(gè)格式字符被翻譯,測試人員需要為它加上單引號(hào)。注意"."是格式字符,必須被單引號(hào)所包含。

    如果省略了初始序列號(hào),而終止序列號(hào)參數(shù)將會(huì)作為循環(huán)計(jì)數(shù)器,文件將會(huì)被使用指定的次數(shù)。例如:

    ${_StringFromFile(PIN#'.'DAT,,1,2)}:讀取 PIN1.DAT, PIN2.DAT。

    ${_StringFromFile(PIN.DAT,,,2)}:讀取 PIN.DAT 兩次。

    7)__machineName

    函數(shù)__machineName返回本機(jī)的主機(jī)名。

    參數(shù)如表11-7所示。

    表11-7? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    變量名

    重用函數(shù)計(jì)算值的引用名

    詳解JMeter函數(shù)和變量(5)

    8)__javaScript

    函數(shù)__javaScript可以用來執(zhí)行JavaScript代碼片段(非Java),并返回結(jié)果值。JMeter的_javaScript函數(shù)會(huì)調(diào)用標(biāo)準(zhǔn)的JavaScript解釋器。JavaScript會(huì)作為腳本語言使用,因此測試人員可以做相應(yīng)的計(jì)算。

    在腳本中可以訪問如下一些變量。

    Log:該函數(shù)的日志記錄器。

    Ctx:JmeterContext對(duì)象。

    Vars:JmeterVariables對(duì)象。

    threadName:字符串包含當(dāng)前線程名稱 (在2.3.2 版本中它被誤寫為"theadName")。

    sampler:當(dāng)前采樣器對(duì)象(如果存在)。

    sampleResult:前面的采樣結(jié)果對(duì)象(如果存在)。

    props:JMeter屬性對(duì)象。

    Rhinoscript允許通過它的包對(duì)象來訪問靜態(tài)方法。例如,用戶可以使用如下方法訪問JMeterContextService靜態(tài)方法:

    Packages.org.apache.jmeter.threads.JMeterContextService.getTotalThreads()

    JMeter不是一款瀏覽器,它不會(huì)執(zhí)行從頁面下載的JavaScript。

    參數(shù)如表11-8所示。

    表11-8? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    JavaScript代碼片段

    待執(zhí)行的JavaScript代碼片段。例如:

    n????????? new Date():返回當(dāng)前日期和時(shí)間

    n????????? Math.floor(Math.random()*(${maxRandom}

    n????????? +1)):在0 和變量maxRandom之間的隨機(jī)數(shù)

    n????????? ${minRandom}+Math.floor(Math.random()*

    n????????? (${maxRandom}-${minRandom}+1)):

    n????????? 在變量 minRandom和maxRandom之間的隨機(jī)數(shù)

    n????????? "${VAR}"=="abcd"

    變量名

    重用函數(shù)計(jì)算值的引用名

    請(qǐng)記得為文本字符串添加必要的引號(hào)。另外,如果表達(dá)式中有逗號(hào),請(qǐng)確保對(duì)其轉(zhuǎn)義。例如,${__javaScript('${sp}'.slice(7\,99999))},對(duì)7之后的逗號(hào)進(jìn)行了轉(zhuǎn)義。

    9)__Random

    函數(shù)__Random會(huì)返回指定最大值和最小值之間的隨機(jī)數(shù)。

    參數(shù)如表11-9所示。

    表11-9? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    最小值

    最小數(shù)值

    最大值

    最大數(shù)值

    變量名

    重用函數(shù)計(jì)算值的引用名

    10)__CSVRead

    函數(shù)__CSVRead會(huì)從CSV文件讀取一個(gè)字符串(請(qǐng)注意與StringFromFile 的區(qū)別)。

    JMeter 1.9.1以前的版本僅支持從單個(gè)文件中讀取,JMeter 1.9.1及其以后版本支持從多個(gè)文件中讀取。

    在大多數(shù)情況下,新配置元件CSV Data Set更好用一些。

    當(dāng)對(duì)某個(gè)文件進(jìn)行第一次讀取時(shí),文件將被打開并讀取到一個(gè)內(nèi)部數(shù)組中。如果在讀取過程中找到了空行,函數(shù)就認(rèn)為到達(dá)文件末尾了,即允許拖尾注釋(這一特性是JMeter 1.9.1版本引入的)。

    后續(xù)所有對(duì)同一個(gè)文件名的引用,都使用相同的內(nèi)部數(shù)組。另外,文件名大小寫對(duì)函數(shù)調(diào)用很重要,哪怕操作系統(tǒng)不區(qū)分大小寫,CSVRead(abc.txt,0)和CSVRead(aBc.txt,0)會(huì)引用不同的內(nèi)部數(shù)組。

    使用*ALIAS特性可以多次打開同一個(gè)文件,另外還能縮減文件名稱。

    每一個(gè)線程都有獨(dú)立的內(nèi)部指針指向文件數(shù)組中的當(dāng)前行。當(dāng)某個(gè)線程第一次引用文件時(shí),函數(shù)會(huì)為線程在數(shù)組中分配下一個(gè)空閑行。如此一來,任何一個(gè)線程訪問的文件行,都與其他線程不同(除非線程數(shù)大于數(shù)組包含的行數(shù))。

    默認(rèn)情況下,函數(shù)會(huì)在遇到的每一個(gè)逗號(hào)處斷行。如果測試人員希望在輸入的列中使用逗號(hào),那么測試人員需要換一個(gè)分隔符(通過設(shè)置屬性csvread.delimiter來實(shí)現(xiàn)),且該符號(hào)沒有在CSV文件的任何列中出現(xiàn)。

    參數(shù)如表11-10所示。

    表11-10? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    文件名

    設(shè)置從哪個(gè)文件讀取(或者*ALIAS)

    列數(shù)

    從文件的哪一列讀取。0 =第一列, 1 =

    第二列,依此類推。“next”為走到文件的

    下一行。*ALIAS為打開一個(gè)文件,并給它分配一個(gè)別名

    例如,測試人員可以用如下參數(shù)來設(shè)置某些變量:

    1 2 3 4 COL1a ${__CSVRead(random.txt,0)}?? COL2a ${__CSVRead(random.txt,1)}${__CSVRead(random.txt,next)}?? COL1b ${__CSVRead(random.txt,0)}?? COL2b ${__CSVRead(random.txt,1)}${__CSVRead(random.txt,next)}

    ?詳解JMeter函數(shù)和變量(6)

    上面的例子會(huì)從一行中讀取兩列,接著從下一行中讀取兩列。如果所有變量都在同一個(gè)前置處理器中(用戶參數(shù)上定義的),那么行都是順序讀取的。否則,不同線程可能會(huì)讀取不同的行。

    這一函數(shù)并不適合于讀取很大的文件,因?yàn)檎麄€(gè)文件都會(huì)被存儲(chǔ)到內(nèi)存之中。對(duì)于較大的文件,請(qǐng)使用配置元件CSV Data Set或者StringFromFile 。

    11)__property

    函數(shù)__property會(huì)返回一個(gè)JMeter屬性的值。如果函數(shù)找不到屬性值,而又沒有提供默認(rèn)值,則它會(huì)返回屬性的名稱。

    例如,

    ${__property(user.dir)}:返回屬性u(píng)ser.dir的值。

    ${__property(user.dir,UDIR)}:返回屬性u(píng)ser.dir的值,并保存在變量UDIR中。

    ${__property(abcd,ABCD,atod)}:返回屬性abcd的值 (如果屬性沒有定義,返回"atod"),并保存在變量ABCD 中。

    ${__property(abcd,,atod)}:返回屬性abcd 的值(如果屬性沒有定義,返回"atod"),但是并不保存函數(shù)的返回值。

    參數(shù)如表11-11所示。

    表11-11? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    屬性名

    獲取屬性值、所需的屬性名

    變量名

    重用函數(shù)計(jì)算值的引用名

    默認(rèn)值

    屬性未定義時(shí)的默認(rèn)值

    12)_P

    函數(shù)_P是一個(gè)簡化版的屬性函數(shù),目的是使用在命令行中定義的屬性。不同于函數(shù)_property,本函數(shù)沒有提供選項(xiàng)用于設(shè)置保存屬性值的變量。 另外,如果沒有設(shè)置默認(rèn)值,默認(rèn)值自動(dòng)設(shè)為1。之所以選擇1,原因在于它對(duì)于很多常見測試變量都是一個(gè)合理值,例如,循環(huán)次數(shù)、線程數(shù)、啟動(dòng)線程耗時(shí)間 等。

    例如:定義屬性值:

    jmeter -Jgroup1.threads=7 -Jhostname1=www.realhost.edu

    獲取值如下。

    ${__P(group1.threads)}:返回屬性group1.threads的值。

    ${__P(group1.loops)}:返回屬性group1.loops 的值。

    ${__P(hostname,www.dummy.org)}:返回屬性hostname的值,如果沒有定義該屬性則返回值www.dummy.org。

    在上面的例子中,第一個(gè)函數(shù)調(diào)用返回7,第二個(gè)函數(shù)調(diào)用返回1,而最后一個(gè)函數(shù)調(diào)用返回www.dummy.org(除非這些屬性在其他地方有定義)。

    參數(shù)如表11-12所示。

    表11-12? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    屬性名

    獲取屬性值、所需的屬性名

    默認(rèn)值

    屬性未定義時(shí)的默認(rèn)值。如果省略

    此參數(shù),默認(rèn)值自動(dòng)設(shè)為1

    13)__log

    函數(shù)__log會(huì)記錄一條日志,并返回函數(shù)的輸入字符串。

    參數(shù)如表11-13所示。

    表11-13? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    待記錄字符串

    一個(gè)字符串

    日志級(jí)別

    OUT、ERR、DEBUG、INFO(默認(rèn))、

    WARN或者ERROR

    可拋棄的文本

    如果非空,會(huì)創(chuàng)建一個(gè)可拋棄

    的文本傳遞給記錄器

    注釋

    如果存在,注釋會(huì)在字符串中展示,

    用于標(biāo)識(shí)日志記錄了什么

    OUT 和ERR的日志級(jí)別,將會(huì)分別導(dǎo)致輸出記錄到System.out和System.err中。在這種情況下,輸出總是會(huì)被打印(它不依賴于當(dāng)前的日志設(shè)置)。

    例如,

    ${__log(Message)}:寫入日志文件,形如"...thread Name : Message"。

    ${__log(Message,OUT)}:寫到控制臺(tái)窗口。

    ${__log(${VAR},,,VAR=)}:寫入日志文件,形如"...thread Name VAR=value"。

    14)__logn

    函數(shù)__logn會(huì)記錄一條日志,并返回空字符串。

    參數(shù)如表11-14所示。

    表11-14? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    待記錄字符串

    一個(gè)字符串

    日志級(jí)別

    OUT,ERR,DEBUG, INFO

    (默認(rèn)),WARN 或者ERROR

    可拋棄的文本

    如果非空,會(huì)創(chuàng)建一個(gè)可拋棄的

    文本傳遞給記錄器

    OUT 和ERR的日志級(jí)別,將會(huì)分別導(dǎo)致輸出記錄到System.out和System.err中。在這種情況下,輸出總是會(huì)被打印(它不依賴于當(dāng)前的日志設(shè)置)。

    例如,${__logn(VAR1=${VAR1},OUT)}:將變量值寫到控制臺(tái)窗口中。

    15)__BeanShell

    函數(shù)__BeanShell會(huì)執(zhí)行傳遞給它的腳本,并返回結(jié)果。

    關(guān)于BeanShell的詳細(xì)資料,請(qǐng)參考BeanShell的Web站點(diǎn):http://www.beanshell.org/ 。

    需要注意,測試腳本中每一個(gè)獨(dú)立出現(xiàn)的函數(shù)調(diào)用,都會(huì)使用不同的解釋器,但是后續(xù)對(duì)函數(shù)調(diào)用的援引會(huì)使用相同的解釋器。這就意味著變量會(huì)持續(xù)存在,并跨越函數(shù)調(diào)用。

    單個(gè)函數(shù)實(shí)例可以從多個(gè)線程調(diào)用。另外,該函數(shù)的execute()方法是同步的。

    如果定義了屬性"beanshell.function.init",那么它會(huì)作為一個(gè)源文件傳遞給解釋器。這樣就可以定義一些通用方法和變量。在bin目錄中有一個(gè)初始化文件的例子:BeanShellFunction.bshrc。

    詳解JMeter函數(shù)和變量(7)

    如下變量在腳本執(zhí)行前就已經(jīng)設(shè)置了。

    log:函數(shù)BeanShell(*)的記錄器。

    ctx:目前的JMeter Context變量。

    vars:目前的JMeter變量。

    props:JMeter屬性對(duì)象。

    threadName:線程名(字符串)。

    sampler:當(dāng)前采樣器(如果存在)。

    sampleResult:當(dāng)前采樣器(如果存在)。

    "*"意味著該變量在JMeter使用初始化文件之前就已經(jīng)設(shè)置了。其他變量在不同調(diào)用之間可能會(huì)發(fā)生變化。

    參數(shù)如表11-15所示。

    表11-15? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    BeanShell腳本

    一個(gè)BeanShell腳本(不是文件名)

    變量名

    重用函數(shù)計(jì)算值的引用名

    例如,

    ${__BeanShell(123*456)}:回56088。

    ${__BeanShell(source("function.bsh"))}:行在function.bsh中的腳本。

    請(qǐng)記得為文本字符串及代表文本字符串的JMeter變量添加必要的引號(hào)。

    16)__plit

    函數(shù)__split會(huì)通過分隔符來拆分傳遞給它的字符串,并返回原始的字符串。如果分隔符緊挨在一起,那么函數(shù)就會(huì)以變量值的形式返回"?"。拆分 出來的字符串,以變量${VAR_1}、{VAR_2}…以此類推的形式加以返回。JMeter 2.1.2及其以后版本,拖尾的分隔符會(huì)被認(rèn)為缺少一個(gè)變量,會(huì)返回"?"。另外,為了更好地配合ForEach控制器,現(xiàn)在__split會(huì)刪除第一個(gè) 不用的變量(由前一次分隔符所設(shè)置)。

    例如,在測試計(jì)劃中定義變量VAR="a||c|":

  • ${__split(${VAR},VAR),|}?
  • 該函數(shù)調(diào)用會(huì)返回VAR變量的值,例如"a||c|",并設(shè)定VAR_n=4(3 ,JMeter 2.1.1及其以前版本)、VAR_1=a、VAR_2=?、VAR_3=c、VAR_4=?(null,JMeter 2.1.1及其以前版本)、VAR_5=null(JMeter 2.1.2及其以后版本)變量的值。

    參數(shù)如表11-16所示。

    表11-16? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    待拆分字符串

    一個(gè)待拆分字符串,例如“a|b|c”

    變量名

    重用函數(shù)計(jì)算值的引用名

    分隔符

    分隔符,例如“|。如果省略了此參數(shù),函數(shù)

    會(huì)使用逗號(hào)做分隔符。需要注意的是,假如測

    試人員要多此一舉,明確指定使用逗號(hào),

    需要對(duì)逗號(hào)轉(zhuǎn)義,如“\,

    17)__XPath

    函數(shù)__XPath讀取XML文件,并在文件中尋找與指定XPath相匹配的地方。每調(diào)用函數(shù)一次,就會(huì)返回下一個(gè)匹配項(xiàng)。到達(dá)文件末尾后,會(huì)從頭開始。如果沒有匹配的節(jié)點(diǎn),那么函數(shù)會(huì)返回空字符串,另外,還會(huì)向JMeter日志文件寫一條警告信息。

    整個(gè)節(jié)點(diǎn)列表都會(huì)被保存在內(nèi)存之中。

    例如:

  • ${__XPath(/path/to/build.xml,?//target/@name)}?
  • 這會(huì)找到build.xml文件中的所有目標(biāo)節(jié)點(diǎn),并返回下一個(gè)name屬性的內(nèi)容。

    參數(shù)如表11-17所示。

    表11-17? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    XML文件名

    一個(gè)待解析的XML文件名

    XPath

    一個(gè)XPath表達(dá)式,用于在

    XML文件中尋找目標(biāo)節(jié)點(diǎn)

    18)__setProperty

    函數(shù)__setProperty用于設(shè)置JMeter屬性的值。函數(shù)的默認(rèn)返回值是空字符串,因此該函數(shù)可以被用在任何地方,只要對(duì)函數(shù)本身調(diào)用是正確的。

    通過將函數(shù)可選的第3個(gè)參數(shù)設(shè)置為"true",函數(shù)就會(huì)返回屬性的原始值。

    屬性對(duì)于JMeter是全局的,因此可以被用來在線程和線程組之間通信。

    參數(shù)如表11-18所示。

    表11-18? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    屬性名

    待設(shè)置屬性名

    屬性值

    屬性的值

    True/False

    是否返回屬性原始值

    詳解JMeter函數(shù)和變量(8)

    19)__time

    函數(shù)__time可以通過多種格式返回當(dāng)前時(shí)間。

    參數(shù)如表11-19所示。

    表11-19? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    格式

    設(shè)置時(shí)間所采用的格式

    變量名

    待設(shè)置變量名

    如果省略了格式字符串,那么函數(shù)會(huì)以毫秒的形式返回當(dāng)前時(shí)間。其他情況下,當(dāng)前時(shí)間會(huì)被轉(zhuǎn)成簡單日期格式。包含如下形式:

    YMD = yyyyMMdd。

    HMS = HHmmss。

    YMDHMS = yyyyMMdd-HHmmss。

    USER1 = JMeter屬性time.USER1。

    USER2 = JMeter屬性time.USER2。

    用戶可以通過修改JMeter屬性來改變默認(rèn)格式,例如,time.YMD=yyMMdd。

    20)_jexl

    函數(shù)_jexl可以用于執(zhí)行通用JEXL表達(dá)式,并返回執(zhí)行結(jié)果。感興趣的讀者可以從下面這兩個(gè)網(wǎng)頁鏈接獲取更多關(guān)于JEXL的信息。

    http://commons.apache.org/jexl/reference/syntax.html。

    http://commons.apache.org/jexl/reference/examples.html#Example_Expressions。

    參數(shù)如表11-20所示。

    表11-20? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    表達(dá)式

    待執(zhí)行的表達(dá)式。例如,6*(5+2)

    變量名

    待設(shè)置變量名

    如下變量可以通過腳本進(jìn)行訪問。

    log:函數(shù)記錄器。

    ctx:JMeterContext對(duì)象。

    vars:JMeterVariables對(duì)象。

    props:JMeter屬性對(duì)象。

    threadName:字符串包含當(dāng)前線程名稱 (在2.3.2 版本中它被誤寫為"theadName")。

    sampler:當(dāng)前的采樣器對(duì)象(如果存在)。

    sampleResult:前面的采樣結(jié)果對(duì)象(如果存在)。

    OUT - System.out,例如 OUT.println("message")。

    JEXL可以基于它們來創(chuàng)建類,或者調(diào)用方法,例如:

  • Systemclass=log.class.forName("java.lang.System"); ?
  • now=Systemclass.currentTimeMillis();?
  • 需要注意的是,Web站點(diǎn)上的JEXL文檔錯(cuò)誤地建議使用"div"做整數(shù)除法。事實(shí)上"div"和"/"都執(zhí)行普通除法。

    JMeter 2.3.2以后的版本允許在表達(dá)式中包含多個(gè)聲明。JMeter 2.3.2及其以前的版本只處理第一個(gè)聲明(如果存在多個(gè)聲明,就會(huì)記錄一條警告日志)。

    21)__V

    函數(shù)__V可以用于執(zhí)行變量名表達(dá)式,并返回執(zhí)行結(jié)果。它可以被用于執(zhí)行嵌套函數(shù)引用(目前JMeter不支持)。

    例如,如果存在變量A1、A2和N=1,則:

    ${A1}:能正常工作。

    ${A${N}}:無法正常工作(嵌套變量引用)。

    ${__V(A${N})}:可以正常工作。A${N}變?yōu)锳1,函數(shù) __V返回變量值A(chǔ)1。

    參數(shù)如表11-21所示。

    表11-21? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    變量名表達(dá)式

    待執(zhí)行變量名表達(dá)式

    22)__evalVar

    函數(shù)__evalVar可以用來執(zhí)行保存在變量中的表達(dá)式,并返回執(zhí)行結(jié)果。

    如此一來,用戶可以從文件中讀取一行字符串,并處理字符串中引用的變量。例如,假設(shè)變量"query"中包含有"select ${column} from ${table}",而"column"和"table"中分別包含有"name"和"customers",那 么${__evalVar(query)}將會(huì)執(zhí)行"select name from customers"。

    參數(shù)如表11-22所示。

    表11-22? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    變量名

    待執(zhí)行變量名

    詳解JMeter函數(shù)和變量(9)

    23)__eval

    函數(shù)__eval可以用來執(zhí)行一個(gè)字符串表達(dá)式,并返回執(zhí)行結(jié)果。

    如此一來,用戶就可以對(duì)字符串(存儲(chǔ)在變量中)中的變量和函數(shù)引用做出修改。例如,給定變量name=Smith、column=age、 table=birthdays、SQL=select ${column} from ${table} where name='${name}',那么通過${__eval(${SQL})},就能執(zhí)行"select age from birthdays where name='Smith'"。這樣一來,就可以與CSV數(shù)據(jù)集相互配合,例如,將SQL語句和值都定義在數(shù)據(jù)文件中。

    參數(shù)如表11-23所示。

    表11-23? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    變量名

    待執(zhí)行變量

    24)__char

    函數(shù)__char會(huì)將一串?dāng)?shù)字翻譯成Unicode字符,另外還請(qǐng)參考下面__unescape()函數(shù)。

    參數(shù)如表11-24所示。

    表11-24? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    Unicode字符編碼

    (十進(jìn)制數(shù)或者十六進(jìn)制數(shù))

    待轉(zhuǎn)換的Unicode字符編碼,

    可以是十進(jìn)制數(shù)或者十六進(jìn)制數(shù)

    Unicode字符編碼(十進(jìn)制數(shù)或者十六進(jìn)制數(shù))?待轉(zhuǎn)換的Unicode字符編碼,可以是十進(jìn)制數(shù)或者十六進(jìn)制數(shù)是

    例如:

  • ${__char(0xC,0xA)}?=?CRLF? ?
  • ${__char(165)}?=?????(yen) ?
  • 函數(shù)__unescape用于反轉(zhuǎn)義Java-escaped字符串,另外還請(qǐng)參考上面的__char函數(shù)。

    參數(shù)如表11-25所示。

    表11-25? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    待反轉(zhuǎn)義字符串

    待反轉(zhuǎn)義字符串

    例如:

  • ${__unescape(\r\n)}?=?CRLF ?
  • ${__unescape(1\t2)}?=?1[tab]2 ?
  • 26)__unescapeHtml

    函數(shù)__unescapeHtml用于反轉(zhuǎn)義一個(gè)包含HTML實(shí)體的字符串,將其變?yōu)榘瑢?shí)際Unicode字符的字符串。支持HTML 4.0實(shí)體。

    例如,字符串"&lt;Fran&ccedil;ais&gt;"變?yōu)?#34;<Fran?ais>"。

    如果函數(shù)不認(rèn)識(shí)某個(gè)實(shí)體,就會(huì)將實(shí)體保留下來,并一字不差地插入結(jié)果字符串中。例如,">&zzzz;x"會(huì)變?yōu)?#34;>&zzzz;x"。

    參數(shù)如表11-26所示。

    表11-26? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    待反轉(zhuǎn)義字符串

    待反轉(zhuǎn)義字符串

    27)__escapeHtml

    函數(shù)__escapeHtml用于轉(zhuǎn)義字符串中的字符(使用HTML實(shí)體)。支持HTML 4.0實(shí)體。

    例如,"bread" & "butter"變?yōu)?amp;quot;bread&quot; &amp; &quot;butter&quot;。

    參數(shù)如表11-27所示。

    表11-27? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    待轉(zhuǎn)義字符串

    待轉(zhuǎn)義字符串

    28)__FileToString

    函數(shù)__FileToString可以被用來讀取整個(gè)文件。每次對(duì)該函數(shù)的調(diào)用,都會(huì)讀取整個(gè)文件。

    如果在打開或者讀取文件時(shí)發(fā)生錯(cuò)誤,那么函數(shù)就會(huì)返回字符串"**ERR**"。

    參數(shù)如表11-28所示。

    表11-28? 參數(shù)描述

    函數(shù)參數(shù)

    描述

    是否必需

    文件名

    包含路徑的文件名

    (路徑可以是相對(duì)于JMeter

    啟動(dòng)目錄的相對(duì)路徑)

    文件編碼方式(如果不采

    用平臺(tái)默認(rèn)的編碼方式)

    讀取文件需要用到的文件

    編碼方式。如果沒有

    指明就使用平臺(tái)默認(rèn)的編碼方式

    變量名

    引用名(refName)用

    于重用函數(shù)創(chuàng)建的值

    詳解JMeter函數(shù)和變量(10)

    6.預(yù)定義變量

    大多數(shù)變量都是通過函數(shù)調(diào)用和測試元件(如用戶定義變量)來設(shè)置的;在這種情況下用戶擁有對(duì)變量名的完整控制權(quán)。但是有些變量是JMeter內(nèi)置的。例如,

    Cookiename:包含Cookie值。

    JMeterThread.last_sample_ok:最近的采樣是否可以(true/false)。

    START 變量(參見后續(xù)內(nèi)容)。

    7.預(yù)定義變量屬性

    JMeter屬性集是在JMeter啟動(dòng)時(shí)通過系統(tǒng)屬性初始化的;其他補(bǔ)充JMeter屬性來自于jmeter.properties、user.properties或者命令行。

    JMeter還另外定義了一些內(nèi)置屬性。下面是具體列表。從方便的角度考慮,屬性START的值會(huì)被復(fù)制到同名變量中去。

    START.MS:以毫秒為單位的JMeter啟動(dòng)時(shí)間。

    START.YMD:JMeter啟動(dòng)日期格式y(tǒng)yyyMMdd。

    START.HMS:JMeter啟動(dòng)時(shí)間格式HHmmss。

    TESTSTART.MS:以毫秒為單位的測試啟動(dòng)時(shí)間。

    請(qǐng)注意:START變量/屬性表征的是JMeter啟動(dòng)時(shí)間,而非測試的啟動(dòng)時(shí)間。它們主要用于文件名之中。

    轉(zhuǎn)載于:https://www.cnblogs.com/song0828/p/6065973.html

    總結(jié)

    以上是生活随笔為你收集整理的详解JMeter函数和变量的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。