locust - 将数据从一个任务函数传递到另一个任务函数时出现问题,同时顺序任务一个接一个
问题描述
我们正在尝试实现基于用户场景的负载测试,它基本上在一个 url 中创建一个订单,然后我们必须在下一个 url 中传递订单 ID 以获取该订单的状态。
我们正在使用蝗虫顺序任务。因为我们希望它像第一个请求 -> 第二个请求 -> 第三个请求一样顺序运行。我们已经按预期获得了响应数据,但我们无法将该可变数据发送到第三个任务以显示订单状态。
import json
from locust import HttpLocust, TaskSet, task, TaskSequence, seq_task
class MyTaskSequence(TaskSequence):
response_data = ""
@seq_task(1)
def index(self):
print("--- First Task")
response = self.client.get("/order/testing-06a5c/")
print(response.status_code)
@seq_task(2)
def get_details(self):
print("--- Second Task")
response = self.client.post(return_data, headers={"authority": "staging.domain.com", "referer":"https://staging.domain.com/"})
print(response.status_code)
response_data = json.loads(response.text)
print(response_data["details"]["claim_uri"])
self.response_data
def on_start(self):
self.get_details()
@seq_task(3)
def post_details(self):
print(self.get_details())
print("-- Third Task", self.response_data)
#return_data = self.response_data["details"]["claim_uri"]
#response = self.client.post(return_data, headers={"authority": "staging.domain.com", "referer":"https://staging.domain.com/"})
#print(response.text)
class MyLocust(HttpLocust):
task_set = MyTaskSequence
min_wait = 5000
max_wait = 15000
host = 'https://staging.domain.com'
输出:
[2018-11-19 19:24:19,784] system.local/INFO/stdout:
[2018-11-19 19:24:19,784] system.local/INFO/stdout: --- First Task
[2018-11-19 19:24:19,785] system.local/INFO/stdout:
[2018-11-19 19:24:20,235] system.local/INFO/stdout: 200
[2018-11-19 19:24:20,235] system.local/INFO/stdout:
[2018-11-19 19:24:29,372] system.local/INFO/stdout: --- Second Task
[2018-11-19 19:24:29,373] system.local/INFO/stdout:
[2018-11-19 19:24:29,653] system.local/INFO/stdout: 200
[2018-11-19 19:24:29,654] system.local/INFO/stdout:
[2018-11-19 19:24:29,654] system.local/INFO/stdout: /payment/initiate/claim/bc6d5024-f608-41af-8e78-191798c31a69/
[2018-11-19 19:24:29,654] system.local/INFO/stdout:
[2018-11-19 19:24:37,089] system.local/INFO/stdout: --- Second Task
[2018-11-19 19:24:37,089] system.local/INFO/stdout:
[2018-11-19 19:24:37,367] system.local/INFO/stdout: 200
[2018-11-19 19:24:37,367] system.local/INFO/stdout:
[2018-11-19 19:24:37,367] system.local/INFO/stdout: /payment/initiate/claim/72217a35-01fc-488e-885e-aea81a57a463/
[2018-11-19 19:24:37,368] system.local/INFO/stdout:
[2018-11-19 19:24:37,368] system.local/INFO/stdout: None
[2018-11-19 19:24:37,368] system.local/INFO/stdout:
[2018-11-19 19:24:37,368] system.local/INFO/stdout: ('-- Third Task', '')
[2018-11-19 19:24:37,368] system.local/INFO/stdout:
^C[2018-11-19 19:24:40,598] system.local/ERROR/stderr: KeyboardInterrupt
我们想将response_data["details"]["claim_uri"]
变量传递给@seq_task(3)。这样我们就可以形成一个动态的目标domain.com/response_data["details"]["claim_uri"]
。此变量将是字符串类型,并且必须在每次第三个任务调用时单独传递。
我们尝试了这种方法,但在输出中得到了 None 。
有什么遗漏的吗?
解决方案
问题在于可变响应数据。变量的范围是本地的,而在没有 self 的情况下调用它。
下面的代码有效。
@seq_task(2)
def get_details(self):
<-- function data -->
self.response_data = json.loads(response.text)
推荐阅读
- sql - Rails 5 Postgres:是否存在包含数据库约束?
- bluetooth - 如何在两个设备之间创建蓝牙 L2CAP 连接?
- php - 从 XML 文件中读取属性
- vue.js - 如何在 vue-class-component 中访问 v-model
- arrays - 神经网络输出形状不匹配
- azure-active-directory - 自定义 Azure B2C 注册策略 - 业务逻辑 API 的客户端凭据授权流程
- c++ - 如何在 C++ 中重新声明已创建的对象值
- sql - 更新列并立即使用结果更新同一语句中的第二列
- php - 如何从 XML id 中获取价值 - PHP
- sql - SELECT 附近的输出参数语法不正确