jMeter - नियमित अभिव्यक्तियाँ
पैटर्न के आधार पर पाठ को खोजने और हेरफेर करने के लिए नियमित अभिव्यक्तियों का उपयोग किया जाता है। JMeter पैटर्न मिलान सॉफ्टवेयर Apache जकार्ता ORO सहित, JMeter परीक्षण योजना में उपयोग किए जा रहे नियमित भाव या पैटर्न के रूपों की व्याख्या करता है ।
नियमित अभिव्यक्तियों के उपयोग के साथ, हम निश्चित रूप से बहुत समय बचा सकते हैं और टेस्ट प्लान बनाते या बढ़ाते हुए अधिक लचीलापन प्राप्त कर सकते हैं। नियमित अभिव्यक्तियाँ पृष्ठों से जानकारी प्राप्त करने के लिए एक सरल विधि प्रदान करती हैं जब किसी परिणाम की भविष्यवाणी करना असंभव या बहुत कठिन होता है।
अभिव्यक्तियों का उपयोग करने का एक मानक उपयोग उदाहरण सर्वर प्रतिक्रिया से एक सत्र आईडी प्राप्त करना है। यदि सर्वर एक अद्वितीय सत्र कुंजी देता है, तो हम इसे आसानी से अपनी लोड स्क्रिप्ट में अभिव्यक्तियों का उपयोग करके प्राप्त कर सकते हैं।
अपनी परीक्षण योजना में नियमित अभिव्यक्ति का उपयोग करने के लिए, आपको JMeter के नियमित अभिव्यक्ति एक्सट्रैक्टर का उपयोग करने की आवश्यकता है। आप परीक्षण योजना में किसी भी घटक में नियमित अभिव्यक्ति रख सकते हैं।
यह बीच के अंतर पर जोर देने के लायक है contains तथा matches, जैसा कि प्रतिसाद अभिकथन परीक्षण तत्व पर प्रयोग किया जाता है -
containsइसका मतलब है कि नियमित अभिव्यक्ति लक्ष्य के कम से कम कुछ हिस्से से मेल खाती है, इसलिए 'वर्णमाला' में "'ph.b.' क्योंकि नियमित रूप से अभिव्यक्ति 'फबे' से मेल खाती है।
matchesइसका मतलब है कि नियमित अभिव्यक्ति पूरे लक्ष्य से मेल खाती है। इसलिए 'अल्फ़ाज़' को "अल। * टी" द्वारा "मिलान" किया जाता है।
मान लीजिए कि आप वेब पेज के निम्नलिखित भाग से मेल खाना चाहते हैं -
name = "file" value = "readme.txt"
और आप readme.txt एक्सट्रैक्ट करना चाहते हैं। एक उपयुक्त नियमित अभिव्यक्ति होगी -
name = "file" value = "(.+?)">
उपरोक्त विशेष वर्ण हैं -
( तथा ) - ये मैच स्ट्रिंग के हिस्से को वापस दिया जाएगा
. - किसी भी चरित्र से मेल खाते हैं
+ - एक या अधिक बार
? - पहला मैच सफल होने पर रुकें
JMeter टेस्ट प्लान बनाएँ
आइए हम रेगुलर एक्सप्रेशन एक्सट्रैक्टर में रेग्युलर एक्सप्रेशंस के उपयोग को समझें- टेस्ट प्लान लिखकर पोस्ट-प्रोसेसर एलीमेंट। यह तत्व उस पाठ पैटर्न की पहचान करने के लिए एक रेगुलर एक्सप्रेशन का उपयोग करके वर्तमान पेज से टेक्स्ट को एक्सट्रैक्ट करता है, जो एक वांछित तत्व के अनुरूप है।
सबसे पहले हम एक HTML पेज लिखते हैं जो लोगों की सूची और उनकी ईमेल आईडी है। हम इसे अपने टॉमकैट सर्वर पर तैनात करते हैं। Html (index.html) की सामग्री इस प्रकार है -
<html>
<head>
</head>
<body>
<table style = "border: 1px solid #000000;">
<th style = "border: 1px solid #000000;">ID</th>
<th style = "border: 1px solid #000000;">name</th>
<th style = "border: 1px solid #000000;">Email</th>
<tr>
<td id = "ID" style = "border: 1px solid #000000;">3</td>
<td id = "Name" style = "border: 1px solid #000000;">Manisha</td>
<td id = "Email" style = "border: 1px solid #000000;">[email protected]</td>
</tr>
<tr>
<td id = "ID" style = "border: 1px solid #000000;">4</td>
<td id = "Name" style = "border: 1px solid #000000;">joe</td>
<td id = "Email" style = "border: 1px solid #000000;">[email protected]</td>
</tr>
</table>
</body>
</html>
इसे tomcat सर्वर पर तैनात करने पर, यह पृष्ठ निम्न स्क्रीनशॉट में दिखाया गया है -
हमारी परीक्षण योजना में, हम उपरोक्त व्यक्ति सूची पृष्ठ में देखी गई व्यक्ति तालिका की पहली पंक्ति में व्यक्ति का चयन करेंगे। इस व्यक्ति की आईडी कैप्चर करने के लिए, आइए पहले हम उस पैटर्न को निर्धारित करें जहां हम उस व्यक्ति को दूसरी पंक्ति में पाएंगे।
जैसा कि निम्नलिखित स्नैपशॉट में देखा जा सकता है, दूसरे व्यक्ति की आईडी <td id = "ID"> और </ td> से घिरी हुई है, और यह इस पैटर्न वाले डेटा की दूसरी पंक्ति है। हम इसका उपयोग उस सटीक पैटर्न से मेल खाने के लिए कर सकते हैं जिससे हम जानकारी निकालना चाहते हैं। जैसा कि हम इस पृष्ठ से जानकारी के दो टुकड़े निकालना चाहते हैं, व्यक्ति आईडी और व्यक्ति का नाम, फ़ील्ड निम्नानुसार परिभाषित किए गए हैं -
JMeter प्रारंभ करें, थ्रेड समूह जोड़ें Test Plan → Add→ Threads(Users)→ Thread Group।
अगला एक नमूना HTTP अनुरोध जोड़ें, परीक्षण योजना का चयन करें, राइट क्लिक करें Add → Sampler → HTTP Request और नीचे दिखाए अनुसार विवरण दर्ज करें -
Name - प्रबंधित करें
Server Name or IP - लोकलहोस्ट
Port Number - 8080
Protocol - हम इसे रिक्त रखेंगे, जिसका अर्थ है कि हम प्रोटोकॉल के रूप में HTTP चाहते हैं।
Path - jmeter / index.html
अगला, एक नियमित अभिव्यक्ति एक्सट्रैक्टर जोड़ें। HTTP रिक्वेस्ट सैम्पलर (मैनेज) का चयन करें, राइट क्लिक करेंAdd → Post Processor → Regular Expression Extractor।
निम्न तालिका उपरोक्त स्क्रीनशॉट में उपयोग किए गए फ़ील्ड का विवरण प्रदान करती है -
अनु क्रमांक | फ़ील्ड और विवरण |
---|---|
1 | Reference Name उस चर का नाम जिसमें निकाले गए परीक्षण को संग्रहीत किया जाएगा (refname)। |
2 | Regular Expression जिस पैटर्न के खिलाफ टेक्स्ट को निकाला जाना है, उसका मिलान किया जाएगा। जो पाठ समूह निकाले जाएंगे, वे वर्णों ('और') '' से संलग्न हैं। हम '+' का उपयोग करते हैं। <td ..> .. </ td> टैग द्वारा संलग्न पाठ का एक भी उदाहरण इंगित करने के लिए। हमारे उदाहरण में अभिव्यक्ति है - <td id = "ID"> (+?) </ Td> \ s * <td id = "Name"> (+?) </ Td> \ s * |
3 | Template '(' और ')' द्वारा संलग्न पैटर्न के प्रत्येक समूह के आदेश का पालन करते हुए, निकाले गए पाठ के प्रत्येक समूह को चर व्यक्ति के सदस्य के रूप में रखा गया है। प्रत्येक समूह को refname_g # के रूप में संग्रहीत किया जाता है, जहां Refname वह स्ट्रिंग है जिसे आपने संदर्भ नाम के रूप में दर्ज किया है, और # समूह संख्या है। $ 1 $ समूह 1 को संदर्भित करता है, $ 2 $ समूह 2 को संदर्भित करता है, आदि $ 0 $ जो भी पूरे अभिव्यक्ति से मेल खाता है। इस उदाहरण में, हम जो आईडी निकालते हैं, उसे Person_g1 में बनाए रखा जाता है, जबकि Name मान को Person_g2 में संग्रहीत किया जाता है। |
4 | Match No. चूंकि हम इस पैटर्न की केवल दूसरी घटना को निकालने की योजना बनाते हैं, दूसरे स्वयंसेवक से मेल खाते हैं, हम मूल्य 2 का उपयोग करते हैं। मान 0 एक यादृच्छिक मिलान करता है, जबकि एक नकारात्मक मूल्य को फॉरएवर नियंत्रक के साथ उपयोग करने की आवश्यकता होती है। |
5 | Default यदि आइटम नहीं मिला है, तो यह डिफ़ॉल्ट मान होगा। यह एक वैकल्पिक फ़ील्ड है। आप इसे खाली छोड़ सकते हैं। |
इस परीक्षण योजना के परिणाम को पकड़ने के लिए एक श्रोता जोड़ें। थ्रेड समूह पर राइट-क्लिक करें और श्रोता जोड़ने के लिए → → श्रोता → परिणाम ट्री विकल्प चुनें।
परीक्षण योजना को reg_express_test.jmx के रूप में सहेजें और परीक्षण चलाएँ। निम्न स्क्रीनशॉट में दिखाए अनुसार आउटपुट एक सफलता होगी -