当前位置: 首页 > news >正文

Spring Boot Cucumber 测试报告嵌入方法

在Spring Boot项目中结合Cucumber进行测试时,将结果(如图片、JSON数据)嵌入到测试报告中,主要通过Cucumber的嵌入(Embedding)机制实现。以下是具体实现步骤和示例:


核心原理

Cucumber支持在步骤定义中通过Scenario对象附加(attach)任意二进制或文本数据,这些数据会被自动嵌入到生成的报告中(如HTML报告)。


实现步骤

1. 添加依赖

确保cucumber-javacucumber-spring依赖中包含报告模块:

<dependency><groupId>io.cucumber</groupId><artifactId>cucumber-java</artifactId><version>7.15.0</version>
</dependency>
<dependency><groupId>io.cucumber</groupId><artifactId>cucumber-spring</artifactId><version>7.15.0</version>
</dependency>
<dependency><groupId>io.cucumber</groupId><artifactId>cucumber-picocontainer</artifactId> <!-- 可选,依赖注入 --><version>7.15.0</version>
</dependency>
2. 配置报告生成

@CucumberOptions中指定HTML报告格式:

@RunWith(Cucumber.class)
@CucumberOptions(features = "src/test/resources/features",glue = "com.example.steps",plugin = {"pretty","html:target/cucumber-report.html",  // 生成HTML报告"json:target/cucumber.json"          // 生成JSON报告(可选)}
)
public class RunCucumberTest {
//Powered by https://zhengkai.blog.csdn.net/
}
 
3. 嵌入数据到报告

在步骤定义中注入Scenario对象,使用attach()方法嵌入数据:

示例1:嵌入图片(如失败截图)
import io.cucumber.java.AfterStep;
import io.cucumber.java.Scenario;
import org.openqa.selenium.OutputType;
import org.openqa.selenium.TakesScreenshot;
import org.springframework.beans.factory.annotation.Autowired;public class UISteps {@Autowiredprivate WebDriver webDriver; // 假设已配置Selenium WebDriver@AfterSteppublic void captureScreenshotOnFailure(Scenario scenario) {if (scenario.isFailed()) {// 截取屏幕为字节数组byte[] screenshot = ((TakesScreenshot) webDriver).getScreenshotAs(OutputType.BYTES);// 嵌入图片到报告(MIME类型指定为image/png)scenario.attach(screenshot, "image/png", "Failure Screenshot");}}
}
示例2:嵌入JSON数据
import io.cucumber.java.en.Then;
import io.cucumber.java.Scenario;
import com.fasterxml.jackson.databind.ObjectMapper;public class ApiSteps {@Then("验证API返回的JSON")public void verifyApiResponse(Scenario scenario) throws Exception {// 模拟获取API响应ApiResponse response = callSomeApi();// 将对象转为JSON字符串String json = new ObjectMapper().writeValueAsString(response);// 嵌入JSON文本到报告(MIME类型指定为application/json)scenario.attach(json, "application/json", "API Response");}
}

报告效果

  1. HTML报告

    • 图片会直接显示在步骤下方

    • JSON数据会显示为可折叠的文本框
      https://cucumber.io/images/blog/cucumber-html-screenshot.png

  2. JSON报告
    嵌入内容会以Base64编码存储在JSON中:

    "embeddings": [{"mime_type": "image/png","data": "iVBORw0KGgoAAAANSUhEUgAA...","name": "Failure Screenshot"}
    ]
     

关键注意事项

  1. attach()方法参数

    scenario.attach(data, mimeType, description);
    • data: 支持byte[]StringInputStream

    • mimeType: 如 "image/png""application/json""text/plain"

    • description: 报告中显示的标题

  2. 钩子函数选择

    • @AfterStep:每一步执行后嵌入(适合截图)

    • @After:每个场景执行后嵌入

    • 直接在@Given/@When/@Then步骤方法中嵌入

  3. 大文件处理

    • 避免嵌入超大文件(>10MB),可能影响报告打开速度

    • 建议使用外部存储链接代替:

      scenario.attach("https://example.com/screenshot.png", "text/uri-list", "External Screenshot");
  4. Spring上下文注入
    确保步骤类被Spring管理(使用@Component注解),并开启Cucumber-Spring集成:

    @SpringBootTest(classes = DemoApplication.class)
    public class SpringIntegrationTest {}

完整项目结构

src/test/
├── java/
│   ├── com/example/
│   │   ├── RunCucumberTest.java         // Cucumber 运行器
│   │   ├── steps/
│   │   │   ├── UISteps.java             // UI步骤定义
│   │   │   └── ApiSteps.java            // API步骤定义
│   │   └── config/
│   │       └── SpringConfig.java        // Spring测试配置
│   └── resources/
│       └── features/
│           └── login.feature            // 特性文件

通过以上实现,测试执行后可在target/cucumber-report.html中查看包含嵌入数据的完整报告。

http://www.lryc.cn/news/588303.html

相关文章:

  • S7-1200 中 AT 覆盖参数的应用:灵活访问数据区域的实用指南
  • STM32小实验1--点亮LED
  • 【HarmonyOS】元服务概念详解
  • 学习日志09 python
  • 若依(RuoYi)框架项目结构全解析
  • 注解@Autowired和@Resource的区别
  • USB读写自动化压力测试
  • 【React Native】ScrollView 和 FlatList 组件
  • C++中STL六大组件List的简单介绍
  • UI前端大数据处理新挑战:如何高效处理实时数据流?
  • AI创作系列第18篇:海狸IM移动端UI统一大升级 - 从混乱到规范的技术重构之路
  • 华为MateBook D 16 SE版 2024款 12代酷睿版i5集显(MCLF-XX,MCLF-16)原厂OEM预装Win11系统
  • 浏览器自动化领域的MCP
  • Spring Boot + Thymeleaf + RESTful API 前后端整合完整示例
  • 单片机(STM32-串口通信)
  • 延迟双删
  • 【ASP.NET Core】内存缓存(MemoryCache)原理、应用及常见问题解析
  • 位置编码类型彩色图解
  • 张艺兴探班RED女团一周年舞台,见证21岁的梦想落地生根
  • 代码随想录算法训练营第二十天
  • 一文读懂现代卷积神经网络—稠密连接网络(DenseNet)
  • Journal of Engineering Mechanics and Machinery,工程力学期刊,1-2天录用,7天出版,即将送检!
  • 自定义类型 - 联合体与枚举(百度笔试题算法优化)
  • 前端将传回的List数据组织成树形数据并展示
  • 用于监测线性基础设施的分布式声学传感:现状与趋势
  • 深度剖析:动态接口代理核心原理与高级应用
  • APP测试之Monkey压力测试
  • Relocations in generic ELF (EM: 40)
  • Qt小组件 - 2(布局)瀑布流布局,GridLayout,FlowLayout
  • 虚拟列表组件如果滑动速度过快导致渲染性能问题