How to configure the local validator with Bitcoin Testnet4

This guide is intended for those wishing to view logs from their programs while benefitting from being connected to Bitcoin testnet4 and therefore gaining access to ordinals/runes helper tools.

Table of Contents:

Config

First, edit the arch-cli configuration file and insert the following details into the testnet section.

arch-cli config edit

Note: We have redacted our Bitcoin node password to prevent abuse; contact us if you need this, otherwise provide your own node credentials and use the below as a reference.

Your arch-cli configuration file should resemble something like the following, with the leader_rpc_endpoint being the endpoint for reaching your Local validator, which defaults to port 9002.

[networks.testnet]
type = "testnet"
bitcoin_rpc_endpoint = "bitcoin-node.test.aws.archnetwork.xyz"
bitcoin_rpc_port = "49332"
bitcoin_rpc_user = "bitcoin"
bitcoin_rpc_password = "redacted"
bitcoin_rpc_wallet = "testwallet"
leader_rpc_endpoint = "http://localhost:9002"

Local validator

Note: the arch-cli (and Docker) can be used to run the local validator.

Additionally, if you do not already have the local validator installed, please pull it from the arch-node releases page.

Be sure to download the local variant, not the regular validator.

Run the local validator

Use the arch-cli command to run the local validator. You'll need to have Docker installed and running.

arch-cli validator start

The validator logs can be viewed easily within the Docker desktop dashboard.

Note: You can also run the standalone local validator binary where the logs will be streamed to stdout unless otherwise redirected.

Steps for running standalone validator binary:

  1. Download the appropriate binary as well as the system_program.so file from arch-node releases page.

  2. Store the system_program.so file within a new directory called /ebpf.

    Your directory structure should resemble the following:

    tmp/
    ├─ ebpf/
    │  ├─ system_program.so
    ├─ local_validator
    
  3. Run the binary and pass the relevant flags dependening on your target network.

    RUST_LOG=info \
    ./local_validator \
    --network-mode testnet \
    --rpc-bind-ip 127.0.0.1 \
    --rpc-bind-port 9002 \
    --bitcoin-rpc-endpoint bitcoin-node.test.aws.archnetwork.xyz \
    --bitcoin-rpc-port 49332 \
    --bitcoin-rpc-username bitcoin \
    --bitcoin-rpc-password redacted
    

Help commands

This section includes some helpful material when needing to restart the node state or better ensure our infrastructure is operational before proceeding.

Arch node

The below commands can be used to assist with running the Local validator.

Start fresh

By removing the /.arch_data directory, we can wipe the state and effective start the node again from genesis (block: 0).

rm -rf .arch_data && RUST_LOG=info \
./local_validator \
...
Pulse check

This cURL command will allow us to ensure that our Local validator is up and running correctly. We can use this to effective get a pulse check on the node which is helpful for debugging.

curl -vL POST -H 'Content-Type: application/json' -d '
{
    "jsonrpc":"2.0",
    "id":1,
    "method":"is_node_ready",
    "params":[]
}' \
http://localhost:9002/

Log assistance

Ordinarily, the arch-node logs will flood your terminal screen (or the Docker logs). This is less than idea when needing to review them carefully, so you can also direct the stdout to a file for later reading.

Here's an example of how to do this:

rm -rf .arch_data && RUST_LOG=info \
./local_validator \
--network-mode testnet \
--rpc-bind-ip 127.0.0.1 \
--rpc-bind-port 9002 \
--bitcoin-rpc-endpoint bitcoin-node.test.aws.archnetwork.xyz \
--bitcoin-rpc-port 49332 \
--bitcoin-rpc-username bitcoin \
--bitcoin-rpc-password redacted \
> node-logs.txt

Then you can tail the output and view the logs as they stream in.

tail -f node-logs.txt

Deploy + interact

Now that everything is setup correctly, we can now deploy our program and begin interacting with it. The deploy step will prove everything works correctly.

arch-cli deploy --network testnet

And if you are running the local validator binary directly from the command-line, set the --rpc-endpoint flag so it overwrites the leader_rpc_endpoint in the arch-cli config if this information was not changed:

arch-cli deploy --network testnet --rpc-url http://localhost:9002

We hope this guide has been helpful, but as always, feel free to ask question within our Discord dev-chat or submit issues within out public-issues repo.