Files
muun-recovery/libwallet/swaps/v1_test.go
2025-05-13 17:49:44 -03:00

76 lines
2.5 KiB
Go
Executable File

package swaps
import (
"testing"
"github.com/btcsuite/btcd/chaincfg"
"github.com/btcsuite/btcutil/hdkeychain"
"github.com/muun/libwallet/addresses"
)
func TestValidateSubmarineSwapV1(t *testing.T) {
type args struct {
rawInvoice string
userPublicKey *KeyDescriptor
muunPublicKey *KeyDescriptor
swap *SubmarineSwap
network *chaincfg.Params
}
tests := []struct {
name string
args args
wantErr bool
}{
{
name: "successful",
args: args{
rawInvoice: "lnbcrt1p033394pp5sfcfh0ukkjfcvcg2vwk2hudue9d48lawqkacdan4msxne66w4krqdqqcqzpgsp5jelulm6a7q38j6jffa9qet3scz4qvcs08x6hfsyn0lfg34p2584q9qy9qsqjcq059jh8qeslj7qwl69ln69znalrxykhaj4kl0g0kfstwsa3warsyxx2d0rqs24tx896lz895wffqaj7l82zs896ec7r5arnw0cwtqpvzt8yd",
userPublicKey: &KeyDescriptor{
Key: decodeKey("tpubD6NzVbkrYhZ4Y3iy9soFSA9zoYbpyhUFu3eAH1sDWyERxH2yJVZUhPUX5QsxD6bZfMWRKzxw28ohD5n6AZWmvZbDpZzgxSVxUnMevqzTXQk"),
Path: "m",
},
muunPublicKey: &KeyDescriptor{
Key: decodeKey("tpubD6NzVbkrYhZ4XbhomyY2axxKe3KB1FK2Wq2z7XYyDF3T4QCuEDZFBUyGfjfHChvEbsbP9RpaYA8cwxkZpQjEcNdaPfuj3cKGqCiHC5YeRTo"),
Path: "m",
},
swap: &SubmarineSwap{
FundingOutput: SubmarineSwapFundingOutput{
OutputAddress: "2MvW8nGkzFXnLWUca6ZGUh3yqEq5MKEyAxb",
ExpirationInBlocks: 10,
ServerPaymentHashInHex: "82709bbf96b49386610a63acabf1bcc95b53ffae05bb86f675dc0d3ceb4ead86",
UserRefundAddress: addresses.New(addresses.V4, "m", "bcrt1q553urspdhwr49xavd67fvl35pzacz4853l4u09vntr8z06djnw7s95fgat"),
UserPublicKey: decodeKey("tpubD6NzVbkrYhZ4Y3iy9soFSA9zoYbpyhUFu3eAH1sDWyERxH2yJVZUhPUX5QsxD6bZfMWRKzxw28ohD5n6AZWmvZbDpZzgxSVxUnMevqzTXQk"),
MuunPublicKey: decodeKey("tpubD6NzVbkrYhZ4XbhomyY2axxKe3KB1FK2Wq2z7XYyDF3T4QCuEDZFBUyGfjfHChvEbsbP9RpaYA8cwxkZpQjEcNdaPfuj3cKGqCiHC5YeRTo"),
},
Receiver: SubmarineSwapReceiver{
PublicKey: "02c9a35bdbeab0b93ee9542d85c38beab7d1e72ea1d9639e5b00b1d5feb64bcfdd",
},
},
network: &chaincfg.RegressionNetParams,
},
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
err := tt.args.swap.validateV1(
tt.args.rawInvoice,
tt.args.userPublicKey,
tt.args.muunPublicKey,
tt.args.network,
)
if (err != nil) != tt.wantErr {
t.Errorf("validateV1() error = %v, wantErr %v", err, tt.wantErr)
}
})
}
}
func decodeKey(s string) *hdkeychain.ExtendedKey {
key, err := hdkeychain.NewKeyFromString(s)
if err != nil {
panic(err)
}
return key
}