」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何整合 Xray/Jira

如何整合 Xray/Jira

發佈於2024-11-08
瀏覽:331

在本文中,我将演示一种将 k6 与 XRAY/Jira 集成的简单方法。

不久前,我被分配了一项任务,为一个预计能够处理相当多请求的 API 编写性能测试。因此,我们需要一个好的工具,它可以更快地使用,并且任何 QA 工程师都可以更轻松地做出贡献。
过去使用过负载冲击,我对K6非常熟悉。这些是我们选择 k6 而不是其他性能测试工具的主要原因:

  • 使用 Javascript:我团队中的大多数 QA/开发人员都熟悉 javascript,因此无需学习新语言

  • 开源:这意味着,使用该工具无需付费,并且社区活跃

  • CI/CD:将 k6 与我们的 CI/CD 管道集成非常简单

我可以继续选择 k6 的优点,但我会写一篇新文章专门讨论这一点。

完成测试框架后,我们希望在 Jira 上获得测试结果。由于我们已经在使用 XRAY,因此我们需要一个解决方案将 k6 JSON 报告转换为 X 射线格式。我找不到任何适合我们案例的解决方案。

K6 句柄摘要()

K6 有一个基本功能,可用于获取所有指标。这些选项是 stdout、XML 和 JSON。

为此,我们只需要创建一个脚本来从handleSummary函数中获取数据对象。

下面是将数据对象从 k6 转换为简单 XRAY 格式报告的脚本:

k6-XRAY-脚本

如何为 k6 和 Xray 集成设置生成器帮助程序脚本

将存储库克隆到您所需的位置:
最好在主项目中创建一个文件夹。

例子:
助手、src、报告

这将帮助您顺利管理导入而不会出现问题:

先决条件

开始之前,请确保您的计算机上安装了以下软件:

  • Node.js
  • npm
  • k6

用法

如果您的 k6 测试是分组组织的,并且每个组标题对应于 Xray 上的一个测试用例,您可以使用生成器脚本创建与 Xray 兼容的 JSON 文件。

例子

Xray 文档中的下图显示了带有 CALC-01 和 CALC-02 键的测试用例。

How to integrate kith Xray/Jira

在您的 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

版本聲明 本文轉載於:https://dev.to/skingori/how-to-integrate-k6-with-xrayjira-5g1g?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3