在 Cucumber 测试中自动将 Cucumber 数据表映射到 Java 对象

简介: 在 Cucumber 测试中自动将 Cucumber 数据表映射到 Java 对象

作为 Java 开发人员,使用 Cucumber 进行行为驱动开发 (BDD) 是一种很好的方法,可以通过使用通俗易懂的语言编写测试来确保代码满足业务要求。Cucumber 最强大的功能之一是能够在功能文件中使用数据表。但是,手动将这些表映射到 Java 对象可能是重复的,并且容易出错。

为了简化此过程,库 cucumber-datatable-to-bean mapping 旨在自动将 Cucumber 数据表映射到 Java 对象。在本文中,我将向您介绍该库的功能,以及如何轻松地将其集成到 Cucumber 项目中,以节省时间并减少样板代码。

如何使用 cucumber-datatable-to-bean 映射

让我们深入了解如何在项目中使用此库。

第 1 步:将库添加到您的项目中

首先,您需要将 cucumber-datatable-to-bean 映射库添加到您的 Maven 或 Gradle 项目中。

对于 Maven,请将以下依赖项添加到您的 pom.xml:

XML 格式

<dependency>
    <groupId>io.github.deblockt</groupId>
    <artifactId>cucumber-datatable-to-bean-mapping</artifactId>
    <version>1.1.2</version>
</dependency>

对于 Gradle,请将以下内容添加到您的 build.gradle 中:

槽的

implementation 'io.github.deblockt:cucumber-datatable-to-bean-mapping:1.1.2'

第 2 步:定义 Java Bean

创建一个 Java Bean 类,该类表示要从 Cucumber 数据表映射的数据结构。使用 Java 注释来指定表头和 Bean 字段之间的映射。

例如,假设您有一个特征文件,其中包含如下所示的数据表:

小黄瓜

Given the following users exist
  | first name | last name | email                  |
  | John       | Doe       | john.doe@example.com   |
  | Jane       | Smith     | jane.smith@example.com |

您可以为User

爪哇岛

import com.deblock.cucumber.datatable.annotations.DataTableWithHeader;
import com.deblock.cucumber.datatable.annotations.Column;
@DataTableWithHeader
public class User {
    @Column
    private String firstName;
    @Column
    private String lastName;
    @Column
    private String email;
    // Getter / Setter
}
// Or use a record
@DataTableWithHeader
public record User(@Column String firstName, @Column String lastName, @Column String email) {}

步骤 3:注释您的步骤定义

现在,您可以在步骤定义中使用此类。

例如:

爪哇岛

import io.cucumber.java.en.Given;
import java.util.List;
public class UserStepDefinitions {
    @Given("the following users exist")
    public void theFollowingUsersExist(List<User> users) {
        for (User user : users) {
            System.out.println("Creating user: " + user.getFirstName() + " " + user.getLastName());
            // Logic to handle user creation
        }
    }
}

第 4 步:运行 Cucumber 测试

就这样:您现在可以运行 Cucumber 测试,该库会自动将数据表映射到对象列表。步骤定义中的 s 参数将填充特征文件中的数据,并且您可以轻松地迭代用户并执行任何必要的逻辑。UserUser

配置

Column Extra 配置

前面的示例使用默认库配置。但是,您可以在注释中提供更多详细信息,例如设置字段描述、定义字段是否为必填字段或指定列的默认值。@Column

爪哇岛

@DataTableWithHeader
public class User {
    @Column(mandatory = false, description = "The custom first name")
    private String firstName;
    @Column(defaultValue = "Doe")
    private String lastName;
    @Column(value = "overridden email name")
    private String email;
    // Getters and Setters
}

库配置

默认情况下,列名是使用人类可读格式(驼峰式命名法转换为带空格的单词)从字段名生成的。您可以通过向文件添加特定属性来覆盖此行为。cucumber.properties

属性文件

cucumber.datatable.mapper.name-builder-class=com.deblock.cucumber.datatable.mapper.name.UseFieldNameColumnNameBuilder

使用此配置,列名称将直接使用字段名称,而无需将其转换为人类可读的格式。

此外,虽然通常建议使用注释注释所有 Data Table 列,但您可以将库配置为自动将所有类字段用作 Data Table 列。@Column

属性文件

cucumber.datatable.mapper.field-resolver-class=com.deblock.cucumber.datatable.mapper.datatable.fieldresolvers.ImplicitFieldResolver
1.
使用此配置,您可以更简洁地定义 Java bean:
爪哇岛
@DataTableWithHeader
public class User {
    private String firstName;
    private String lastName;
    private String email;
    @Ignore
    private String externalInformation;
    // Getters and Setters
}

