采用BDD原则在Jetpack Compose进行 UI Test

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
云数据库 Tair(兼容Redis),内存型 2GB
简介: BDD(行为驱动开发)是一种以用户角度定义系统行为的软件开发方法论,与现代UI测试需求高度契合。通过使用如`@Given`、`@When`、`@Then`等注解,可提升测试逻辑的可读性与维护性。虽然Jetpack Compose未直接支持这些注解,但可通过命名约定和结构设计模拟实现BDD风格的UI测试,从而增强团队协作、提升测试效率。示例展示了如何在Kotlin中结合JUnit与Compose测试规则编写可读性强的测试用例。

随着界面复杂度的增加,有效的测试策略真的很重要,BDD是一种软件开发方法论,强调从用户角度定义系统的行为,和现代UI Test的需求高度契合。

BDD风格的UI测试框架

首先需要了解基本概念:

  • @Given: 描述Test的前提条件。
  • @When: 表示用户执行的操作。
  • @Then: 验证操作的结果是否符合预期。
  • @After: 用于清理测试环境或资源,可以保证每个Test 都是独立且可重复。

建议要使用createComposeRule()提供的Rule,允许Junit Test 环境中Using Composable函数。

代码语言:kotlin

AI代码解释

import androidx.compose.ui.test.junit4.createComposeRule
import org.junit.Rule
import org.junit.Test
class Test {
    @get:Rule
    val composeTestRule = createComposeRule()
    // Test code...
}

1. 使用BDD风格编写测试案例

如果要为一个简单的按钮编写BDD风格的测试案例,这个按钮点击后会改变文本内容。

定义可组合函数

代码语言:kt

AI代码解释

@Composable
fun ToggleTextButton(onToggle: () -> Unit) {
    var buttonText by remember { mutableStateOf("Text") }
    Button(onClick = {
        buttonText = if (buttonText == "Text") "Toggled Text" else "Initial Text"
        onToggle()
    }) {
        Text(text = buttonText)
    }
}
2. 编写BDD风格的测试案例

实际注解不存在 Jetpack Compose的测试lib中,但可以通过命名约定模仿它们。

代码语言:kt

AI代码解释

@Test
fun toggleButtonText() {
    // Given: 设置初始状态
    var toggled = false
    composeTestRule.setContent {
        ToggleTextButton { toggled = !toggled }
    }
    // When: 用户点击按钮
    composeTestRule.onNodeWithText("Initial Text").performClick()
    // Then: 验证文本已更改
    composeTestRule.onNodeWithText("Toggled Text").assertIsDisplayed()
    // After: 清理步骤里实现..
}

模拟@Given, @When, @Then, @After

或者只是遵循命名约定来达到类似的效果,例如:

代码语言:kt

AI代码解释

// 自定义注解
annotation class Given
annotation class When
annotation class Then
annotation class After
@Test
fun `Toggle button text with custom annotations`() {
    @Given fun setupInitialState() {
        // 初始状态
    }
    @When fun performUserAction() {
        // 用户动作
    }
    @Then fun checkOutcome() {
        // 验证结果
    }
    @After fun tearDown() {
        // 清理资源
    }
}

总结

虽然 Jetpack Compose没有直接支持像@Given@When@Then这样的注解,但是通过合理的命名约定和测试结构设计,有效应用BDD 原则指导我们的UI测试开发过程。为什么这样做?因此提高了测试代码的可读性,促进了团队成员之间的沟通与协作,确保了软件功能按照预期工作。

请注意,在实践中,可能不需要创建真正的注解,而是通过良好的测试方法命名和结构化测试逻辑体现BDD理念。这种方法能够帮助Developer 和QA更好理解和维护测试代码。

然而这里只展示了简化的例子,实际项目中的测试可能会更加复杂,包括更多的前置条件、交互步骤以及断言。此外,利用工具如 Cucumber 等可以进一步增强BDD流程的正式性和自动化程度。

