验证应用程序模块结构
我们可以通过调用 ApplicationModules 实例上的 ….verify() 方法来验证我们的代码结构是否符合预期约束
-
Java
-
Kotlin
ApplicationModules.of(Application.class).verify();
ApplicationModules.of(Application::class.java).verify()
验证包括以下规则
Spring Modulith 可选地与 jMolecules ArchUnit 库集成,如果存在,则自动触发此处描述的领域驱动设计和架构验证规则。
处理检测到的违规
如果检测到任何架构违规,ApplicationModules.verify() 将抛出异常。您可以通过调用 ApplicationModules.detectViolations() 来访问这些违规以便进一步处理,例如忽略某些违规。
ApplicationModules.of(…)
.detectViolations()
.filter(violation -> …)
.throwIfPresent();
自定义验证
如上文所述,默认情况下,ApplicationModules.verify(…) 和 ….detectViolations(…) 都会根据类路径配置自动执行额外的验证。
要自定义、禁用或注册额外的验证,verify(…) 和 detectVolations(…) 都接受一个 VerificationOptions 实例。
var hexagonal = JMoleculesArchitectureRules.ensureHexagonal(VerificationDepth.STRICT); (1)
var options = VerificationOptions.defaults().withAdditionalVerifications(hexagonal); (2)
ApplicationModules.of(…).verify(options); (3)
| 1 | 在严格模式下为六边形架构设置 jMolecules 架构验证。 |
| 2 | 创建一个 VerificationOptions 实例,用刚刚设置的验证替换默认验证。 |
| 3 | 使用刚刚配置的选项执行验证。 |