通过以这种方式配置库,除非使用注释明确忽略,否则所有字段都将自动作为 Data Table 列包含在内。@Ignore

为什么使用 cucumber-datatable-to-bean 映射?

自动映射:通过使用注释定义一次映射规则,您可以自动将数据表转换为 Java 对象。

减少样板代码:此库最大限度地减少了映射数据表所需的代码量,使您的步骤定义更简洁、更易于维护。

提高可读性:由于步骤定义中的映射代码越来越少,您的测试将变得更易于阅读和理解,这是 BDD 的核心原则之一。

增强映射错误处理:如果数据表存在问题,例如缺少列或数据类型不正确,该库会提供详细的错误消息,以帮助进行调试和测试。

cucumber-datatable-to-bean-mapping 库简化了将 Cucumber 数据表转换为 Java 对象的过程,从而节省了时间并降低了 BDD 测试中出现错误的可能性。通过将此库添加到您的项目中,您可以简化步骤定义,并将更多精力放在编写有意义的测试而不是样板代码上。


目录
相关文章
|
20天前
|
存储 Java
Java中判断一个对象是否是空内容
在 Java 中,不同类型的对象其“空内容”的定义和判断方式各异。对于基本数据类型的包装类,空指对象引用为 null;字符串的空包括 null、长度为 0 或仅含空白字符,可通过 length() 和 trim() 判断;集合类通过 isEmpty() 方法检查是否无元素;数组的空则指引用为 null 或长度为 0。
|
2月前
|
Java
Java快速入门之类、对象、方法
本文简要介绍了Java快速入门中的类、对象和方法。首先,解释了类和对象的概念,类是对象的抽象,对象是类的具体实例。接着,阐述了类的定义和组成,包括属性和行为,并展示了如何创建和使用对象。然后,讨论了成员变量与局部变量的区别,强调了封装的重要性,通过`private`关键字隐藏数据并提供`get/set`方法访问。最后,介绍了构造方法的定义和重载,以及标准类的制作规范,帮助初学者理解如何构建完整的Java类。
|
2月前
|
安全 Java
Object取值转java对象
通过本文的介绍,我们了解了几种将 `Object`类型转换为Java对象的方法,包括强制类型转换、使用 `instanceof`检查类型和泛型方法等。此外,还探讨了在集合、反射和序列化等常见场景中的应用。掌握这些方法和技巧,有助于编写更健壮和类型安全的Java代码。
50 17
|
2月前
|
Java
java代码优化:判断内聚到实体对象中和构造上下文对象传递参数
通过两个常见的java后端实例场景探讨代码优化,代码不是优化出来的,而是设计出来的,我们永远不可能有专门的时间去做代码优化,优化和设计在平时
38 15
|
4月前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
5月前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
88 17
|
4月前
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
5月前
|
存储 Java 数据管理
Java零基础-Java对象详解
【10月更文挑战第7天】Java零基础教学篇,手把手实践教学!
51 6
|
5月前
|
Oracle Java 关系型数据库
重新定义 Java 对象相等性
本文探讨了Java中的对象相等性问题,包括自反性、对称性、传递性和一致性等原则,并通过LaptopCharger类的例子展示了引用相等与内容相等的区别。文章还介绍了如何通过重写`equals`方法和使用`Comparator`接口来实现更复杂的相等度量,以满足特定的业务需求。
54 3
|
5月前
|
存储 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第9天】在Java的世界里,对象序列化是连接数据持久化与网络通信的桥梁。本文将深入探讨Java对象序列化的机制、实践方法及反序列化过程,通过代码示例揭示其背后的原理。从基础概念到高级应用,我们将一步步揭开序列化技术的神秘面纱,让读者能够掌握这一强大工具,以应对数据存储和传输的挑战。

热门文章

最新文章

  • 1
    小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
  • 2
    3天功能开发→3小时:通义灵码2.0+DEEPSEEK实测报告,单元测试生成准确率92%的秘密
  • 3
    Potpie.ai:比Copilot更狠!这个AI直接接管项目代码,自动Debug+测试+开发全搞定
  • 4
    基于FPGA的图像双线性插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
  • 5
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
  • 6
    大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
  • 7
    「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!
  • 8
    用户说 | 通义灵码2.0,跨语言编码+自动生成单元测试+集成DeepSeek模型且免费使用
  • 9
    以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
  • 10
    AxBench:斯坦福大学推出评估语言模型控制方法的基准测试框架