interface-contract-verifier
SKILL.md
Interface Contract Verifier
Overview
Verify that formal or structured contracts (preconditions, postconditions, invariants) defined in interfaces and classes are preserved when updating to a new program version.
Core Workflow
1. Extract Contracts
Extract contracts from both versions:
python scripts/contract_extractor.py --program old_version --output old_contracts.json
python scripts/contract_extractor.py --program new_version --output new_contracts.json
2. Verify Contracts
Compare and verify contract preservation:
python scripts/contract_verifier.py --old old_contracts.json --new new_contracts.json --output report.json
3. Review Violations
Examine violations: weakened preconditions, strengthened postconditions, broken invariants.
Contract Types
Preconditions
Requirements before method execution:
def withdraw(amount):
"""Precondition: amount > 0 and amount <= balance"""
Postconditions
Guarantees after method execution:
def deposit(amount):
"""Postcondition: balance == old(balance) + amount"""
Invariants
Properties always true for a class:
class BankAccount:
"""Invariant: balance >= 0"""
Verification Rules
Liskov Substitution Principle:
- Preconditions can be weakened (accept more)
- Postconditions can be strengthened (guarantee more)
- Invariants must be maintained
Violation Types
Strengthened Precondition (Error)
New version rejects previously valid inputs.
Weakened Postcondition (Error)
New version guarantees less.
Broken Invariant (Critical)
Class invariant no longer holds.
Resolution Guidance
Fix Strengthened Precondition
Relax precondition or update callers.
Fix Weakened Postcondition
Strengthen implementation to meet original guarantee.
Fix Broken Invariant
Add checks to maintain invariant in all methods.
Resources
- references/design_by_contract.md: Design by Contract principles
- scripts/contract_extractor.py: Extract contracts from code
- scripts/contract_verifier.py: Verify contract preservation
Weekly Installs
1
Repository
arabelatso/skills-4-seGitHub Stars
47
First Seen
13 days ago
Security Audits
Installed on
amp1
cline1
opencode1
cursor1
kimi-cli1
codex1