Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/taxmeifyoucan/ephemeral-testnet
Resources and project management of Ethereum ephemeral testnet
https://github.com/taxmeifyoucan/ephemeral-testnet
Last synced: about 1 month ago
JSON representation
Resources and project management of Ethereum ephemeral testnet
- Host: GitHub
- URL: https://github.com/taxmeifyoucan/ephemeral-testnet
- Owner: taxmeifyoucan
- Created: 2022-11-22T14:07:44.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2023-07-26T13:03:03.000Z (over 1 year ago)
- Last Synced: 2024-10-04T12:55:14.698Z (3 months ago)
- Size: 324 KB
- Stars: 26
- Watchers: 7
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Ephemeral Testnet
**Ephemery is supporting Shapella since iteration 60. Make sure to run Shapella compatible [version of your client](https://blog.ethereum.org/2023/03/28/shapella-mainnet-announcement).**
The objective of this effort is to create the first automatically reset ephemeral Ethereum testnet which would serve as a cross-client testing network without issues stemming from a long-term running history.
## Proposal
An ephemeral testnet is a single network that rolls back to the genesis after a set period of time. This kind of network is focused on short term and heavy testing usecases. The purpose of this is also to avoid problems like insufficient testnet funds, inactive validators, state bloat, and similar issues faced by long-running testnets.
Learn more about the idea in the [original proposal](https://notes.ethereum.org/@mario-havel/stakers-testnet) and [specification](/specs.md).
## Meta, network info
| | Current value |
| ---------------- | ------------------- |
| Network ID | ![ChainId](https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fephemery.dev%2FlatestInfo.php&query=%24.chainid&label=%20&color=gray) |
| Iteration number | ![Iteration](https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fephemery.dev%2FlatestInfo.php&query=%24.iteration&label=%20&color=gray) |
| Rollback period | 7 days |
| Next rollback | ![Dynamic JSON Badge](https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fephemery.dev%2FlatestInfo.php&query=%24.resetTimeReadable&label=%20&color=gray) |### Landing page
https://ephemery.dev/ (add RPC with single click)
### RPC providers
- https://rpc.bordel.wtf/test (geth)
- https://otter.bordel.wtf/erigon
- https://eth.ephemeral.zeus.fyi (lighthouse-geth, full beacon)### Faucets
- https://faucet.bordel.wtf/
- https://ephemery-faucet.pk910.de/### Block explorers
- https://otter.bordel.wtf/
- https://explorer.ephemery.dev/### Beacon explorers
- https://beaconchain.ephemery.dev/
- https://ephemery.info/
- https://checkpointz.bordel.wtf/ (Checkpoint sync)### Validators
- [Launchpad](https://ephemery.launchpad.remyroy.com/en/)
- https://github.com/remyroy/staking-deposit-cli/releases/tag/v2.3.0.ephemery CLI## Resources and contributing
The network is currently in its early stages, it runs as a small network with a manual reset mechanism. Each reset changes network parameters and requires a new genesis. Setup and reset mechanism is coordinated via [this repository](https://github.com/ephemery-testnet/ephemery-genesis). Each release contains values for the new release.
To run a node and participate in the network, use setup from [this repository](https://github.com/ephemery-testnet/ephemery-scripts). There are various deployment options, you can either use a [Docker setup](https://github.com/ephemery-testnet/ephemery-scripts#docker), cloud-init script or manually modify the `retention.sh` script to suit your system and run it as a cron job. There are also [instructions for manually setting up a node](https://github.com/ephemery-testnet/ephemery-scripts#manual-deployment).
Checkout [current version of specs](./specs.md) for client implementation and feel free to provide feedback.
### Contribute
Contribute by participating in the network and identifying issues caused by the ephemeral setup. You can help a lot by testing features and infrastracture which might break during the reset. Here are few ideas for general testing:
- Run a node, especially client which is not tested yet
- Add validators, monitor attestations, proposed blocks, slashing issues
- Use your wallet, find out how it behaves after the reset, how it handles different network ID from same RPC
- Deploy dapps, try your favorite developer tooling
- Run infrastracture, explorers, etc
- Reach out with your own ideas for testingFeel free to open issue in this repository with your findings and ideas. And feel free to join the discussion in [Matrix room](https://matrix.to/#/#staker-testnet:matrix.org).
## Roadmap
Ephemeral testnet needs a lot of research and development to be stable and widely usable. Here is a simple roadmap and current progress:
- [x] Proposal and initial discussion
- [x] Private network with manual reset mechanism
- Using external script to reset the network
- A small private chain was created to identify feasibility issues and to stabilize the devops setup.
- [x] Public network with manual reset mechanism
- Stable network open to the public and wider debugging, simplifing node/validator setup
- [x] Creating general specifications for automatically reset ephemeral testnet
- Discussion about implementation details and specifications based on data gathered from the network with manual resets
- [Specs draft](./specs.md)
- [x] [Draft EIP](https://github.com/ethereum/EIPs/pull/6916)
- [ ] Automatic onchain infrastracture
- [x] Refuding validators
- [ ] Deploying primitives for dapps
- [ ] Preliminary client implementation work
- Single client pair, testing on private/public chain
- Improving and finishing specs
- [ ] Cross client implementation
- Testing all client combos, ACD discussion![](./bttg.png)