walletunlocker: use require library, fix linter issues
To prepare for new tests to be added, we first rewrite the existing tests to use the require library and get rid of some smaller linter issues.
This commit is contained in:
parent
b685a97fcd
commit
4b0b20c98b
@ -5,7 +5,6 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -17,7 +16,9 @@ import (
|
|||||||
"github.com/lightningnetwork/lnd/keychain"
|
"github.com/lightningnetwork/lnd/keychain"
|
||||||
"github.com/lightningnetwork/lnd/lnrpc"
|
"github.com/lightningnetwork/lnd/lnrpc"
|
||||||
"github.com/lightningnetwork/lnd/lnwallet/btcwallet"
|
"github.com/lightningnetwork/lnd/lnwallet/btcwallet"
|
||||||
|
"github.com/lightningnetwork/lnd/macaroons"
|
||||||
"github.com/lightningnetwork/lnd/walletunlocker"
|
"github.com/lightningnetwork/lnd/walletunlocker"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -34,6 +35,12 @@ var (
|
|||||||
testNetParams = &chaincfg.MainNetParams
|
testNetParams = &chaincfg.MainNetParams
|
||||||
|
|
||||||
testRecoveryWindow uint32 = 150
|
testRecoveryWindow uint32 = 150
|
||||||
|
|
||||||
|
defaultTestTimeout = 3 * time.Second
|
||||||
|
|
||||||
|
defaultRootKeyIDContext = macaroons.ContextWithRootKeyID(
|
||||||
|
context.Background(), macaroons.DefaultRootKeyID,
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
func createTestWallet(t *testing.T, dir string, netParams *chaincfg.Params) {
|
func createTestWallet(t *testing.T, dir string, netParams *chaincfg.Params) {
|
||||||
@ -55,13 +62,9 @@ func createTestWallet(t *testing.T, dir string, netParams *chaincfg.Params) {
|
|||||||
_, err := loader.CreateNewWallet(
|
_, err := loader.CreateNewWallet(
|
||||||
testPassword, testPassword, testSeed, time.Time{},
|
testPassword, testPassword, testSeed, time.Time{},
|
||||||
)
|
)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("failed creating wallet: %v", err)
|
|
||||||
}
|
|
||||||
err = loader.UnloadWallet()
|
err = loader.UnloadWallet()
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("failed unloading wallet: %v", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestGenSeedUserEntropy tests that the gen seed method generates a valid
|
// TestGenSeedUserEntropy tests that the gen seed method generates a valid
|
||||||
@ -72,10 +75,10 @@ func TestGenSeed(t *testing.T) {
|
|||||||
// First, we'll create a new test directory and unlocker service for
|
// First, we'll create a new test directory and unlocker service for
|
||||||
// that directory.
|
// that directory.
|
||||||
testDir, err := ioutil.TempDir("", "testcreate")
|
testDir, err := ioutil.TempDir("", "testcreate")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
defer func() {
|
||||||
}
|
_ = os.RemoveAll(testDir)
|
||||||
defer os.RemoveAll(testDir)
|
}()
|
||||||
|
|
||||||
service := walletunlocker.New(testDir, testNetParams, true, nil)
|
service := walletunlocker.New(testDir, testNetParams, true, nil)
|
||||||
|
|
||||||
@ -89,18 +92,14 @@ func TestGenSeed(t *testing.T) {
|
|||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
seedResp, err := service.GenSeed(ctx, genSeedReq)
|
seedResp, err := service.GenSeed(ctx, genSeedReq)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to generate seed: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// We should then be able to take the generated mnemonic, and properly
|
// We should then be able to take the generated mnemonic, and properly
|
||||||
// decipher both it.
|
// decipher both it.
|
||||||
var mnemonic aezeed.Mnemonic
|
var mnemonic aezeed.Mnemonic
|
||||||
copy(mnemonic[:], seedResp.CipherSeedMnemonic[:])
|
copy(mnemonic[:], seedResp.CipherSeedMnemonic[:])
|
||||||
_, err = mnemonic.ToCipherSeed(aezeedPass)
|
_, err = mnemonic.ToCipherSeed(aezeedPass)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to decipher cipher seed: %v", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestGenSeedInvalidEntropy tests that the gen seed method generates a valid
|
// TestGenSeedInvalidEntropy tests that the gen seed method generates a valid
|
||||||
@ -112,11 +111,9 @@ func TestGenSeedGenerateEntropy(t *testing.T) {
|
|||||||
// First, we'll create a new test directory and unlocker service for
|
// First, we'll create a new test directory and unlocker service for
|
||||||
// that directory.
|
// that directory.
|
||||||
testDir, err := ioutil.TempDir("", "testcreate")
|
testDir, err := ioutil.TempDir("", "testcreate")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
|
||||||
}
|
|
||||||
defer func() {
|
defer func() {
|
||||||
os.RemoveAll(testDir)
|
_ = os.RemoveAll(testDir)
|
||||||
}()
|
}()
|
||||||
service := walletunlocker.New(testDir, testNetParams, true, nil)
|
service := walletunlocker.New(testDir, testNetParams, true, nil)
|
||||||
|
|
||||||
@ -129,18 +126,14 @@ func TestGenSeedGenerateEntropy(t *testing.T) {
|
|||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
seedResp, err := service.GenSeed(ctx, genSeedReq)
|
seedResp, err := service.GenSeed(ctx, genSeedReq)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to generate seed: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// We should then be able to take the generated mnemonic, and properly
|
// We should then be able to take the generated mnemonic, and properly
|
||||||
// decipher both it.
|
// decipher both it.
|
||||||
var mnemonic aezeed.Mnemonic
|
var mnemonic aezeed.Mnemonic
|
||||||
copy(mnemonic[:], seedResp.CipherSeedMnemonic[:])
|
copy(mnemonic[:], seedResp.CipherSeedMnemonic[:])
|
||||||
_, err = mnemonic.ToCipherSeed(aezeedPass)
|
_, err = mnemonic.ToCipherSeed(aezeedPass)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to decipher cipher seed: %v", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestGenSeedInvalidEntropy tests that if a user attempt to create a seed with
|
// TestGenSeedInvalidEntropy tests that if a user attempt to create a seed with
|
||||||
@ -152,11 +145,9 @@ func TestGenSeedInvalidEntropy(t *testing.T) {
|
|||||||
// First, we'll create a new test directory and unlocker service for
|
// First, we'll create a new test directory and unlocker service for
|
||||||
// that directory.
|
// that directory.
|
||||||
testDir, err := ioutil.TempDir("", "testcreate")
|
testDir, err := ioutil.TempDir("", "testcreate")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
|
||||||
}
|
|
||||||
defer func() {
|
defer func() {
|
||||||
os.RemoveAll(testDir)
|
_ = os.RemoveAll(testDir)
|
||||||
}()
|
}()
|
||||||
service := walletunlocker.New(testDir, testNetParams, true, nil)
|
service := walletunlocker.New(testDir, testNetParams, true, nil)
|
||||||
|
|
||||||
@ -172,13 +163,8 @@ func TestGenSeedInvalidEntropy(t *testing.T) {
|
|||||||
// We should get an error now since the entropy source was invalid.
|
// We should get an error now since the entropy source was invalid.
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
_, err = service.GenSeed(ctx, genSeedReq)
|
_, err = service.GenSeed(ctx, genSeedReq)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatalf("seed creation should've failed")
|
require.Contains(t, err.Error(), "incorrect entropy length")
|
||||||
}
|
|
||||||
|
|
||||||
if !strings.Contains(err.Error(), "incorrect entropy length") {
|
|
||||||
t.Fatalf("wrong error, expected incorrect entropy length")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestInitWallet tests that the user is able to properly initialize the wallet
|
// TestInitWallet tests that the user is able to properly initialize the wallet
|
||||||
@ -188,11 +174,9 @@ func TestInitWallet(t *testing.T) {
|
|||||||
|
|
||||||
// testDir is empty, meaning wallet was not created from before.
|
// testDir is empty, meaning wallet was not created from before.
|
||||||
testDir, err := ioutil.TempDir("", "testcreate")
|
testDir, err := ioutil.TempDir("", "testcreate")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
|
||||||
}
|
|
||||||
defer func() {
|
defer func() {
|
||||||
os.RemoveAll(testDir)
|
_ = os.RemoveAll(testDir)
|
||||||
}()
|
}()
|
||||||
|
|
||||||
// Create new UnlockerService.
|
// Create new UnlockerService.
|
||||||
@ -203,17 +187,13 @@ func TestInitWallet(t *testing.T) {
|
|||||||
cipherSeed, err := aezeed.New(
|
cipherSeed, err := aezeed.New(
|
||||||
keychain.KeyDerivationVersion, &testEntropy, time.Now(),
|
keychain.KeyDerivationVersion, &testEntropy, time.Now(),
|
||||||
)
|
)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create seed: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// With the new seed created, we'll convert it into a mnemonic phrase
|
// With the new seed created, we'll convert it into a mnemonic phrase
|
||||||
// that we'll send over to initialize the wallet.
|
// that we'll send over to initialize the wallet.
|
||||||
pass := []byte("test")
|
pass := []byte("test")
|
||||||
mnemonic, err := cipherSeed.ToMnemonic(pass)
|
mnemonic, err := cipherSeed.ToMnemonic(pass)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create mnemonic: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now that we have all the necessary items, we'll now issue the Init
|
// Now that we have all the necessary items, we'll now issue the Init
|
||||||
// command to the wallet. This should check the validity of the cipher
|
// command to the wallet. This should check the validity of the cipher
|
||||||
@ -222,45 +202,27 @@ func TestInitWallet(t *testing.T) {
|
|||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
req := &lnrpc.InitWalletRequest{
|
req := &lnrpc.InitWalletRequest{
|
||||||
WalletPassword: testPassword,
|
WalletPassword: testPassword,
|
||||||
CipherSeedMnemonic: []string(mnemonic[:]),
|
CipherSeedMnemonic: mnemonic[:],
|
||||||
AezeedPassphrase: pass,
|
AezeedPassphrase: pass,
|
||||||
RecoveryWindow: int32(testRecoveryWindow),
|
RecoveryWindow: int32(testRecoveryWindow),
|
||||||
}
|
}
|
||||||
_, err = service.InitWallet(ctx, req)
|
_, err = service.InitWallet(ctx, req)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("InitWallet call failed: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// The same user passphrase, and also the plaintext cipher seed
|
// The same user passphrase, and also the plaintext cipher seed
|
||||||
// should be sent over and match exactly.
|
// should be sent over and match exactly.
|
||||||
select {
|
select {
|
||||||
case msg := <-service.InitMsgs:
|
case msg := <-service.InitMsgs:
|
||||||
if !bytes.Equal(msg.Passphrase, testPassword) {
|
msgSeed := msg.WalletSeed
|
||||||
t.Fatalf("expected to receive password %x, "+
|
require.Equal(t, testPassword, msg.Passphrase)
|
||||||
"got %x", testPassword, msg.Passphrase)
|
require.Equal(
|
||||||
}
|
t, cipherSeed.InternalVersion, msgSeed.InternalVersion,
|
||||||
if msg.WalletSeed.InternalVersion != cipherSeed.InternalVersion {
|
)
|
||||||
t.Fatalf("mismatched versions: expected %v, "+
|
require.Equal(t, cipherSeed.Birthday, msgSeed.Birthday)
|
||||||
"got %v", cipherSeed.InternalVersion,
|
require.Equal(t, cipherSeed.Entropy, msgSeed.Entropy)
|
||||||
msg.WalletSeed.InternalVersion)
|
require.Equal(t, testRecoveryWindow, msg.RecoveryWindow)
|
||||||
}
|
|
||||||
if msg.WalletSeed.Birthday != cipherSeed.Birthday {
|
|
||||||
t.Fatalf("mismatched birthday: expected %v, "+
|
|
||||||
"got %v", cipherSeed.Birthday,
|
|
||||||
msg.WalletSeed.Birthday)
|
|
||||||
}
|
|
||||||
if msg.WalletSeed.Entropy != cipherSeed.Entropy {
|
|
||||||
t.Fatalf("mismatched versions: expected %x, "+
|
|
||||||
"got %x", cipherSeed.Entropy[:],
|
|
||||||
msg.WalletSeed.Entropy[:])
|
|
||||||
}
|
|
||||||
if msg.RecoveryWindow != testRecoveryWindow {
|
|
||||||
t.Fatalf("mismatched recovery window: expected %v,"+
|
|
||||||
"got %v", testRecoveryWindow,
|
|
||||||
msg.RecoveryWindow)
|
|
||||||
}
|
|
||||||
|
|
||||||
case <-time.After(3 * time.Second):
|
case <-time.After(defaultTestTimeout):
|
||||||
t.Fatalf("password not received")
|
t.Fatalf("password not received")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -270,16 +232,12 @@ func TestInitWallet(t *testing.T) {
|
|||||||
// Now calling InitWallet should fail, since a wallet already exists in
|
// Now calling InitWallet should fail, since a wallet already exists in
|
||||||
// the directory.
|
// the directory.
|
||||||
_, err = service.InitWallet(ctx, req)
|
_, err = service.InitWallet(ctx, req)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatalf("InitWallet did not fail as expected")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Similarly, if we try to do GenSeed again, we should get an error as
|
// Similarly, if we try to do GenSeed again, we should get an error as
|
||||||
// the wallet already exists.
|
// the wallet already exists.
|
||||||
_, err = service.GenSeed(ctx, &lnrpc.GenSeedRequest{})
|
_, err = service.GenSeed(ctx, &lnrpc.GenSeedRequest{})
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatalf("seed generation should have failed")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestInitWalletInvalidCipherSeed tests that if we attempt to create a wallet
|
// TestInitWalletInvalidCipherSeed tests that if we attempt to create a wallet
|
||||||
@ -289,11 +247,9 @@ func TestCreateWalletInvalidEntropy(t *testing.T) {
|
|||||||
|
|
||||||
// testDir is empty, meaning wallet was not created from before.
|
// testDir is empty, meaning wallet was not created from before.
|
||||||
testDir, err := ioutil.TempDir("", "testcreate")
|
testDir, err := ioutil.TempDir("", "testcreate")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
|
||||||
}
|
|
||||||
defer func() {
|
defer func() {
|
||||||
os.RemoveAll(testDir)
|
_ = os.RemoveAll(testDir)
|
||||||
}()
|
}()
|
||||||
|
|
||||||
// Create new UnlockerService.
|
// Create new UnlockerService.
|
||||||
@ -309,9 +265,7 @@ func TestCreateWalletInvalidEntropy(t *testing.T) {
|
|||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
_, err = service.InitWallet(ctx, req)
|
_, err = service.InitWallet(ctx, req)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatalf("wallet creation should have failed")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestUnlockWallet checks that trying to unlock non-existing wallet fail, that
|
// TestUnlockWallet checks that trying to unlock non-existing wallet fail, that
|
||||||
@ -322,11 +276,9 @@ func TestUnlockWallet(t *testing.T) {
|
|||||||
|
|
||||||
// testDir is empty, meaning wallet was not created from before.
|
// testDir is empty, meaning wallet was not created from before.
|
||||||
testDir, err := ioutil.TempDir("", "testunlock")
|
testDir, err := ioutil.TempDir("", "testunlock")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
|
||||||
}
|
|
||||||
defer func() {
|
defer func() {
|
||||||
os.RemoveAll(testDir)
|
_ = os.RemoveAll(testDir)
|
||||||
}()
|
}()
|
||||||
|
|
||||||
// Create new UnlockerService.
|
// Create new UnlockerService.
|
||||||
@ -340,9 +292,7 @@ func TestUnlockWallet(t *testing.T) {
|
|||||||
|
|
||||||
// Should fail to unlock non-existing wallet.
|
// Should fail to unlock non-existing wallet.
|
||||||
_, err = service.UnlockWallet(ctx, req)
|
_, err = service.UnlockWallet(ctx, req)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatalf("expected call to UnlockWallet to fail")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a wallet we can try to unlock.
|
// Create a wallet we can try to unlock.
|
||||||
createTestWallet(t, testDir, testNetParams)
|
createTestWallet(t, testDir, testNetParams)
|
||||||
@ -352,29 +302,19 @@ func TestUnlockWallet(t *testing.T) {
|
|||||||
WalletPassword: []byte("wrong-ofc"),
|
WalletPassword: []byte("wrong-ofc"),
|
||||||
}
|
}
|
||||||
_, err = service.UnlockWallet(ctx, wrongReq)
|
_, err = service.UnlockWallet(ctx, wrongReq)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatalf("expected call to UnlockWallet to fail")
|
|
||||||
}
|
|
||||||
|
|
||||||
// With the correct password, we should be able to unlock the wallet.
|
// With the correct password, we should be able to unlock the wallet.
|
||||||
_, err = service.UnlockWallet(ctx, req)
|
_, err = service.UnlockWallet(ctx, req)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to unlock wallet: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Password and recovery window should be sent over the channel.
|
// Password and recovery window should be sent over the channel.
|
||||||
select {
|
select {
|
||||||
case unlockMsg := <-service.UnlockMsgs:
|
case unlockMsg := <-service.UnlockMsgs:
|
||||||
if !bytes.Equal(unlockMsg.Passphrase, testPassword) {
|
require.Equal(t, testPassword, unlockMsg.Passphrase)
|
||||||
t.Fatalf("expected to receive password %x, got %x",
|
require.Equal(t, testRecoveryWindow, unlockMsg.RecoveryWindow)
|
||||||
testPassword, unlockMsg.Passphrase)
|
|
||||||
}
|
case <-time.After(defaultTestTimeout):
|
||||||
if unlockMsg.RecoveryWindow != testRecoveryWindow {
|
|
||||||
t.Fatalf("expected to receive recovery window %d, "+
|
|
||||||
"got %d", testRecoveryWindow,
|
|
||||||
unlockMsg.RecoveryWindow)
|
|
||||||
}
|
|
||||||
case <-time.After(3 * time.Second):
|
|
||||||
t.Fatalf("password not received")
|
t.Fatalf("password not received")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -386,10 +326,10 @@ func TestChangeWalletPassword(t *testing.T) {
|
|||||||
|
|
||||||
// testDir is empty, meaning wallet was not created from before.
|
// testDir is empty, meaning wallet was not created from before.
|
||||||
testDir, err := ioutil.TempDir("", "testchangepassword")
|
testDir, err := ioutil.TempDir("", "testchangepassword")
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to create temp directory: %v", err)
|
defer func() {
|
||||||
}
|
_ = os.RemoveAll(testDir)
|
||||||
defer os.RemoveAll(testDir)
|
}()
|
||||||
|
|
||||||
// Create some files that will act as macaroon files that should be
|
// Create some files that will act as macaroon files that should be
|
||||||
// deleted after a password change is successful.
|
// deleted after a password change is successful.
|
||||||
@ -400,7 +340,7 @@ func TestChangeWalletPassword(t *testing.T) {
|
|||||||
t.Fatalf("unable to create temp file: %v", err)
|
t.Fatalf("unable to create temp file: %v", err)
|
||||||
}
|
}
|
||||||
tempFiles = append(tempFiles, file.Name())
|
tempFiles = append(tempFiles, file.Name())
|
||||||
file.Close()
|
require.NoError(t, file.Close())
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new UnlockerService with our temp files.
|
// Create a new UnlockerService with our temp files.
|
||||||
@ -416,9 +356,7 @@ func TestChangeWalletPassword(t *testing.T) {
|
|||||||
|
|
||||||
// Changing the password to a non-existing wallet should fail.
|
// Changing the password to a non-existing wallet should fail.
|
||||||
_, err = service.ChangePassword(ctx, req)
|
_, err = service.ChangePassword(ctx, req)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatal("expected call to ChangePassword to fail")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a wallet to test changing the password.
|
// Create a wallet to test changing the password.
|
||||||
createTestWallet(t, testDir, testNetParams)
|
createTestWallet(t, testDir, testNetParams)
|
||||||
@ -430,9 +368,7 @@ func TestChangeWalletPassword(t *testing.T) {
|
|||||||
NewPassword: newPassword,
|
NewPassword: newPassword,
|
||||||
}
|
}
|
||||||
_, err = service.ChangePassword(ctx, wrongReq)
|
_, err = service.ChangePassword(ctx, wrongReq)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatal("expected call to ChangePassword to fail")
|
|
||||||
}
|
|
||||||
|
|
||||||
// The files should still exist after an unsuccessful attempt to change
|
// The files should still exist after an unsuccessful attempt to change
|
||||||
// the wallet's password.
|
// the wallet's password.
|
||||||
@ -446,17 +382,13 @@ func TestChangeWalletPassword(t *testing.T) {
|
|||||||
// new password should fail.
|
// new password should fail.
|
||||||
wrongReq.NewPassword = []byte("8")
|
wrongReq.NewPassword = []byte("8")
|
||||||
_, err = service.ChangePassword(ctx, wrongReq)
|
_, err = service.ChangePassword(ctx, wrongReq)
|
||||||
if err == nil {
|
require.Error(t, err)
|
||||||
t.Fatal("expected call to ChangePassword to fail")
|
|
||||||
}
|
|
||||||
|
|
||||||
// When providing the correct wallet's current password and a new
|
// When providing the correct wallet's current password and a new
|
||||||
// password that meets the length requirement, the password change
|
// password that meets the length requirement, the password change
|
||||||
// should succeed.
|
// should succeed.
|
||||||
_, err = service.ChangePassword(ctx, req)
|
_, err = service.ChangePassword(ctx, req)
|
||||||
if err != nil {
|
require.NoError(t, err)
|
||||||
t.Fatalf("unable to change wallet's password: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// The files should no longer exist.
|
// The files should no longer exist.
|
||||||
for _, tempFile := range tempFiles {
|
for _, tempFile := range tempFiles {
|
||||||
@ -468,11 +400,9 @@ func TestChangeWalletPassword(t *testing.T) {
|
|||||||
// The new password should be sent over the channel.
|
// The new password should be sent over the channel.
|
||||||
select {
|
select {
|
||||||
case unlockMsg := <-service.UnlockMsgs:
|
case unlockMsg := <-service.UnlockMsgs:
|
||||||
if !bytes.Equal(unlockMsg.Passphrase, newPassword) {
|
require.Equal(t, newPassword, unlockMsg.Passphrase)
|
||||||
t.Fatalf("expected to receive password %x, got %x",
|
|
||||||
testPassword, unlockMsg.Passphrase)
|
case <-time.After(defaultTestTimeout):
|
||||||
}
|
|
||||||
case <-time.After(3 * time.Second):
|
|
||||||
t.Fatalf("password not received")
|
t.Fatalf("password not received")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user