Skip to content

A 6-part series on how to use Echidna on real-world codebases

License

Notifications You must be signed in to change notification settings

audityourcontracts/echidna-streaming-series

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Echidna Streaming Workshop

Welcome to the 6-part series on how to use Echidna to fuzz like a pro! This repository has 6 folders, each of which maps to a specific workshop in the series.

To learn more about how these workshops will work, please read this blogpost.

Note that each workshop will be live streamed on Trail of Bits' Twitch channel and YouTube channel at 12 PM EST on the following days:

Beginner

Part 1: The Basics (streaming on Nov 16, 2022)

Part 2: Fuzzing arithmetics and functions (streaming on Nov 22, 2022)

Intermediate

Part 3: Introduction to AMM’s invariants (streaming on Nov 30, 2022)

Part 4: AMM fuzzing (streaming on Dec 6, 2022)

Advanced

Part 5: Introduction to advanced DeFi’s invariants (streaming on Dec 14, 2022)

Part 6: Advanced DeFi invariants (streaming on Dec 21, 2022)

Additional Notes

  • This repository will be migrated to the building-secure-contracts repository at the end of the series. We will update this README when that time comes.
  • This repository will be updated as the series continues. Thus, there might be some incomplete folders / broken links in the process.

Try your own invariants!

ABDK Math

  • Associative property of multiplication – (x * y) * z = x * (y * z)
  • Distributive property of multiplication – x * (y + z) = (x * y) + (x * z)
  • Multiplication of inverses (using the inv function) – inv(x * y) = inv(x) * inv(y)
  • Square roots – sqrt(x) * sqrt(x) = x
  • Logarithms – log2(x * y) = log2(x) * log2(y)
  • Average gavg()
  • Power pow()
  • Natural logarithm – ln()
  • Exponentiation – exp()

Uniswap V2

  • Path independence for swaps
  • Pool invariant always increases
  • LP tokens are minted differently based on existing pool liquidity
  • An LP provider's underlying asset balances are monotonically increasing
  • Path independence for LPs

Echidna Installation

About

A 6-part series on how to use Echidna on real-world codebases

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Solidity 87.7%
  • TypeScript 12.2%
  • JavaScript 0.1%