Infrastructure-as-code repo to activate and bootstrap Tezos testnets in a repeatable, automated way.
See teztnets.xyz for the list of active Teztnets.
tezos-k8s is a framework to deploy Tezos nodes or chains using Kubernetes and Helm.
See the tezos-k8s documentation
We support the beacon-compatible Tezos Faucet.
A collection of raw Michelson contracts can be optionally deployed in any Teztnet at genesis.
Upon deployment of a Teztnet, a genesis baker will run and its p2p and rpc endpoints will be exposed externally. Example:
- p2p:
ghostnet.teztnets.xyz
- rpc
rpc.ghostnet.teztnets.xyz
Tezos nodes supports downloading of network specification from a json endpoint: octez-node config init --network https://teztnets.xyz/<TEZTNET NAME>
The Teztnet platform creates and exposes such endpoints.
You are encouraged to build automation to ensure your Tezos project keeps running with the future versions of Tezos shell and/or protocol.
- monitor this repo's
main
branch using your monitoring tool of choice - this endpoint lists the current active testnets: https://teztnets.xyz/teztnets.json
Each Teztnet is defined within a subdirectory of the /networks
directory in this repository. The Teztnet directory must contain the following files:
- A Helm chart
values.yaml
file - Optionally, a Helm chart
faucet_values.yaml
file if deploying a faucet - Optionally, a submodule of tezos-k8s (in case you need an unreleased or custom version of the tezos-k8s software)
The Helm chart values.yaml lets you customize your chain in many ways:
- specify activation parameters, such as:
- list of genesis bakers
- list of accounts funded at genesis
- chains parameters (blocks per cycle, time between blocks...)
- specify user-activated upgrades for hard-forks at a given length
- specify the list of baker/endorser binaries to run.
Look in any Teztnet directory's values.yaml file for reference as to how to configure your own Teztnet.
The default Helm values.yaml has details on every possible way to customize your teztnet.
The website is created with Jekyll from Markdown files generated from Jinja templates based on Pulumi outputs.
To build the website locally, from the top-level dir of the repo:
source .env
to populate the secret env vars- run
pulumi stack output networks > networks.json
- run
pulumi stack output teztnets > teztnets.json
- run
python src/release.py
cd target/release
- run
bundle install
- run
bundle exec jekyll serve
The website will be rendered on localhost:4000
.