相关文章
|
3月前
|
人工智能 安全 Nacos
Nacos 3.0:微服务与AI融合的技术新纪元
Nacos 3.0:微服务与AI融合的技术新纪元
260 83
|
2月前
|
Ubuntu Linux 索引
Centos 7、Debian及Ubuntu系统中安装和验证tree命令的指南。
通过上述步骤,我们可以在CentOS 7、Debian和Ubuntu系统中安装并验证 `tree`命令。在命令行界面中执行安装命令,然后通过版本检查确认安装成功。这保证了在多个平台上 `tree`命令的一致性和可用性,使得用户无论在哪种Linux发行版上都能使用此工具浏览目录结构。
282 78
|
2月前
|
人工智能 JSON 编译器
Code和Clang配置C++开发环境
本文介绍了如何在VS Code中配置C++开发环境,包括安装VS Code、C++扩展、Clang编译器,创建并运行Hello World项目,使用IntelliSense、调试程序及自定义配置等内容,帮助开发者快速上手C++开发。
264 0
|
2月前
|
JSON 人工智能 API
工具演变 & MCP基础
本内容介绍了大模型工具调用方式的演进历程,从早期的函数表达阶段到OpenAI的标准化工具定义,再到结构化推理的引入。同时深入解析了MCP(Model Context Protocol)的核心价值,即通过统一协议降低Agent与工具服务集成的工程复杂度,提升工具调用的标准化与效率。
121 0
|
2月前
|
机器学习/深度学习 数据采集 人工智能
实战FastText构建中文
FastText是由Tomas Mikolov团队于2016年推出的高效文本分类与词向量训练工具,作为Word2Vec的优化版本,其具备以下优势:训练速度快,比传统深度学习模型快多个数量级;支持大规模数据,可处理数十亿词汇;内置n-gram特征处理,简化文本预处理流程;资源消耗低,适合普通硬件运行。本文通过点评数据的二分类任务,展示了从数据下载、清洗、模型训练到评估的完整实践流程,验证了FastText在中文意图分类中的高效性与实用性。
174 0
|
8月前
|
分布式计算 并行计算 调度
基于HPC场景的集群任务调度系统LSF/SGE/Slurm/PBS
在HPC场景中,集群任务调度系统是资源管理和作业调度的核心工具。LSF、SGE、Slurm和PBS是主流调度系统。LSF适合大规模企业级集群,提供高可靠性和混合云支持;SGE为经典开源系统,适用于中小规模集群;Slurm成为HPC领域事实标准,支持多架构和容器化;PBS兼具商业和开源版本,擅长拓扑感知调度。选型建议:超大规模科研用Slurm,企业生产环境用LSF/PBS Pro,混合云需求选LSF/PBS Pro,传统小型集群用SGE/Slurm。当前趋势显示Slurm在TOP500系统中占比超60%,而商业系统在金融、制造等领域保持优势。
1413 32
|
8月前
|
存储 人工智能 搜索推荐
阿里云佘俊泉:边缘云场景的探索与机遇
阿里云佘俊泉:边缘云场景的探索与机遇
249 0
|
11月前
|
移动开发 定位技术 iOS开发
HTML5 Geolocation(地理定位)3
本页介绍如何在地图上显示用户位置,并利用地理定位获取给定位置的详细信息,包括更新本地信息、显示周边兴趣点及实现车载导航。通过 `getCurrentPosition()` 方法可获取用户当前位置的详细数据,如经纬度、精度等。`watchPosition()` 方法则持续跟踪用户位置变化,适用于实时导航。示例代码展示了如何使用这些方法获取并显示位置信息。
|
11月前
|
消息中间件 存储 测试技术
流量回放的数据隔离
流量回放的数据隔离
318 4
|
SQL 安全 Java
Spring Boot中的跨站点脚本攻击(XSS)与SQL注入防护
【6月更文挑战第15天】在现代Web应用程序开发中,安全性是一个至关重要的课题。跨站点脚本攻击(XSS)和SQL注入是最常见的两种攻击类型,它们可以严重威胁到应用程序的安全。
899 0