Skip to main content

TUI for running interacting with Foundry's Forge Tests.

Project description

Crucible Logo

Crucible is a terminal UI application wrapper for forge test built with Textual (💖). It provides an interactive environment to navigate your test tree and the trace output of running a test with full verbosity.

Installation

I recommend using pipx, which installes applications distributed via pypi into their own virtual environment.

$ pipx install forge-crucible

This will install the crucible executable.

Running

To run it just navigate to the root of a foundry project and run:

$ crucible

The app should run the full test suite and output a tree representation:

Example Test Suite view

You can navigate the tree via the arrows or vim-style (recommended 🤓). You can also press CTRL+P to bring up the command pallet where you can fuzzy-find tests to run:

Example Search view

Once you pick a test you will see the trace view:

Example Test Trace view

Disclaimer

This is very alpha software so it might not work. It employs a grammer to parse the forge output. I've tried it on a variety of tests but it could still fail when opening a test. If it happens it will create a /tmp/<test-name>.txt file with the output. Please open an issue and attach the output.

Upcoming features

  • Trace filtering: Have a list of customizable filters that can be toggled to hide trace lines from the output. The current filtering feature just filters console.log, VM.label and VM.addr.
  • Trace search: Jump to trace line by fuzzy searching on the function call or event name.
  • Profile switch: Switch the foundry profile that you're using to run the tests, should automatically detect existing profiles.
  • Custom labling: Ability to do in-app labeling of addresses or bytes32 identifiers.
  • External decoding: Use public resources to decode function calls and events which could come up in fork-tests.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

forge_crucible-0.1.23.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

forge_crucible-0.1.23-py3-none-any.whl (25.4 kB view details)

Uploaded Python 3

File details

Details for the file forge_crucible-0.1.23.tar.gz.

File metadata

  • Download URL: forge_crucible-0.1.23.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.6 Darwin/23.5.0

File hashes

Hashes for forge_crucible-0.1.23.tar.gz
Algorithm Hash digest
SHA256 1293e3fdd7289bd2014ec56cf6832d514dd3d44690b8965d6562a6b6a07d2291
MD5 ab5fc7543d1e03d82fa882c2c980d5a2
BLAKE2b-256 d9bec8cc7b4722eb2b5a901d26c328b617b75a29dce7706d9914701255897f0c

See more details on using hashes here.

File details

Details for the file forge_crucible-0.1.23-py3-none-any.whl.

File metadata

  • Download URL: forge_crucible-0.1.23-py3-none-any.whl
  • Upload date:
  • Size: 25.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.6 Darwin/23.5.0

File hashes

Hashes for forge_crucible-0.1.23-py3-none-any.whl
Algorithm Hash digest
SHA256 e95666f280ca94fc5613e4423f0846f3480e24a205699687ef83336393addb18
MD5 66dfc9bfa024e62d457d159b65db6200
BLAKE2b-256 b6a7a70142473db139420eacb705cff7f25f4e7150f5b5dfed6e45e996b67434

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page