mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 04:04:21 +01:00
* [server] descriptor-based vtxo script * [server] fix unit tests * [sdk] descriptor based vtxo * empty config check & version flag support * fix: empty config check & version flag support (#309) * fix * [sdk] several fixes * [sdk][server] several fixes * [common][sdk] add reversible VtxoScript type, use it in async payment * [common] improve parser * [common] fix reversible vtxo parser * [sdk] remove logs * fix forfeit map * remove debug log * [sdk] do not allow reversible vtxo script in case of self-transfer * remove signing pubkey * remove signer public key, craft forfeit txs client side * go work sync * fix linter errors * rename MakeForfeitTxs to BuildForfeitTxs * fix conflicts * fix tests * comment VtxoScript type * revert ROUND_INTERVAL value --------- Co-authored-by: Pietralberto Mazza <18440657+altafan@users.noreply.github.com> Co-authored-by: sekulicd <sekula87@gmail.com>
68 lines
2.2 KiB
Go
68 lines
2.2 KiB
Go
package bitcointree_test
|
|
|
|
import (
|
|
"encoding/hex"
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/ark-network/ark/common/bitcointree"
|
|
"github.com/ark-network/ark/common/descriptor"
|
|
"github.com/btcsuite/btcd/btcec/v2/schnorr"
|
|
"github.com/decred/dcrd/dcrec/secp256k1/v4"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestParseDescriptor(t *testing.T) {
|
|
aspKey, err := secp256k1.GeneratePrivateKey()
|
|
require.NoError(t, err)
|
|
|
|
aliceKey, err := secp256k1.GeneratePrivateKey()
|
|
require.NoError(t, err)
|
|
|
|
bobKey, err := secp256k1.GeneratePrivateKey()
|
|
require.NoError(t, err)
|
|
|
|
aspPubKey := hex.EncodeToString(schnorr.SerializePubKey(aspKey.PubKey()))
|
|
alicePubKey := hex.EncodeToString(schnorr.SerializePubKey(aliceKey.PubKey()))
|
|
bobPubKey := hex.EncodeToString(schnorr.SerializePubKey(bobKey.PubKey()))
|
|
|
|
unspendableKey := hex.EncodeToString(bitcointree.UnspendableKey().SerializeCompressed())
|
|
|
|
defaultScriptDescriptor := fmt.Sprintf(
|
|
descriptor.DefaultVtxoDescriptorTemplate,
|
|
unspendableKey,
|
|
alicePubKey,
|
|
aspPubKey,
|
|
512,
|
|
alicePubKey,
|
|
)
|
|
|
|
vtxo, err := bitcointree.ParseVtxoScript(defaultScriptDescriptor)
|
|
require.NoError(t, err)
|
|
|
|
require.IsType(t, &bitcointree.DefaultVtxoScript{}, vtxo)
|
|
require.Equal(t, defaultScriptDescriptor, vtxo.ToDescriptor())
|
|
require.Equal(t, alicePubKey, hex.EncodeToString(schnorr.SerializePubKey(vtxo.(*bitcointree.DefaultVtxoScript).Owner)))
|
|
require.Equal(t, aspPubKey, hex.EncodeToString(schnorr.SerializePubKey(vtxo.(*bitcointree.DefaultVtxoScript).Asp)))
|
|
|
|
reversibleScriptDescriptor := fmt.Sprintf(
|
|
descriptor.ReversibleVtxoScriptTemplate,
|
|
unspendableKey,
|
|
alicePubKey,
|
|
aspPubKey,
|
|
512,
|
|
alicePubKey,
|
|
bobPubKey,
|
|
aspPubKey,
|
|
)
|
|
|
|
vtxo, err = bitcointree.ParseVtxoScript(reversibleScriptDescriptor)
|
|
require.NoError(t, err)
|
|
|
|
require.IsType(t, &bitcointree.ReversibleVtxoScript{}, vtxo)
|
|
require.Equal(t, reversibleScriptDescriptor, vtxo.ToDescriptor())
|
|
require.Equal(t, alicePubKey, hex.EncodeToString(schnorr.SerializePubKey(vtxo.(*bitcointree.ReversibleVtxoScript).Sender)))
|
|
require.Equal(t, bobPubKey, hex.EncodeToString(schnorr.SerializePubKey(vtxo.(*bitcointree.ReversibleVtxoScript).Owner)))
|
|
require.Equal(t, aspPubKey, hex.EncodeToString(schnorr.SerializePubKey(vtxo.(*bitcointree.ReversibleVtxoScript).Asp)))
|
|
}
|