aboutsummaryrefslogtreecommitdiffstats
path: root/accounts/accounts_test.go
blob: 30e0b011adb38bc02d79479ab88fcebdca21766f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package accounts

import (
    "testing"

    "time"

    "github.com/ethereum/go-ethereum/crypto"
    "github.com/ethereum/go-ethereum/crypto/randentropy"
    "github.com/ethereum/go-ethereum/ethutil"
)

func TestAccountManager(t *testing.T) {
    ks := crypto.NewKeyStorePlain(ethutil.DefaultDataDir() + "/testaccounts")
    am := NewAccountManager(ks, 100*time.Millisecond)
    pass := "" // not used but required by API
    a1, err := am.NewAccount(pass)
    toSign := randentropy.GetEntropyCSPRNG(32)
    _, err = am.SignLocked(a1, pass, toSign)
    if err != nil {
        t.Fatal(err)
    }

    // Cleanup
    time.Sleep(150 * time.Millisecond) // wait for locking

    accounts, err := am.Accounts()
    if err != nil {
        t.Fatal(err)
    }
    for _, account := range accounts {
        err := am.DeleteAccount(account.Address, pass)
        if err != nil {
            t.Fatal(err)
        }
    }
}

func TestAccountManagerLocking(t *testing.T) {
    ks := crypto.NewKeyStorePassphrase(ethutil.DefaultDataDir() + "/testaccounts")
    am := NewAccountManager(ks, 200*time.Millisecond)
    pass := "foo"
    a1, err := am.NewAccount(pass)
    toSign := randentropy.GetEntropyCSPRNG(32)

    // Signing without passphrase fails because account is locked
    _, err = am.Sign(a1, toSign)
    if err != ErrLocked {
        t.Fatal(err)
    }

    // Signing with passphrase works
    _, err = am.SignLocked(a1, pass, toSign)
    if err != nil {
        t.Fatal(err)
    }

    // Signing without passphrase works because account is temp unlocked
    _, err = am.Sign(a1, toSign)
    if err != nil {
        t.Fatal(err)
    }

    // Signing without passphrase fails after automatic locking
    time.Sleep(250 * time.Millisecond)

    _, err = am.Sign(a1, toSign)
    if err != ErrLocked {
        t.Fatal(err)
    }

    // Cleanup
    accounts, err := am.Accounts()
    if err != nil {
        t.Fatal(err)
    }
    for _, account := range accounts {
        err := am.DeleteAccount(account.Address, pass)
        if err != nil {
            t.Fatal(err)
        }
    }
}