系统组件测试与属性基测试全解析
1. 事件处理器的特性与测试要点
事件处理器具备分区处理能力,当处理事件失败时,仅需停止对应分区,而非整个处理器。不过,有人可能倾向于将命令处理与事件实例化耦合为一个工作单元,但这种做法可能是为适应开发习惯而改变系统架构,且对视图存储失败时的处理行为并无改善。实际上,测试能充分降低编程错误带来的风险,同时可通过快速构建和持续交付及时将代码变更投入生产,此过程耗时可作为与业务方探讨系统可用性目标的起点。当事件处理器因编程错误无法处理事件时,不影响系统处理读请求,这体现了系统的弹性。
事件处理器具有确定性,给定输入事件通常应执行相同操作,但从多个输入分区消费事件时,操作可能不同。测试事件处理器对事件的处理,常作为整个系统测试的一部分,需查询有状态视图,这与针对该视图的GraphQL查询和订阅测试相关。有状态视图模型可用于检查命令处理器的结果,若存储该视图的系统支持声明式约束,可利用其能力交叉检查唯一约束和外键关系,若处理事件违反约束,问题可能出在命令处理器。
事件处理器自身也应进行隔离测试,使用与业务领域无关且简单的事件集编写测试,这有助于模拟失败情况,如状态视图存储失败和软处理程序超时等。
2. 系统关键组件概述
系统的关键组件包括命令处理器、命令生成器和事件处理器。各组件的隔离测试能增强对组件本身的信心,但要确保整个系统的可靠性,还需进行端到端测试。
- 命令处理器 :负责维护一类业务规则,接收改变系统状态的命令。提供的突变器函数根据命令和当前系统状态生成描述命令变更的事件集,应用器函数根据事件和系统状态返回包含变更的新状态实例。突变器和应用器为纯函数,状态
系统组件测试与属性基测试解析
超级会员免费看
订阅专栏 解锁全文
2661

被折叠的 条评论
为什么被折叠?



