
本文探讨了在Cucumber测试中跨场景传递变量的技术方法,虽然技术上可行,但从测试设计的角度来看,强烈建议避免这种做法。文章将介绍使用全局变量和Cucumber的Background关键字两种方式来实现跨场景变量共享,并着重强调独立场景的重要性,建议使用Background确保每个场景所需的前提条件都已满足。
在Cucumber中,理想情况下,每个Scenario都应该是独立的,可以独立运行,互不依赖。依赖于其他Scenario执行结果的设计会降低测试的可维护性和可靠性。然而,在某些特定情况下,可能需要在不同的Scenario之间共享变量。以下将介绍两种实现方式,但请务必谨慎使用,并考虑是否可以通过更合理的设计来避免。
使用全局变量
最直接的方法是在Step Definition类中定义一个全局变量。在第一个Scenario中设置该变量的值,然后在后续的Scenario中使用它。
public class MyFeatureClass {
private String folderName = ""; // 全局变量
@When("^I create folder with \"([^\"]*)\" name api$")
public void createFolder(String name) {
// ... (省略RestAssured请求代码) ...
// 假设getJsonPath(response, "uuid")返回文件夹的UUID
folderName = getJsonPath(response, "uuid");
}
@When("^I send create inside the folder with \"([^\"]*)\" name api$")
public void createInsideFolder(String name) {
// 使用全局变量 folderName
String parentFolderUuid = folderName;
// ... (省略RestAssured请求代码,使用parentFolderUuid) ...
}
}注意事项:
- 使用全局变量会引入状态,使得Scenario之间产生耦合。如果Scenario的执行顺序发生变化,或者其中一个Scenario失败,可能会影响其他Scenario的结果。
- 全局变量可能导致难以调试的问题,因为很难追踪变量值的变化。
- 在多线程环境下,使用全局变量需要进行线程安全处理,否则可能出现数据竞争。
使用Cucumber的Background
Cucumber的Background关键字允许定义在每个Scenario执行之前都会执行的步骤。这可以用来设置一些通用的前提条件,例如创建必要的文件夹。
首先,在Feature文件中添加Background:
Feature: 文件和文件夹操作
Background: 创建基础文件夹
Given 我创建名为 "基础文件夹" 的文件夹
Scenario: 在基础文件夹下创建子文件夹
When 我在名为 "基础文件夹" 的文件夹下创建名为 "子文件夹" 的文件夹
Then 验证子文件夹是否创建成功然后,在Step Definition类中实现Background中的步骤:
public class MyFeatureClass {
private String baseFolderUuid = "";
@Given("^我创建名为 \"([^\"]*)\" 的文件夹$")
public void 创建名为的文件夹(String folderName) {
// ... (省略RestAssured请求代码) ...
// 保存基础文件夹的UUID
baseFolderUuid = getJsonPath(response, "uuid");
}
@When("^我在名为 \"([^\"]*)\" 的文件夹下创建名为 \"([^\"]*)\" 的文件夹$")
public void 在名为的文件夹下创建名为的文件夹(String parentFolderName, String subFolderName) {
// 使用baseFolderUuid作为parentFolderUuid
String parentFolderUuid = baseFolderUuid;
// ... (省略RestAssured请求代码,使用parentFolderUuid) ...
}
}优点:
- Background可以确保每个Scenario都从一个已知的状态开始,减少了Scenario之间的依赖性。
- Background可以提高测试的可读性,因为每个Scenario都明确地定义了其前提条件。
缺点:
- Background中的步骤会在每个Scenario之前执行,即使某些Scenario不需要这些步骤。这可能会降低测试的执行效率。
- 仍然使用了全局变量,虽然范围缩小到Feature级别,但仍然存在潜在的风险。
总结
虽然可以使用全局变量或Cucumber的Background关键字在不同的Scenario之间共享变量,但强烈建议避免这种做法。应该尽量设计独立的Scenario,并使用更合理的方式来设置前提条件,例如直接在Scenario中创建必要的资源,或者使用数据库清理脚本来重置测试环境。如果必须共享变量,请务必谨慎使用,并充分考虑其潜在的风险。 优先考虑使用Background,并尽量减少全局变量的使用。 最终目标是创建可靠、可维护且易于理解的Cucumber测试。










