code.vegaprotocol.io/vega@v0.79.0/cmd/vegawallet/commands/key_describe_test.go (about)

     1  // Copyright (C) 2023 Gobalsky Labs Limited
     2  //
     3  // This program is free software: you can redistribute it and/or modify
     4  // it under the terms of the GNU Affero General Public License as
     5  // published by the Free Software Foundation, either version 3 of the
     6  // License, or (at your option) any later version.
     7  //
     8  // This program is distributed in the hope that it will be useful,
     9  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    10  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    11  // GNU Affero General Public License for more details.
    12  //
    13  // You should have received a copy of the GNU Affero General Public License
    14  // along with this program.  If not, see <http://www.gnu.org/licenses/>.
    15  
    16  package cmd_test
    17  
    18  import (
    19  	"testing"
    20  
    21  	cmd "code.vegaprotocol.io/vega/cmd/vegawallet/commands"
    22  	"code.vegaprotocol.io/vega/cmd/vegawallet/commands/flags"
    23  	vgrand "code.vegaprotocol.io/vega/libs/rand"
    24  	"code.vegaprotocol.io/vega/wallet/api"
    25  
    26  	"github.com/stretchr/testify/assert"
    27  	"github.com/stretchr/testify/require"
    28  )
    29  
    30  func TestDescribeKeyFlags(t *testing.T) {
    31  	t.Run("Valid flags succeeds", testKeyDescribeValidFlagsSucceeds)
    32  	t.Run("Missing wallet fails", testKeyMissingWalletFails)
    33  	t.Run("Missing public key fails", testKeyMissingPublicKeyFails)
    34  }
    35  
    36  func testKeyDescribeValidFlagsSucceeds(t *testing.T) {
    37  	// given
    38  	testDir := t.TempDir()
    39  	expectedPassphrase, passphraseFilePath := NewPassphraseFile(t, testDir)
    40  	walletName := vgrand.RandomStr(10)
    41  	pubKey := vgrand.RandomStr(10)
    42  
    43  	f := &cmd.DescribeKeyFlags{
    44  		Wallet:         walletName,
    45  		PassphraseFile: passphraseFilePath,
    46  		PublicKey:      pubKey,
    47  	}
    48  
    49  	expectedReq := api.AdminDescribeKeyParams{
    50  		Wallet:    walletName,
    51  		PublicKey: pubKey,
    52  	}
    53  
    54  	// when
    55  	req, passphrase, err := f.Validate()
    56  
    57  	// then
    58  	require.NoError(t, err)
    59  	assert.Equal(t, expectedReq, req)
    60  	assert.Equal(t, expectedPassphrase, passphrase)
    61  }
    62  
    63  func testKeyMissingWalletFails(t *testing.T) {
    64  	// given
    65  	testDir := t.TempDir()
    66  
    67  	// given
    68  	_, passphraseFilePath := NewPassphraseFile(t, testDir)
    69  	pubKey := vgrand.RandomStr(10)
    70  
    71  	f := &cmd.DescribeKeyFlags{
    72  		PassphraseFile: passphraseFilePath,
    73  		PublicKey:      pubKey,
    74  	}
    75  
    76  	// when
    77  	req, _, err := f.Validate()
    78  
    79  	// then
    80  	assert.ErrorIs(t, err, flags.MustBeSpecifiedError("wallet"))
    81  	require.Empty(t, req)
    82  }
    83  
    84  func testKeyMissingPublicKeyFails(t *testing.T) {
    85  	// given
    86  	testDir := t.TempDir()
    87  
    88  	// given
    89  	_, passphraseFilePath := NewPassphraseFile(t, testDir)
    90  	walletName := vgrand.RandomStr(10)
    91  
    92  	f := &cmd.DescribeKeyFlags{
    93  		PassphraseFile: passphraseFilePath,
    94  		Wallet:         walletName,
    95  	}
    96  
    97  	// when
    98  	req, _, err := f.Validate()
    99  
   100  	// then
   101  	assert.ErrorIs(t, err, flags.MustBeSpecifiedError("pubkey"))
   102  	require.Empty(t, req)
   103  }