Skip to content

Quicksilver Testnet Instructions and Config

Notifications You must be signed in to change notification settings

sohalefarhadi/testnets

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 

Repository files navigation

Freddie Mercury

Rhapsody Testnet

The Rhapsody testnet is named for the hit song "Bohemian Rhapsody" written by Freddie Mercury, for his band Queen, back in 1975. For inspiration whilst joining this testnet, please feel free to listen to this in the background: Bohemian Rhapsody on YouTube.

All Quicksilver testnets shall be named after songs by Freddie Mercury and/or Queen, for no reason more than the guy was a lyrical and musical genius, and there is a somewhat tenuous link between Quicksilver -> Mercury -> Freddie that is ripe for exploitation.

We have added a bunch of scripts to aid your journey; you'll need make, bash, git, jq, gcc and go (v1.17) installed, along with some additional dependencies that will depend on your OS (e.g. stdlibc++).

Additional tasks will be added during the coming days.

If you experience any bugs, issues or problems, please raise an issue here: https://github.com/ingenuity-build/quicksilver

Details

Hardware Requirements

Like any Cosmos-SDK chain, the hardware requirements are pretty modest.

  • 4x CPUs; the faster clock speed the better
  • 8GB RAM
  • 40GB Disk (we are using statesync, so disk requirements are low)
  • Permanent Internet connection (traffic will be minimal during testnet; 10Mbps will be plenty - for production at least 100Mbps is expected)

Nodes

We are running the following nodes:

  • node01.quicktest-1.quicksilver.zone:26657
  • node02.quicktest-1.quicksilver.zone:26657
  • node03.quicktest-1.quicksilver.zone:26657
  • node04.quicktest-1.quicksilver.zone:26657

Seeds:

Semi-automated Configuration

## clone this repo
git clone https://github.com/ingenuity-build/testnets ## this repo
cd testnets/rhapsody

## download and build quicksilverd and gaiad
make init

## show keys
make keys

## follow instructions listed to get funds from the faucet via discord

## check balances
make balances

## start the validator
make start

## view the logs
make logs

## submit a create-validator tx to start validating (enter your validator name when prompted)
make validate 

---

## clean up time! (post-testnet)
make stop 

make clean

What am I doing wrong?!

Unfunded account

joe@desktop:~/code/testnets/rhapsody$ make validate
Enter your validator name: my_validator
Error: rpc error: code = NotFound desc = rpc error: code = NotFound desc = account quick1fk9qtycszzk32c3hk8xwjwvkhmkc8rv6gg0xzd not found: key not found

Solution: Use discord #qck-tap channel to fund your address (might take a few seconds to come through!)

Node not running

joe@desktop:~/code/testnets/rhapsody$ make validate
Enter your validator name: my_validator
Error: post failed: Post "http://localhost:26657": dial tcp 127.0.0.1:26657: connect: connection refused
...

Solution: Your node is not running; run make start. If problems persist, take a look at make logs and come find someone on discord!

Manual Configuration

Download and build Quicksilver:

git clone https://github.com/ingenuity-build/quicksilver.git --branch v0.1.10
cd quicksilver
make build

Testnet configuration script (touch scripts/testnet_conf.sh):

#!/bin/bash -i

set -xe

### CONFIGURATION ###

CHAIN_ID=quicktest-3

GENESIS_URL="https://raw.githubusercontent.com/ingenuity-build/testnets/main/rhapsody/genesis.json"
SEEDS="dd3460ec11f78b4a7c4336f22a356fe00805ab64@seed.quicktest-1.quicksilver.zone:26656"

BINARY=./build/quicksilverd
NODE_HOME=$HOME/.quicksilverd

# SET this value for your node:
NODE_MONIKER="Your_Node"

### STATE SYNC ###
# To sync the chain on v0.1.10, you _will_ need to use statesync. See testnets/rhapsody/quicksilver.sh for more information.

# if you set this to true, please have TRUST HEIGHT and TRUST HASH and RPC configured
export STATE_SYNC=false
# set height
export TRUST_HEIGHT=
# set hash
export TRUST_HASH=""
export SYNC_RPC="http://node02.quicktest-1.quicksilver.zone:26657,http://node03.quicktest-1.quicksilver.zone:26657,http://node04.quicktest-1.quicksilver.zone:26657"

echo  "Initializing $CHAIN_ID..."
$BINARY config chain-id $CHAIN_ID --home $NODE_HOME
$BINARY config keyring-backend test --home $NODE_HOME
$BINARY config broadcast-mode block --home $NODE_HOME
$BINARY init $NODE_MONIKER --chain-id $CHAIN_ID --home $NODE_HOME

echo "Get genesis file..."
curl -sSL $GENESIS_URL > $NODE_HOME/config/genesis.json

if  $STATE_SYNC; then
    echo  "Enabling state sync..."
    sed -i -e '/enable =/ s/= .*/= true/'  $NODE_HOME/config/config.toml
    sed -i -e "/trust_height =/ s/= .*/= $TRUST_HEIGHT/"  $NODE_HOME/config/config.toml
    sed -i -e "/trust_hash =/ s/= .*/= \"$TRUST_HASH\"/"  $NODE_HOME/config/config.toml
    sed -i -e "/rpc_servers =/ s/= .*/= \"$SYNC_RPC\"/"  $NODE_HOME/config/config.toml
else
    echo  "Disabling state sync..."
fi

echo "Set seeds..."
sed -i -e "/seeds =/ s/= .*/= \"$SEEDS\"/"  $NODE_HOME/config/config.toml

Run this script from the quicksilver repository main directory;

Remember to make it executable:

chmod +x scripts/testnet_conf.sh

Then simply run:

./scripts/testnet_conf.sh

Running your node

At this point you can run the node on the CLI with ./build/quicksilverd start to ensure everything is configured correctly. At this point you may configure your system to run Quicksilver as a system service or daemon.

Upgrade to Validator

Test Wallet

To run as a validator you will need to create a QCK wallet:

./build/quicksilverd keys add $YOUR_TEST_WALLET --keyring-backend=test

If you already have a test wallet you want to use run (and enter your mnemonic):

./build/quicksilverd keys add $YOUR_TEST_WALLET --recover --keyring-backend=test

Faucet

Join our discord server to access the faucets for QCK and ATOM. Make sure you are in the appropriate channel:

  • qck-tap for QCK tokens;
  • atom-tap for ATOM tokens;

To check the faucet address:

$faucet_address rhapsody

To check your balance:

$balance $YOUR_TEST_WALLET rhapsody

To request a faucet grant:

$request $YOUR_TEST_WALLET rhapsody

Validator Tx

Then simply run the tx to upgrade to validator status:

## Upgrade node to validator
./build/quicksilverd tx staking create-validator \
  --from=$YOUR_TEST_WALLET \
  --amount=1000000uqck \
  --moniker=$NODE_MONIKER \
  --chain-id=$CHAIN_ID \
  --commission-rate=0.1 \
  --commission-max-rate=0.5 \
  --commission-max-change-rate=0.1 \
  --min-self-delegation=1 \
  --pubkey=$($BINARY tendermint show-validator)

Using minting qAtoms on Quicksilver

Instructions to come early next week!

About

Quicksilver Testnet Instructions and Config

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 95.7%
  • Makefile 4.3%