Set a boundary between trusted and verified for RabbitMQ controller #414
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
After this PR our rabbitmq controller example consists of four folders:
trusted
: all the trusted code, including the top-level theorems and unverified wrapper object (like vstd::Vec).exec
: the executable code that is verified.model
: the ghost version of the executable code. This is not trusted.proof
: the proof for liveness (and safety).Notably, files in
trusted
only import other files fromtrusted
or Anvil's trusted specs---they don't import anything fromexec
,model
, orproof
. Everything outsidetrusted
is verified---they don't have anyexternal
orexternal_body
proof functions.After this refactoring, the liveness theorem inside
trusted
now takes a Maker trait as a placeholder for the sub-resource objects created by the controller implementation:And our liveness proof inside
proof
instantiates this theorem with the concrete makerRabbitmqMaker
and proves it:Maker
trait is defined insidetrusted
andRabbitmqMaker
(which implementsMaker
) is not intrusted
.