Tilt#
Tilt is part of the official Docker ecosystem. It's a tool that allows developers to configure a Kubernetes environment for development easily.
Note
Tilt is often referred to as "Devnet" in the Wormhole ecosystem, so any information labeled as "Devnet" also applies to Tilt.
However, in the context of Wormhole, "Tilt" refers to the development environment used by the Wormhole Core repository. This environment stands up Docker images for all the tools necessary to build across multiple blockchains, including:
- All the Wormhole-supported blockchains and ecosystems
- A Guardian node
- Relayers
- Databases, Redis
- Utility front ends
The Tilt environment is designed to provide an entire cross-chain development stack right out of the box.
Is Tilt Right for You?#
Tilt is a good option for developers who need a local development environment and have access to a machine that can handle running it. It is also an excellent option for developers who want to establish a CI testing suite.
- Out-of-the-box support for the many components needed to develop across the heterogeneous blockchain spaces
- Consistent development environment, where contracts deploy deterministically, and everything is already linked up
- Ability to easily enable or disable components as needed
- Regularly updated as new components join the Wormhole ecosystem
- Relatively high system requirements, but this can be mitigated by disabling components
- Most blockchains are "blank slates" with no contracts deployed. Thus, if your contracts have any dependencies, you may have to deploy them yourself or alter the default Tilt configuration
- Spin-up and rebuild times can be slow, which can result in a slow workflow
Tilt Installation#
Tilt functions best in a UNIX-style environment. To run the Tilt environment, make sure you have Tilt and Go installed.
MacOS Instructions#
You'll need to have homebrew
installed on your system. You can install it with:
Install Go:
Install Docker:
After installation, go into Docker settings and switch on kubernetes
. Also configure Docker to have 4 CPUs and about 16GB of RAM.
Install Tilt:
Linux Instructions#
Install Go#
You can install Go with the following command:
wget https://go.dev/dl/go1.18.1.linux-amd64.tar.gz &&
rm -r /usr/local/go && tar -C /usr/local -xzf go1.18.1.linux-amd64.tar.gz
Install Docker Desktop#
If you're using Linux with a windows manager, it's highly recommended that you install Docker Desktop, since it comes with built-in Kubernetes, and you won't need to download Minikube. It's recommended that you allocate Docker at least 4 CPUs and 16GB RAM. Also, make sure you set up Docker as a non-root user. You can refer to this list of Docker installation methods.
If you're using Docker Desktop, you can enable Kubernetes by going into Settings > Kubernetes and checking the checkbox to enable Kubernetes.
Minikube#
The alternative to Docker Desktop with Kubernetes is to install minikube. You can configure Minikube as follows:
minikube start --driver=docker --kubernetes-version=v1.23.3 --cpus=4 --memory=14G --disk-size=10G --namespace=wormhole
If you reboot your VM you'll need to run the minikube start
command again before you bring up Tilt.
Install Tilt#
You can install Tilt with the following command:
Linux Experimental Instructions#
This is an experimental, single-command setup script.
Warning
This is only recommended if you're running headless Linux and unable to use Docker Desktop, as you can enable Kubernetes from Docker.
This experimental single command setup script should install dependencies for you on Linux and configure everything properly. If it doesn't work as expected, refer to the standard Linux installation steps above.
If you've all got prerequisites installed, clone the Wormhole Core Repository and start Tilt.
git clone --branch main https://github.com/wormhole-foundation/wormhole.git &&
cd wormhole &&
tilt up
Virtual Machine Instructions#
If you're running Tilt in a VM, you'll need to pass in some extra flags to enable Tilt to listen to incoming traffic from external addresses:
You can now access the Tilt UI at vm_external_ip:10350
. If the VM's external IP doesn't work, check the firewall and port settings to make sure your VM allows incoming traffic. Be sure to check out the Tiltfile
, which has much of the configuration and arguments for the development environment. It's relatively straightforward to enable and disable components. For example, you can enable blockchains by setting them to true at startup. Note the use of the --
separator between Tilt command flags and the flags you wish to pass to configure the setup.
Using Tilt#
Tilt can be treated as an external environment or Devnet that you can easily spin up and tear down. If you've followed the standard setup, all your resources will be bound to various ports on localhost. To see all the endpoints that are hosted in your Tilt environment, you should check out the Tilt dashboard, located at http://localhost:10350/overview.
All the deployed contract addresses can be found under the Devnet section of the chain being used in the Environments pages. Useful information pertaining to funded wallets and private keys can also be found in the Devnet.md
file of the docs.
Shutting Down Tilt#
To shut down Tilt, run tilt down
with the same network flags provided in the tilt up
command.
FAQ#
Where are Fantom, Celo, Polygon, and Other EVM Chains?#
The smart contract development environment is effectively the same for all chains that support EVM. For changes in gas costs and transaction times, consider testing contract logic on Devnet and then using Testnet environments to get chain-specific answers.
Solana is Taking Forever#
Due to Solana's architecture, building the Solana pod often takes 25-40 minutes. Consider increasing the number of CPU cores assigned to Devnet for a faster build.
Solana Program Deploy Doesn't Work#
Kubernetes doesn't currently allow port forwarding for UDP ports (GitHub Issue), which is what Solana uses for solana program deploy
. Instead, it is recommended to use Solana Deployer. Not only does this deploy programs over regular RPC (thus bypassing UDP port requirements), but it's also much faster than Solana program deploy.
How Do I Reset State For a Pod?#
If you want to iterate quickly and don't want to bring Tilt down and back up, you can reset a pod's state by clicking the refresh button next to the pod name in the Tilt UI.
Contracts and Accounts#
The Devnet environment deploys the core layer and Token Bridge to each chain at the same addresses every time. It also provides funds to specific wallets.
Default Ports#
Service | Port |
---|---|
Guardian REST | 7071 |
Guardian gRPC Port | 7070 |
Eth0 RPC | 8545 |
Eth1 RPC | 8546 |
Solana RPC | 8899 |