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 के रूप में सहेजें । रन → स्टार्ट विकल्प का उपयोग करके इस परीक्षण योजना को निष्पादित करें।

आउटपुट देखें

निम्न आउटपुट श्रोता में देखा जा सकता है।

अंतिम छवि में, आप प्रतिक्रिया संदेश "हैलो मनीषा टू जेएक्स डब्ल्यूएस दुनिया" देख सकते हैं।