jMeter - वेब्स सर्विस टेस्ट प्लान
इस अध्याय में, हम सीखेंगे कि वेबसेवाओं के परीक्षण के लिए टेस्ट प्लान कैसे बनाया जाए। हमारे परीक्षण के उद्देश्य के लिए, हमने एक सरल वेबबेस सेवा बनाई है और इसे स्थानीय रूप से टॉमकैट सर्वर पर तैनात किया है।
Webservice परियोजना बनाएँ
एक webservice परियोजना बनाने के लिए, हमने ग्रहण आईडीई का उपयोग किया है। सबसे पहले Service Endpoint Interface लिखेंHelloWorld पैकेज के तहत com.tutorialspoint.ws। HelloWorld.java की सामग्री इस प्रकार है -
package com.tutorialspoint.ws;
import javax.jws.WebMethod;
import javax.jws.WebService;
import javax.jws.soap.SOAPBinding;
import javax.jws.soap.SOAPBinding.Style;
//Service Endpoint Interface
@WebService
@SOAPBinding(style = Style.RPC)
public interface HelloWorld {
@WebMethod String getHelloWorldMessage(String string);
}
इस सेवा का एक तरीका है getHelloWorldMessage जो एक स्ट्रिंग पैरामीटर लेता है।
अगला, कार्यान्वयन वर्ग बनाएं HelloWorldImpl.java पैकेज के तहत com.tutorialspoint.ws।
package com.tutorialspoint.ws;
import javax.jws.WebService;
@WebService(endpointInterface="com.tutorialspoint.ws.HelloWorld")
public class HelloWorldImpl implements HelloWorld {
@Override
public String getHelloWorldMessage(String myName) {
return("Hello "+myName+" to JAX WS world");
}
}
आइए अब हम एंडपॉइंट प्रकाशक बनाकर इस वेब सेवा को स्थानीय रूप से प्रकाशित करें और सर्वर पर सेवा को उजागर करें।
प्रकाशन विधि दो मापदंडों को लेती है -
समापन बिंदु URL स्ट्रिंग।
कार्यान्वयनकर्ता वस्तु, इस मामले में HelloWorld कार्यान्वयन वर्ग, जिसे ऊपर के पैरामीटर में उल्लिखित URL द्वारा पहचाने गए समापन बिंदु पर एक वेब सेवा के रूप में उजागर किया गया है।
HelloWorldPublisher.java की सामग्री इस प्रकार है -
package com.tutorialspoint.endpoint;
import javax.xml.ws.Endpoint;
import com.tutorialspoint.ws.HelloWorldImpl;
public class HelloWorldPublisher {
public static void main(String[] args) {
Endpoint.publish("http://localhost:9000/ws/hello", new HelloWorldImpl());
}
}
नीचे दिखाए अनुसार web.xml सामग्री को संशोधित करें -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems,
Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/j2ee/dtds/web-app_2_3.dtd">
<web-app>
<listener>
<listener-class>
com.sun.xml.ws.transport.http.servlet.WSServletContextListener
</listener-class>
</listener>
<servlet>
<servlet-name>hello</servlet-name>
<servlet-class>com.sun.xml.ws.transport.http.servlet.WSServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>hello</servlet-name>
<url-pattern>/hello</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>120</session-timeout>
</session-config>
</web-app>
इस एप्लिकेशन को एक वेबसर्विस के रूप में तैनात करने के लिए, हमें एक और कॉन्फ़िगरेशन फ़ाइल की आवश्यकता होगी sun-jaxws.xml। इस फ़ाइल की सामग्री इस प्रकार है -
<?xml version = "1.0" encoding = "UTF-8"?>
<endpoints
xmlns = "http://java.sun.com/xml/ns/jax-ws/ri/runtime"
version = "2.0">
<endpoint name = "HelloWorld"
implementation = "com.tutorialspoint.ws.HelloWorldImpl"
url-pattern = "/hello"/>
</endpoints>
अब जब सभी फाइलें तैयार हो जाएंगी, तो निर्देशिका संरचना निम्न स्क्रीनशॉट में दिखाई देगी -
अब इस एप्लीकेशन की WAR फाइल बनाएं।
प्रोजेक्ट चुनें → राइट क्लिक करें → निर्यात करें → WAR फ़ाइल।
इस रूप में सहेजें hello.war के तहत फ़ाइल webapps Tomcat सर्वर का फ़ोल्डर।
अब टॉमकैट सर्वर शुरू करें।
एक बार सर्वर शुरू हो जाने के बाद, आपको URL - http: // localhost: 8080 / hello / हैलो के साथ वेबसर्वर तक पहुंचने में सक्षम होना चाहिए
JMeter टेस्ट प्लान बनाएं
अब उपरोक्त webservice का परीक्षण करने के लिए एक परीक्षण योजना बनाते हैं।
टेस्ट प्लान का नाम बदलें
Jheter विंडो को /home/manisha/apache-jmeter2.9/bin/jmeter.sh पर क्लिक करके खोलें।
टेस्ट प्लान नोड पर क्लिक करें।
इस टेस्ट प्लान नोड को WebserviceTest नाम दें।
थ्रेड समूह जोड़ें
एक थ्रेड समूह जोड़ें, जो सैम्पलर, कंट्रोलर और श्रोताओं जैसे अन्य सभी तत्वों के लिए प्लेसहोल्डर है।
WebserviceTest (हमारी परीक्षण योजना) पर राइट क्लिक करें → जोड़ें → थ्रेड्स (उपयोगकर्ता) → थ्रेड समूह। थ्रेड ग्रुप टेस्ट प्लान (वेबसर्स्टेस्ट) नोड के तहत जोड़ा जाएगा।
इसके बाद, हमें अपने परीक्षण के अनुरूप थ्रेड समूह के डिफ़ॉल्ट गुणों को संशोधित करना चाहिए। निम्नलिखित गुणों को बदल दिया जाता है -
Name - webservice उपयोगकर्ता
Number of Threads (Users) - २
Ramp-Up Period - 0 सेकंड का डिफ़ॉल्ट मान छोड़ दें।
Loop Count - २
नमूना जोड़ें - SOAP / XML-RPC अनुरोध
अब जब हमने उपयोगकर्ताओं को परिभाषित किया है, तो यह उन कार्यों को परिभाषित करने का समय है जो वे प्रदर्शन करेंगे।
हम SOAP / XML-RPC अनुरोध तत्व जोड़ देंगे -
Add मेनू प्राप्त करने के लिए माउस बटन राइट-क्लिक करें।
Add → Sampler → SOAP / XML-RPC रिक्वेस्ट सेलेक्ट करें।
ट्री में SOAP / XML-RPC रिक्वेस्ट एलिमेंट को सेलेक्ट करें
नीचे दी गई छवि के अनुसार निम्नलिखित गुणों को संपादित करें -
इस तत्व में निम्नलिखित विवरण दर्ज किए गए हैं -
Name − SOAP/XML-RPC Request
URL - http: // localhost: 8080 / हैलो / हैलो? Wsdl
Soap/XML-RPC Data - नीचे दी गई सामग्री दर्ज करें
<soapenv:Envelope xmlns:soapenv = "http://schemas.xmlsoap.org/soap/envelope/"
xmlns:web = "http://ws.tutorialspoint.com/">
<soapenv:Header/>
<soapenv:Body>
<web:getHelloWorldMessage>
<arg0>Manisha</arg0>
</web:getHelloWorldMessage>
</soapenv:Body>
</soapenv:Envelope>
श्रोता जोड़ें
अंतिम तत्व जिसे आपको अपने टेस्ट प्लान में जोड़ना है, वह एक श्रोता है। यह तत्व एक फ़ाइल में आपके HTTP अनुरोधों के सभी परिणामों को संग्रहीत करने और डेटा का एक दृश्य मॉडल प्रस्तुत करने के लिए जिम्मेदार है।
Webservice उपयोगकर्ता तत्व का चयन करें।
Add → Listener → परिणाम परिणाम ट्री का चयन करके एक दृश्य परिणाम ट्री श्रोता जोड़ें।
टेस्ट प्लान चलाएं
अब उपरोक्त परीक्षण योजना को test_webservice.jmx के रूप में सहेजें । रन → स्टार्ट विकल्प का उपयोग करके इस परीक्षण योजना को निष्पादित करें।
आउटपुट देखें
निम्न आउटपुट श्रोता में देखा जा सकता है।
अंतिम छवि में, आप प्रतिक्रिया संदेश "हैलो मनीषा टू जेएक्स डब्ल्यूएस दुनिया" देख सकते हैं।