- Detect cyclic dependencies level wise or module wise
- Prohibit parent access
- Define layer relationships like
MayNotAccess
,MayOnlyAccess
,MyNotBeAccessedBy
,MayOnlyBeAccessedBy
- And more, please consult the documentation.
You can install it either as sub command of Cargo or as a package in your developer dependencies.
# Sub command
cargo install cargo-archtest --force
# Package
[dev-dependencies]
arch_test_core = "*"
Define in the cargo root path a file called architecture.json
. Fill it according to the Specification
struct.
Example:
{
"layer_names": ["analyzer", "parser", "domain_values", "entities", "materials", "services", "tests", "utils"],
"access_rules": [
"NoLayerCyclicDependencies",
"NoModuleCyclicDependencies",
"NoParentAccess",
{
"MayNotAccess": {
"accessor": "parser",
"accessed": ["analyzer"],
"when_same_parent": true
}
},
{
"MayOnlyBeAccessedBy": {
"accessors": ["services", "tests"],
"accessed": "materials",
"when_same_parent": false
}
},
{
"MayNotBeAccessedBy": {
"accessors": ["materials", "domain_values", "entities", "utils"],
"accessed": "services",
"when_same_parent": true
}
}
]
}
You can use the Architecture
struct in order to define your architecture.
Afterwards you check it for failures.
let architecture = Architecture::new(hash_set!["analyzer".to_owned(), "parser".to_owned(), ...])
.with_access_rule(NoParentAccess)
.with_access_rule(NoModuleCyclicDependencies)
.with_access_rule(NoLayerCyclicDependencies)
...
.with_access_rule(MayNotAccess::new(
"materials".to_owned(),
hash_set!["tests".to_owned()],
true,
));
let module_tree = ModuleTree::new("src/lib.rs");
assert!(architecture.validate_access_rules().is_ok());
assert!(architecture.check_access_rules(&module_tree).is_ok());
If you are interested in the failure you can pretty print it like this:
architecture.check_access_rules(&module_tree).err().unwrap().print(module_tree.tree());
You can use it in continuous integration by using either methods. If you decide to use the Cargo sub command on GitHub, the following snippet will allow you to test your project.
arch_test:
name: ArchTest
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions-rs/[email protected]
with:
crate: cargo-archtest
version: latest
- run: cargo archtest