在 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 测试中出现错误的可能性。通过将此库添加到您的项目中,您可以简化步骤定义,并将更多精力放在编写有意义的测试而不是样板代码上。


目录
相关文章
|
3天前
|
Java
java代码优化:判断内聚到实体对象中和构造上下文对象传递参数
通过两个常见的java后端实例场景探讨代码优化,代码不是优化出来的,而是设计出来的,我们永远不可能有专门的时间去做代码优化,优化和设计在平时
22 15
|
2月前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
3月前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
68 17
|
2月前
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
3月前
|
存储 Java 数据管理
Java零基础-Java对象详解
【10月更文挑战第7天】Java零基础教学篇,手把手实践教学!
40 6
|
3月前
|
Oracle Java 关系型数据库
重新定义 Java 对象相等性
本文探讨了Java中的对象相等性问题,包括自反性、对称性、传递性和一致性等原则,并通过LaptopCharger类的例子展示了引用相等与内容相等的区别。文章还介绍了如何通过重写`equals`方法和使用`Comparator`接口来实现更复杂的相等度量,以满足特定的业务需求。
36 3
|
3月前
|
存储 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第9天】在Java的世界里,对象序列化是连接数据持久化与网络通信的桥梁。本文将深入探讨Java对象序列化的机制、实践方法及反序列化过程,通过代码示例揭示其背后的原理。从基础概念到高级应用,我们将一步步揭开序列化技术的神秘面纱,让读者能够掌握这一强大工具,以应对数据存储和传输的挑战。
|
3月前
|
存储 Java 数据管理
Java零基础-Java对象详解
【10月更文挑战第3天】Java零基础教学篇,手把手实践教学!
45 1
|
3月前
|
Java 数据安全/隐私保护
java类和对象
java类和对象
31 5
|
3月前
|
Java 编译器 C语言
【一步一步了解Java系列】:类与对象的联系
【一步一步了解Java系列】:类与对象的联系
27 4