This repository contains the formalization of Cedar and infrastructure for performing differential randomized testing (DRT) between the formalization and Rust production implementation available in cedar.
You can learn more about our formalization efforts in the following blog posts:
- How we built Cedar with automated reasoning and differential testing
- Lean Into Verified Software Development
cedar-leancontains the Lean formalization of, and proofs about, Cedar.cedar-drtcontains code for fuzzing, property-based testing, and differential testing of Cedar.cedar-policy-generatorscontains code for generating schemas, entities, policies, and requests using the arbitrary crate.
See the README in each directory for more information.
- Install Lean, following the instructions here.
cd cedar-leansource ../cedar-drt/set_env_vars.sh(only required if running on AL2)lake updatelake build Cedar
The simplest way to build our DRT framework is to use the included Dockerfile:
docker build . -t cedar_drt # ~10 minutes
docker run --rm -it cedar_drtIf you'd rather not use Docker, here are the full instructions for a local build:
- Install Lean, following the instructions above.
- Clone the
cedarrepository in the current (cedar-spec) repository. source cedar-drt/set_env_vars.shcd cedar-lean && ../cedar-drt/build_lean_lib.shcd ../cedar-drt && cargo build
The build has only been tested on Amazon Linux 2.
To run DRT:
- Follow the build instructions above.
- If running locally,
source ./set_env_vars.sh. cargo fuzz run -s none <target>.
List the available fuzz targets with cargo fuzz list.
Available targets are described in the README in the cedar-drt directory.
That README also explains how to debug build failures, and how to save DRT-generated tests.
Additional commands available with cargo fuzz help.
To work with cedar-drt in VSCode, first configure two settings so that the rust analyzer plugin doesn't error when trying to find the Lean installation and so that it works properly in the fuzz crate.
Add the following entries to your .vscode/settings.json. First run source set_env_vars.sh && echo $LEAN_LIB_DIR to get the correct value for LEAN_LIB_DIR.
{
"rust-analyzer.linkedProjects": [
"./cedar-drt/fuzz/Cargo.toml"
],
"rust-analyzer.cargo.extraEnv": {
"LEAN_LIB_DIR": <$LEAN_LIB_DIR as populated by set_env_vars.sh>
}
}See the cedar-lean README for some additional consideration when working with the Lean formalization.
See CONTRIBUTING for more information.
This project is licensed under the Apache-2.0 License.