|
此版本仍在开发中,尚未被视为稳定版。如需最新稳定版本,请使用 Spring Modulith 2.0.4! |
验证应用程序模块结构
我们可以通过在 ApplicationModules 实例上调用 ….verify() 方法,来验证我们的代码安排是否符合预期的约束:
-
Java
-
Kotlin
ApplicationModules.of(Application.class).verify();
ApplicationModules.of(Application::class.java).verify()
验证包括以下规则:
Spring Modulith 可选择性地与 jMolecules ArchUnit 库集成,如果存在该库,将自动触发其领域驱动设计(DDD)和架构验证规则,相关描述见此处。
处理检测到的违规行为
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 | 使用刚刚配置的选项执行验证。 |