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 स्टार्टअप समय का प्रतिनिधित्व करते हैं, न कि परीक्षण प्रारंभ समय। वे मुख्य रूप से फ़ाइल नाम आदि में उपयोग के लिए अभिप्रेत हैं।