17、软件开发中的关键理念与实践

软件开发中的关键理念与实践

1. 分离关注点与测试策略

在软件开发中,若能正确分离用户界面(UI)和业务逻辑的关注点,例如通过应用层来处理业务用例,这在速度和功能验证方面都极为有效。我们可以将 UI 测试单独划分成一个测试套件,从而提高测试的粒度。毕竟,UI 显示数据错误与因领域模型功能错误导致数据库中数据错误是截然不同的问题。一个设计良好的系统能为我们的测试策略提供更多选择。

2. 行走骨架(The Walking Skeleton)

行走骨架是系统的一个微小实现,它能执行一个小的端到端功能。它无需采用最终的架构,但应将主要的架构组件连接起来。架构和功能随后可以并行演进。

当从头开始开发时,强烈建议采用这种方法。因为在开发流程完成之前,我们很难获得反馈,特别是在分布式系统中,集成点往往是主要的痛点来源(包括配置错误、访问密钥问题、网络可用性等)。构建系统最薄的端到端切片非常有价值,因为它能迫使我们在时间充裕且代码库几乎为空时,先解决棘手的基础设施问题。

一旦行走骨架能够正常工作,就意味着运行代码和验收测试所需的所有基础设施都已搭建好、成功连接并准备好扩展。

示例需求:混乱的配送办公室

将以下非结构化需求转换为行为驱动开发(BDD)风格的规范。理想情况下,应使用 Given/When/Then 结构的验收标准,并将其纳入自动化套件,以融入持续自动化环境。

预计发货日期服务

创建一个具有 DispatchDate 方法的服务,该方法根据通过网站收集的客户订单 ID,返回其预计发货日期。

订单包含订单日期和客户添加到购物篮中的一系列产

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值