Files
ark/pkg/client-sdk/wallet/wallet_test.go
Pietralberto Mazza 8de2df3d7f Covenant-less ark sdk (#225)
* Add method to compute vtxo taproot script

* Drop debug logs

* Refactor client:
* Remove dep from stubs in interface
* Remove redeem branch, out of scope (moved to ark client)

* Add example for covenant and covenantless sdk

* Simplify explorer - No need for bitcoin and liquid impls

* Refactor wallet:
* wallet struct for common operations (create, lock/unlock, getType, isLocked)
* liquidWallet struct for liquid operations (derive/get addresses, sign tx)
* bitcoinWallet struct for bitcoin operations (derive/get addresses, sign tx)

* Update utils:
* drop methods to parse tree (moved to ark client)
* add methods for encryption, network parsing, key generation
* add methods for covenant/covenantless redeem branches (move to common?)

* Add support for covenantless sdk:
* move interface to dedicated file
* arkCLient struct for common operations (Init, lock/unlock, get config data, receive)
* covenantArkClient struct for covenant operations (onboard, balance, send, redeem)
* covenantlessArkClient struct for covenantless operations (onboard, balance, send, redeem)

* Fix wasm

* Fixes

* Make explorer use utils.Cache

* Renamings

* Lint

* Fix e2e tests

* Fix e2e test
2024-08-07 01:37:18 +02:00

140 lines
4.1 KiB
Go

package wallet_test
import (
"context"
"strings"
"testing"
"github.com/ark-network/ark-sdk/client"
"github.com/ark-network/ark-sdk/store"
inmemorystore "github.com/ark-network/ark-sdk/store/inmemory"
"github.com/ark-network/ark-sdk/wallet"
singlekeywallet "github.com/ark-network/ark-sdk/wallet/singlekey"
inmemorywalletstore "github.com/ark-network/ark-sdk/wallet/singlekey/store/inmemory"
"github.com/ark-network/ark/common"
"github.com/btcsuite/btcd/btcec/v2"
"github.com/stretchr/testify/require"
)
func TestWallet(t *testing.T) {
ctx := context.Background()
key, _ := btcec.NewPrivateKey()
password := "password"
testStoreData := store.StoreData{
AspUrl: "localhost:8080",
AspPubkey: key.PubKey(),
WalletType: wallet.SingleKeyWallet,
ClientType: client.GrpcClient,
Network: common.LiquidRegTest,
RoundLifetime: 512,
UnilateralExitDelay: 512,
MinRelayFee: 300,
}
tests := []struct {
name string
chain string
args []interface{}
}{
{
name: "liquid" + wallet.SingleKeyWallet,
chain: "liquid",
args: []interface{}{common.LiquidRegTest},
},
{
name: "bitcoin" + wallet.SingleKeyWallet,
chain: "bitcoin",
args: []interface{}{common.LiquidRegTest},
},
}
for i := range tests {
tt := tests[i]
t.Run(tt.name, func(t *testing.T) {
t.Parallel()
store, err := inmemorystore.NewConfigStore()
require.NoError(t, err)
require.NotNil(t, store)
err = store.AddData(ctx, testStoreData)
require.NoError(t, err)
walletStore, err := inmemorywalletstore.NewWalletStore()
require.NoError(t, err)
require.NotNil(t, walletStore)
var walletSvc wallet.WalletService
if tt.chain == "liquid" {
walletSvc, err = singlekeywallet.NewLiquidWallet(store, walletStore)
} else {
walletSvc, err = singlekeywallet.NewBitcoinWallet(store, walletStore)
}
require.NoError(t, err)
require.NotNil(t, walletSvc)
key, err := walletSvc.Create(ctx, password, "")
require.NoError(t, err)
require.NotEmpty(t, key)
offchainAddr, onchainAddr, err := walletSvc.NewAddress(ctx, false)
require.NoError(t, err)
require.NotEmpty(t, offchainAddr)
require.NotEmpty(t, onchainAddr)
offchainAddrs, onchainAddrs, redemptionAddrs, err := walletSvc.GetAddresses(ctx)
require.NoError(t, err)
require.Len(t, offchainAddrs, 1)
require.Len(t, onchainAddrs, 1)
require.Len(t, redemptionAddrs, 1)
offchainAddr, onchainAddr, err = walletSvc.NewAddress(ctx, true)
require.NoError(t, err)
require.NotEmpty(t, offchainAddr)
require.NotEmpty(t, onchainAddr)
expectedNumOfAddresses := 2
if strings.Contains(tt.name, wallet.SingleKeyWallet) {
expectedNumOfAddresses = 1
}
offchainAddrs, onchainAddrs, redemptionAddrs, err = walletSvc.GetAddresses(ctx)
require.NoError(t, err)
require.Len(t, offchainAddrs, expectedNumOfAddresses)
require.Len(t, onchainAddrs, expectedNumOfAddresses)
require.Len(t, redemptionAddrs, expectedNumOfAddresses)
num := 3
offchainAddrs, onchainAddrs, err = walletSvc.NewAddresses(ctx, false, num)
require.NoError(t, err)
require.Len(t, offchainAddrs, num)
require.Len(t, onchainAddrs, num)
expectedNumOfAddresses += num
if strings.Contains(tt.name, wallet.SingleKeyWallet) {
expectedNumOfAddresses = 1
}
offchainAddrs, onchainAddrs, redemptionAddrs, err = walletSvc.GetAddresses(ctx)
require.NoError(t, err)
require.Len(t, offchainAddrs, expectedNumOfAddresses)
require.Len(t, onchainAddrs, expectedNumOfAddresses)
require.Len(t, redemptionAddrs, expectedNumOfAddresses)
// Check no password is required to unlock if wallet is already unlocked.
alreadyUnlocked, err := walletSvc.Unlock(ctx, password)
require.NoError(t, err)
require.False(t, alreadyUnlocked)
alreadyUnlocked, err = walletSvc.Unlock(ctx, "")
require.NoError(t, err)
require.True(t, alreadyUnlocked)
// Check no password is required to lock if wallet is already locked.
err = walletSvc.Lock(ctx, password)
require.NoError(t, err)
err = walletSvc.Lock(ctx, "")
require.NoError(t, err)
})
}
}