jMeter - कार्य
JMeter फ़ंक्शंस और उपयोगकर्ता चर
जेमीटर के कार्य विशेष मूल्य हैं जो किसी भी पेड़ में किसी भी नमूना या अन्य तत्व के क्षेत्रों को आबाद कर सकते हैं।
एक फ़ंक्शन कॉल इस तरह दिखता है -
${__functionName(var1,var2,var3)}
_functionName एक फ़ंक्शन के नाम से मेल खाता है। उदाहरण के लिए${__threadNum}।
यदि किसी फ़ंक्शन पैरामीटर में अल्पविराम होता है, तो सुनिश्चित करें कि आप इसे नीचे दिखाए गए अनुसार "\" से बच सकते हैं -
${__time(EEE\, d MMM yyyy)}
चर के रूप में संदर्भित हैं -
${VARIABLE}
कार्यों की सूची
निम्न तालिका प्रकारों के एक समूह को शिथिल रूप से सूचीबद्ध करती है -
प्रकार प्रकार | नाम | टिप्पणी |
---|---|---|
जानकारी | threadNum | थ्रेड नंबर प्राप्त करें। |
जानकारी | samplerName | नमूना नाम (लेबल) प्राप्त करें। |
जानकारी | machineIP | स्थानीय मशीन आईपी पता प्राप्त करें। |
जानकारी | मशीन का नाम | स्थानीय मशीन का नाम प्राप्त करें। |
जानकारी | समय | विभिन्न स्वरूपों में वर्तमान समय लौटें। |
जानकारी | लॉग | एक संदेश लॉग (या प्रदर्शित) और (मूल्य वापस करें)। |
जानकारी | logn | लॉग (या प्रदर्शन) एक संदेश (खाली वापसी मूल्य)। |
इनपुट | StringFromFile | एक फ़ाइल से एक पंक्ति पढ़ें। |
इनपुट | FileToString | एक पूरी फाइल पढ़ें। |
इनपुट | CSVRead | CSV सीमांकित फ़ाइल से पढ़ें। |
इनपुट | XPath | किसी फ़ाइल से पढ़ने के लिए XPath एक्सप्रेशन का उपयोग करें। |
गणना | काउंटर | वेतन वृद्धि संख्या उत्पन्न करें। |
गणना | intSum | इंट नंबर जोड़ें। |
गणना | longSum | लंबी संख्या जोड़ें। |
गणना | बिना सोचे समझे | एक यादृच्छिक संख्या उत्पन्न करें। |
गणना | RandomString | एक यादृच्छिक स्ट्रिंग उत्पन्न करें। |
गणना | UUID | एक यादृच्छिक प्रकार 4 UUID उत्पन्न करें। |
स्क्रिप्टिंग | BeanShell | बीनशेल स्क्रिप्ट चलाएं। |
स्क्रिप्टिंग | जावास्क्रिप्ट | प्रक्रिया जावास्क्रिप्ट (मोज़िला राइनो)। |
स्क्रिप्टिंग | jexl, jexl2 | एक कॉमन्स Jexl अभिव्यक्ति का मूल्यांकन करें। |
गुण | संपत्ति | एक संपत्ति पढ़ें। |
गुण | पी | एक संपत्ति (आशुलिपि विधि) पढ़ें। |
गुण | setProperty | एक JMeter संपत्ति सेट करें। |
चर | विभाजित करें | एक स्ट्रिंग को चर में विभाजित करें। |
चर | वी | एक चर नाम का मूल्यांकन करें। |
चर | eval | एक चर अभिव्यक्ति का मूल्यांकन करें। |
चर | evalVar | एक चर में संग्रहीत अभिव्यक्ति का मूल्यांकन करें। |
तार | regexFunction | एक नियमित अभिव्यक्ति का उपयोग करके पिछली प्रतिक्रिया को पार्स करें। |
तार | escapeOroRegexpChars | ओआरओ नियमित अभिव्यक्ति द्वारा उपयोग किए जाने वाले उद्धरण मेटा चार्ट। |
तार | चार | संख्याओं की सूची से यूनिकोड वर्ण मान उत्पन्न करें। |
तार | unescape | जावा से बचने की प्रक्रिया के तार (जैसे \ n & \ t)। |
तार | unescapeHtml | HTML-एन्कोडेड स्ट्रिंग्स को डिकोड करें। |
तार | escapeHtml | HTML एन्कोडिंग का उपयोग करके तारों को एन्कोड करें। |
तार | TestPlanName | वर्तमान परीक्षण योजना का नाम लौटाएं। |
दो प्रकार के कार्य हैं -
उपयोगकर्ता-परिभाषित स्थिर मूल्य (या चर)
अंतर्निहित कार्य
उपयोगकर्ता द्वारा परिभाषित स्थैतिक मान उपयोगकर्ता को एक परीक्षण ट्री संकलित किए जाने और चलाने के लिए प्रस्तुत किए जाने पर वैरिएबल को उनके स्थिर मूल्य से प्रतिस्थापित करने की अनुमति देता है।
चरों को नेस्टेड नहीं किया जा सकता है; अर्थात${Var${N}} काम नहीं करता।
__V (चर) फ़ंक्शन (2.2 के बाद के संस्करण) का उपयोग यह करने के लिए किया जा सकता है - $ {__ वी (वार $ {एन})}।
इस प्रकार का प्रतिस्थापन कार्यों के बिना संभव है, लेकिन यह कम सुविधाजनक है और कम सहज है।
जहां फंक्शंस और वेरिएबल्स का उपयोग करें
कार्य और चर किसी भी परीक्षण घटक के किसी भी क्षेत्र में लिखे जा सकते हैं।
निम्नलिखित कार्य एक परीक्षण योजना में अच्छी तरह से काम करना चाहिए -
- intSum
- longSum
- machineName
- BeanShell
- javaScript
- jexl
- random
- time
- संपत्ति के कार्य
- कार्य लॉग करें
टेस्ट प्लान में जिन फंक्शन्स का इस्तेमाल किया जाता है उनमें कुछ प्रतिबंध हैं। JMeter थ्रेड वेरिएबल्स पूरी तरह से सेट नहीं किए गए हैं जब फ़ंक्शन संसाधित होते हैं, इसलिए पैरामीटर के रूप में पारित किए गए चर नाम सेट नहीं किए जाएंगे और चर संदर्भ काम नहीं करेंगे। इसलिए, विभाजन () और रेगेक्स () और चर मूल्यांकन कार्य नहीं होंगे। ThreadNum () समारोह काम नहीं करेगा और यह परीक्षण योजना के स्तर पर कोई मतलब नहीं है।
चर और कार्यों का संदर्भ लेना
एक परीक्षण तत्व में एक चर को संदर्भित करना चर नाम को '$ {' और '}' के साथ जोड़कर किया जाता है।
फ़ंक्शंस को उसी तरीके से संदर्भित किया जाता है, लेकिन कन्वेंशन द्वारा, फ़ंक्शन के नाम उपयोगकर्ता मान नामों के साथ संघर्ष से बचने के लिए "__" से शुरू होते हैं।
कुछ फ़ंक्शन उन्हें कॉन्फ़िगर करने के लिए तर्क लेते हैं, और ये कोष्ठक, अल्पविराम-सीमांकित में जाते हैं। यदि फ़ंक्शन कोई तर्क नहीं लेता है, तो कोष्ठक को छोड़ा जा सकता है। उदाहरण के लिए -
${__BeanShell(vars.put("name"\,"value"))}
वैकल्पिक रूप से, आप अपनी स्क्रिप्ट को एक चर के रूप में परिभाषित कर सकते हैं, उदाहरण के लिए टेस्ट प्लान पर -
SCRIPT vars.put("name","value")
लिपि को निम्नानुसार संदर्भित किया जा सकता है -
${__BeanShell(${SCRIPT})}
समारोह हेल्पर संवाद
फंक्शन हेल्पर डायलॉग JMeter के उपलब्ध है Options टैब।
फ़ंक्शन हेल्पर का उपयोग करके, आप पुल डाउन से एक फ़ंक्शन का चयन कर सकते हैं, और इसके तर्कों के लिए मान असाइन कर सकते हैं। तालिका में बाएँ स्तंभ तर्क का एक संक्षिप्त विवरण प्रदान करता है, और दायाँ स्तंभ वह है जहाँ आप उस तर्क के लिए मान लिखते हैं। विभिन्न कार्य अलग-अलग तर्क देते हैं।
एक बार जब आप ऐसा कर लेते हैं, तो "जनरेट" बटन पर क्लिक करें, और उपयुक्त स्ट्रिंग जेनरेट हो जाती है, जिसे आप जहां चाहें वहां परीक्षण योजना में कॉपी-पेस्ट कर सकते हैं।
पूर्व-परिभाषित चर
कुछ वैरिएबल JMeter द्वारा आंतरिक रूप से परिभाषित किए गए हैं। वे हैं -
COOKIE_cookiename - कुकी मान होता है।
JMeterThread.last_sample_ok - अंतिम नमूना ठीक था या नहीं - सच / गलत। नोट - यह पोस्टप्रोसेसर और दावे के चलने के बाद अपडेट किया गया है।
स्टार्ट चर।
पहले से परिभाषित गुण
कुछ अंतर्निहित गुणों को JMeter द्वारा परिभाषित किया गया है। ये नीचे सूचीबद्ध हैं। सुविधा के लिए, START प्रॉपर्टीज़ को समान नामों के साथ चर में कॉपी किया जाता है।
START.MS - JMeter की शुरुआत मिलीसेकंड में होती है।
START.YMD - JMeter yyyyMMdd के रूप में समय शुरू करता है।
START.HMS - JMeter HHmms के रूप में समय शुरू करते हैं।
TESTSTART.MS - टेस्ट का आरंभ समय मिलीसेकंड में होता है।
ध्यान दें कि START चर / गुण JMeter स्टार्टअप समय का प्रतिनिधित्व करते हैं, न कि परीक्षण प्रारंभ समय। वे मुख्य रूप से फ़ाइल नाम आदि में उपयोग के लिए अभिप्रेत हैं।