01
背景
在今年的敏捷团队建设中,我通过Suite执行器实现了一键自动化单元测试。Juint除了Suite执行器还有哪些执行器呢?由此我的Runner探索之旅开始了!
随着需求开发迭代、代码库规模逐渐变大、新的团队成员引入等诸多因素,系统起初制定的架构规则不可避免遭到破坏。不仅仅是破坏团队的统一开发规范,更为重要的是随着代码库规模逐渐增长,大大降低系统的可维护性、扩展性,增加评审复杂度和重构成本,也最终导致团队生产力下降以及研发成本增长。
在敏捷开发环境下,系统通过迭代增量的交付价值,系统架构也是如此。团队不可能在项目之初就建立完美的系统架构,系统架构应该随着系统迭代不断演进。
架构演进和架构腐化是看待架构的不同视角:架构腐化着眼于现状,架构演进侧重于未来。
架构腐化不可避免,随着时间流转腐化现象必然发生。而需要做的是:通过某种方式及早发现和修正。
02
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
需要通过引入一种机制或技术,降低或及早发现架构腐化现象的发生,保持统一的系统架构约束。
对于架构规则常见的验证方式:代码评审、代码质量分析工具或平台、Archunit
图1.对于架构规则常见的验证方式
以下对常见的几种方式进行优劣势对比:
代码评审:通过强流程控制代码评审活动发生,增强代码评审的强度和质量
【优势】
【劣势】
代码质量分析工具:比如Sonar、Checkstyle等
【优势】
【劣势】
Archunit:通过单元测试形式对架构规则自动化检查
【优势】
【劣势】
03
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
Archunit是一款免费、简单可扩展的类库,它可以使用任何Java单元测试框架来检查Java代码的架构约束。基于Archunit可以自动化检测:
Archunit和代码质量分析工具的关系如下图所示,二者都可以对代码进行分析,在功能覆盖上存在一定交叉。
图2.Archunit和代码质量分析工具的关系
Archunit不能解决所有的架构属性的约束自动化验证,其主要侧重于系统的演进性、可维护性、可测试性、可解释性等,也可以对耦合度、命名规范等进行验证。
图3.Archunit的验证范围
04
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目
4.1 开始就是如此简单
使用Archunit编写架构规则约束非常简单,其提供了便捷的流式API,可以快速的构建规则。
示例1:RULE.01 所有的枚举类必须以Enum为后缀
图4.RULE.01 所有的枚举类必须以Enum为后缀
示例2:对应用分层进行约束校验
图5.对应用分层进行约束校验
在IDE下执行Archiunit单元测试结果示意如下图所示:
图6.在IDE下执行Archiunit单元测试结果示意
4.2 如何组织架构规则
架构规则组织可以从多个维度,比如:
下图左侧所示:基于逻辑分类对规则进行分组
下图右侧所示:基于职能分类对规则进行分组
图7.左侧:基于逻辑分类进行分组;右侧:基于职能分类进行分组
4.3 团队如何规范化
团队是否要引入Archunit本身也是一项架构决策,建议采用文档化形式对该决策进行记录,记录形式参考《轻量级架构决策记录机制》https://developer.jdcloud.com/article/2646?mid=30
如果团队想要引入Archunit,从流程化和规范化视角可以基于准备-试点-优化-推广的模式进行实施:
图8.准备-试点-优化-推广的模式
实施准备:
应用试点:在产品线内部选定一个试点应用
复盘优化:基于试点效果进行复盘,基于团队成员反馈进行架构规则优化、已有规则的修改及废弃等等
推广普及:基于试点的一些实践在其它应用或业务线进行推广普及
对于遗留系统已经形成了特定的规则(有可能是已经发生腐化),由于业务系统的持续迭代,在单个迭代完全大规模重构已有系统的可能性不大。所以,建议采增量方式,在迭代研发资源可接受的范围内,逐步引入并丰富架构规则,并对破坏规则的应用代码进行重构。
05
结语
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
Archunit不能做什么:
Archunit对架构约束的自动化检测极有价值,且具有较低的接入和定制化成本,强烈建议团队引入试点。引入Archunit进行架构约束自动化检查后,将对以下方面产生影响:
打造SAAS化服务的会员徽章体系,可以作为标准的产品化方案统一对外输出。结合现有平台的通用能力,实现会员行为全路径覆盖,并能结合企业自身业务特点,规划相应的会员精准营销活动,提升会员忠诚度和业务的持续增长。
▪
底层能力:维护用户基础数据、行为数据建模、用户画像分析、精准营销策略的制定
▪功能支撑:会员成长体系、等级计算策略、权益体系、营销底层能力支持
▪用户活跃:会员关怀、用户触达、活跃活动、业务线交叉获客、拉新促活