jMeter - Webservice 测试计划
在本章中,我们将学习如何创建测试计划来测试 WebService。为了进行测试,我们创建了一个简单的 webservice 项目并将其部署在本地 Tomcat 服务器上。
创建 Webservice 项目
为了创建 webservice 项目,我们使用了 Eclipse IDE。首先在包 com.tutorialspoint.ws 下编写服务端点接口 HelloWorld。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,该方法接受一个 String 参数。
接下来,在包 com.tutorialspoint.ws 下创建实现类 HelloWorldImpl.java。
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"); } }
现在让我们通过创建 Endpoint 发布者在本地发布此 Web 服务,并在服务器上公开该服务。
publish 方法采用两个参数 −
端点 URL 字符串。
Implementor 对象,在本例中为 HelloWorld 实现类,它作为 Web 服务公开在上述参数中提到的 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>
要将此应用程序部署为 Web 服务,我们需要另一个配置文件 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 文件。
将其另存为 Tomcat 服务器的 webapps 文件夹下的 hello.war 文件。
现在启动 Tomcat 服务器。
服务器启动后,您应该能够使用 URL − 访问 Web 服务http://localhost:8080/hello/hello
创建 JMeter 测试计划
现在让我们创建一个测试计划来测试上述 webservice。
重命名测试计划
单击 /home/manisha/apache-jmeter2.9/bin/jmeter.sh 打开 JMeter 窗口。
单击测试计划节点。
将此测试计划节点重命名为 WebserviceTest。

添加线程组
添加一个线程组,它是所有其他元素(如采样器、控制器和监听器)的占位符。
右键单击 WebserviceTest(我们的测试计划)→ 添加 → 线程(用户)→ 线程组。线程组将添加到测试计划(WebserviceTest)节点下。
接下来,让我们修改线程组的默认属性以适合我们的测试。以下属性已更改 −
名称 − webservice 用户
线程数(用户) − 2
加速期 − 保留默认值 0 秒。
循环计数 − 2

添加采样器 - SOAP/XML-RPC 请求
现在我们已经定义了用户,是时候定义他们将要执行的任务了。
我们将添加 SOAP/XML-RPC 请求元素 −
右键单击鼠标按钮以获取添加菜单。
选择添加 → 采样器 → SOAP/XML-RPC 请求。
在树中选择 SOAP/XML-RPC 请求元素
如下图所示编辑以下属性 −
在此元素中输入以下详细信息 −
名称 − SOAP/XML-RPC 请求
URL − http://localhost:8080/hello/hello?wsdl
Soap/XML-RPC 数据 − 输入以下内容
<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 用户元素。
通过选择添加 → 监听器 → 查看结果树来添加查看结果树监听器。

运行测试计划
现在将上述测试计划另存为 test_webservice.jmx。使用运行 → 执行此测试计划启动选项。
查看输出
在监听器中可以看到以下输出。



在最后一张图片中,你可以看到响应消息"Hello Manisha to JAX WS world"。