在本文中,我将演示一种将 k6 与 XRAY/Jira 集成的简单方法。
不久前,我被分配了一项任务,为一个预计能够处理相当多请求的 API 编写性能测试。因此,我们需要一个好的工具,它可以更快地使用,并且任何 QA 工程师都可以更轻松地做出贡献。
过去使用过负载冲击,我对K6非常熟悉。这些是我们选择 k6 而不是其他性能测试工具的主要原因:
使用 Javascript:我团队中的大多数 QA/开发人员都熟悉 javascript,因此无需学习新语言
开源:这意味着,使用该工具无需付费,并且社区活跃
CI/CD:将 k6 与我们的 CI/CD 管道集成非常简单
我可以继续选择 k6 的优点,但我会写一篇新文章专门讨论这一点。
完成测试框架后,我们希望在 Jira 上获得测试结果。由于我们已经在使用 XRAY,因此我们需要一个解决方案将 k6 JSON 报告转换为 X 射线格式。我找不到任何适合我们案例的解决方案。
K6 有一个基本功能,可用于获取所有指标。这些选项是 stdout、XML 和 JSON。
为此,我们只需要创建一个脚本来从handleSummary函数中获取数据对象。
下面是将数据对象从 k6 转换为简单 XRAY 格式报告的脚本:
k6-XRAY-脚本
将存储库克隆到您所需的位置:
最好在主项目中创建一个文件夹。
例子:
助手、src、报告
这将帮助您顺利管理导入而不会出现问题:
开始之前,请确保您的计算机上安装了以下软件:
如果您的 k6 测试是分组组织的,并且每个组标题对应于 Xray 上的一个测试用例,您可以使用生成器脚本创建与 Xray 兼容的 JSON 文件。
Xray 文档中的下图显示了带有 CALC-01 和 CALC-02 键的测试用例。
在您的 k6 测试脚本中,您可以将组标题命名为 CALC-01 和 CALC-02。该脚本将搜索这些组名称并将测试结果分配给 Xray 上的相应测试用例。
group('CALC-01', function() { // test code }); group('CALC-02', function() { // test code });
脚本生成与Xray兼容的JSON文件,保存在与脚本相同的目录中。
git clone https://github.com/skingori/k6-json-xray.git
我们将使用k6提供的handleSummary函数和generator.js脚本中的textSummary来生成JSON文件。 handleSummary 函数接收一个数据对象,我们将其传递给 getSummary 以将其修改为 Xray 兼容的格式。
在这里阅读有关 k6 HandleSummary 的更多信息
更改打开执行脚本并添加以下行:
import { getSummary } from "./generator.js"; import { textSummary } from "https://jslib.k6.io/k6-summary/0.0.1/index.js";
我直接使用 ./generator.js,因为它与我的脚本位于同一文件夹中。假设您使用的是助手,这应该是:
import { getSummary } from "./helper/generator.js";
在代码末尾添加handleSummary函数:
export function handleSummary(data) { return { stdout: textSummary(data, { indent: " ", enableColors: true }), "summary.json": JSON.stringify(getSummary(data, "CALC-2062", "CALC"), null, 2) }; }
我们的函数 getSummary 会将数据对象转换为 X 射线预期格式并将输出保存到summary.json 文件中
为什么我们使用 textSummary?
要在控制台上打印输出,我们需要从 k6 JS 实用程序库导入 textSummary
但这可能不适用于每个人,如果您不需要任何标准输出报告,则不必导入 textSummary
import http from 'k6/http'; import { sleep, group, check } from 'k6'; import { getSummary } from "./generator.js"; import { textSummary } from "https://jslib.k6.io/k6-summary/0.0.1/index.js"; export const options = { vus: 10, duration: '30s', }; export default function() { group('CALC-01', function() { const resp = http.get('http://test.k6.io'); check(resp, { 'status is 200': (r) => r.status === 200, }); sleep(1); }); group('CALC-02', function() { const resp = http.get('http://test.k6.io'); check(resp, { 'status is 200': (r) => r.status === 200, }); sleep(1); }); }; export function handleSummary(data) { return { stdout: textSummary(data, { indent: " ", enableColors: true }), "summary.json": JSON.stringify(getSummary(data, "CALC-2062", "CALC"), null, 2) }; }
注意:如果您不想导入 textSummary,可以删除 stdout: textSummary(data, { indent: " ", enableColors: true }), line
handleSummary 默认工作,通常在测试生命周期结束时调用。
要运行脚本,请使用以下命令:
k6 run script.js -e TEST_PLAN_KEY="CALC-2345" -e TEST_EXEC_KEY="CALC-0009"
TEST_PLAN_KEY 和 TEST_EXEC_KEY 用于识别 Xray 上的测试计划和测试执行。
在此处阅读有关测试计划和测试执行键的更多信息
上述脚本将在summary.json下生成以下报告
{ "info": { "summary": "K6 Test execution - Mon Sep 09 2024 21:20:16 GMT 0300 (EAT)", "description": "This is k6 test with maximum iteration duration of 4.95s, 198 passed requests and 0 failures on checks", "user": "k6-user", "startDate": "2024-09-09T18:20:16.000Z", "finishDate": "2024-09-09T18:20:16.000Z", "testPlanKey": "CALC-2345" }, "testExecutionKey": "CALC-0009", "tests": [ { "testKey": "CALC-01", "start": "2024-09-09T18:20:16.000Z", "finish": "2024-09-09T18:20:16.000Z", "comment": "Test execution passed", "status": "PASSED" }, { "testKey": "CALC-02", "start": "2024-09-09T18:20:16.000Z", "finish": "2024-09-09T18:20:16.000Z", "comment": "Test execution passed", "status": "PASSED" } ] }
要获取有关 k6 和 X-ray 的更多详细信息,请参阅他们的文档:
K6文件
X射线文件
也请查看这篇文章 - 如何使用 Xray 和 Jira 创建和管理测试用例,这是 Sérgio Freire 撰写的一篇很酷的文章
一如既往,请随时与我联系!
领英
电子邮件
GitHub
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3