A regtest demo
Our software is experimental and it is reckless to run it with real bitcoin.
Bitcoin Core provides a few other networks
that can be used to test new functionality. In this scenario
we are going to use regtest
.
Setting up a regtest environment
Ensure you have installed all optional dependencies described in compile from source.
Go to root of the repository and
source the ark_demo.sh
file.
source ark_demo.sh
This creates a good environment to play with bark
and aspd
.
We start with setting up a regtest
bitcoin-node.
If you already have a node running you can use that one.
You just have to ensure that txindex
is enabled.
For the purpose of this tutorial it is easier to spin up a new
regtest
node. The ark_demo.sh
script has created a handy
alias bd
bd --daemon
You can always use type -a bd
to see what the alias does.
In this case it will tell you that bd
is an alias for
bitcoind -regtest -datadir=/ark/test/bitcoindatadir -server -txdindex -fallbackfee=0.0002
.
You can use the bitcoin-cli
which is aliased to bcli
to interact
with the node.
bcli getnetworkinfo
Testing bitcoin without coins isn't fun. We add a wallet to Bitcoin Core and send some funds to it. We mine some blocks and reap the rewards.
bcli createwallet "default"
bcli -generate 106
bcli getbalance
Then we create and configure an ark-server using the aspd
-command.
Our ark-server will run on regtest
and use the bitcoin
-node
we've started a few lines before.
aspd create \
--network regtest \
--datadir ./test/arkdatadir \
--bitcoind-url $BITCOIND_URL \
--bitcoind-cookie $BITCOIND_COOKIE
The server can be started using
aspd start --datadir ./test/arkdatadir
The server will start working immediately but requires some funds. We can get the address and some funds to it. You can get the address using the following rpc command.
aspd rpc get-address
We can now send 100 BTC to the asp
bcli sendtoaddress <asp-addr> 100
and check if the aspd
received the money
aspd rpc balance
Next, you can start some clients. To create a client, use the following command:
bark --datadir ./test/bark1 create \
--regtest \
--asp http://localhost:3535 \
--bitcoind $BITCOIND_URL \
--bitcoind-cookie $BITCOIND_COOKIE
bark --datadir ./test/bark2 create \
--regtest \
--asp http://localhost:3535 \
--bitcoind $BITCOIND_URL \
--bitcoind-cookie $BITCOIND_COOKIE
Note that clients can receive off-chain Ark transactions without having any on-chain balance, but a little bit of on-chain money is needed to perform unilateral exits.
You can fund the wallet using
BARK1_ADDR=$(bark --datadir ./test/bark1 onchain address)
bcli sendtoaddress $BARK1_ADDR 5
To use the onchain wallets, there are a few commands available:
BARK2_ADDR=$(bark --datadir ./test/bark2 onchain address)
bark --datadir ./test/bark1 onchain send $BARK2_ADDR "0.1 btc"
bark --datadir ./test/bark2 onchain balance
Once we have money, we can onboard into the Ark, afterwards the balance will also show an off-chain element.
bark --datadir ./test/bark1 onboard "1 btc"
bark --datadir ./test/bark1 balance
Remember that all txs will just be in the mempool if you don't generate blocks once a while...
bcli -generate 1
Then, we will send some money from bark1
to bark2
## Should be empty..
BARK2_PK=$(bark --datadir ./test/bark2 vtxo-pubkey)
# For now every client has just a single pubkey.
echo "${BARK2_PK}"
bark --datadir ./test/bark1 send ${BARK2_PK} "0.1 btc"
bark --datadir ./test/bark2 balance
Notice, the payment went through instantly. We didn't need to wait for a round. The payment happend in an out-of-round transaction.
We can verify this by calling
bark --datadir ./test/bark2 vtxos --json | jq
and looking at the output
[
{
"id": "86c3af18b333c7512b7929e7b97de74eb2d2203d53d4fec4b10958d951ab775d:0",
"amount": 10000000,
"vtxo_type": "oor",
"utxo": "86c3af18b333c7512b7929e7b97de74eb2d2203d53d4fec4b10958d951ab775d:0",
"user_pubkey": "027e84e31b9a2550ae36825ea52c0d6058be888016c1aa0942c8aa724ad2936eef",
"asp_pubkey": "03e1a811953d47f8b68a584db1352141639aeccf594234f849f3229b58a6d074c1",
"expiry_height": 250,
"exit_delta": 12
}
]
You can see that vtxo_type
is oor
and that the expiry_height
equals 250
.
The vtxo can be refreshed using
bark --datadir ./test/bark2 refresh
Use the vtxos
-command to verify that a new vtxo has been created and the
vtxo_type
is round
.
bark --datadir ./test/bark2 vtxos --json | jq .[].vtxo_type