在继续本节之前,让我们先了解一些有关WebServicesAPI的关键概念。
WebServices
Web服务被定义为旨在通过网络支持两台机器之间交互的软件系统。它被设计为具有以通常在Web服务描述语言(WSDL)中指定的机器可处理格式描述的接口。通常,“HTTP”是最常用的通信协议。Web服务还使用SOAP,REST和XML-RPC作为通信手段。
Web服务可能不包含完整的规范集,有时可能无法执行完整API可能执行的所有任务。
API(应用程序编程接口)
API充当两个不同应用程序之间的接口,以便它们可以相互通信。这是第三方供应商可以编写与其他程序轻松连接的程序的方法。API可以使用任何通信方式来启动应用程序之间的交互。例如,Linux内核API使用中断调用系统调用。
API包含一套完整的规则和规范,供软件程序遵循以便于交互。
WebAPI
WebAPI可以被视为Web服务中的一种开发,其中重点已经转移到更简单的基于表示状态转移(REST)的通信。RestfulAPI不需要基于XML的Web服务协议(SOAP和WSDL)来支持其接口。
Web服务大致分为两类:
1) 简单对象访问协议(SOAP)
2) 代示状态转移(REST)
为了测试目的,我们将使用一些公开可用的RESTAPI来测试JMeter。
可以在Internet上搜索各种可公开使用的RESTAPI。并获取API密钥以在JMeter中设置测试。您还可以使用任何开发环境构建整个Web服务项目,并将其部署在JMeter上以运行测试计划。
对于此测试,我们使用的是开放天气地图网站在URL下提供的API:
https://openweathermap.org/api
下图显示了Open Weather Map网站提供的API部分。
可以在此网站上注册以访问您的API密钥,该密钥随后用于获取正确的天气报告。
在我们的例子中,生成的API密钥
:3f25ec8eed9e1951e21407a34312c2c8
下图显示了成功登录后生成的API密钥。
现在,我们将使用此API密钥以及调用API的方法来获得所需的结果。调用API的方法包括服务器名称,后跟城市代码/城市名称和API密钥。
下图显示了OpenWeatherMap网站提供的API调用示例。
现在,我们将创建一个测试计划来测试OpenWeatherMap网站提供的REST API。
创建JMeter测试计划
- 进入到JMeter/bin文件夹,双击jmeter.bat文件以启动JMeter界面。
- 单击“Test Plan”节点。
- 将此测试计划节点重命名为: WebServiceTest 。
- 选择 WebServiceTest 节点,然后右键单击所选项。
- 鼠标悬停在“Add” 选项上,然后将显示元素列表。
- 选择“线程(用户)”>“线程组”。
修改线程组的以下属性:
- 名称 – Webservice user
- 线程数(用户) – 2
- 加速期 – 保留默认值(1)。
- 循环计数-1
添加采样器
- 选择Webservice user 元素(线程组),然后右键单击所选项。
- 鼠标悬停在“Add”选项上,然后将显示元素列表。
- 选择Sampler> HTTP Request。
在HTTP Request控制面板中设置以下字段:
- 名称 – HTTP请求
- 服务器名称或IP – api.openweathermap.org
- 路径 – data/2.5/weather
- 参数 – q = London
- appid = 3f25ec8eed9e1951e21407a34312c2c8
添加监听器
Listener元素将负责将HTTP请求的所有结果存储在文件中,并呈现数据的可视化模型。
- 选择Webservice user元素。
- 鼠标悬停在“Add”选项上,然后将显示元素列表。
- 选择Listener> View Results Tree选项。
保存并执行测试计划
- 单击 File > Save Test Plan as 。
- 将整个测试计划保存为HTTP_test.jmx。
单击Run > Start以执行测试计划。
验证输出
可以在侦听器中看到以下输出。
在响应数据选项卡中,可以看到OpenWeatherMap网站提供的实际天气报告。