github.com/pure-x-eth/consensus_tm@v0.0.0-20230502163723-e3c2ff987250/p2p/key_test.go (about) 1 package p2p 2 3 import ( 4 "bytes" 5 "os" 6 "path/filepath" 7 "testing" 8 9 "github.com/stretchr/testify/assert" 10 "github.com/stretchr/testify/require" 11 12 "github.com/pure-x-eth/consensus_tm/crypto/ed25519" 13 tmrand "github.com/pure-x-eth/consensus_tm/libs/rand" 14 ) 15 16 func TestLoadOrGenNodeKey(t *testing.T) { 17 filePath := filepath.Join(os.TempDir(), tmrand.Str(12)+"_peer_id.json") 18 19 nodeKey, err := LoadOrGenNodeKey(filePath) 20 assert.Nil(t, err) 21 22 nodeKey2, err := LoadOrGenNodeKey(filePath) 23 assert.Nil(t, err) 24 25 assert.Equal(t, nodeKey, nodeKey2) 26 } 27 28 func TestLoadNodeKey(t *testing.T) { 29 filePath := filepath.Join(os.TempDir(), tmrand.Str(12)+"_peer_id.json") 30 31 _, err := LoadNodeKey(filePath) 32 assert.True(t, os.IsNotExist(err)) 33 34 _, err = LoadOrGenNodeKey(filePath) 35 require.NoError(t, err) 36 37 nodeKey, err := LoadNodeKey(filePath) 38 assert.NoError(t, err) 39 assert.NotNil(t, nodeKey) 40 } 41 42 func TestNodeKeySaveAs(t *testing.T) { 43 filePath := filepath.Join(os.TempDir(), tmrand.Str(12)+"_peer_id.json") 44 45 assert.NoFileExists(t, filePath) 46 47 privKey := ed25519.GenPrivKey() 48 nodeKey := &NodeKey{ 49 PrivKey: privKey, 50 } 51 err := nodeKey.SaveAs(filePath) 52 assert.NoError(t, err) 53 assert.FileExists(t, filePath) 54 } 55 56 //---------------------------------------------------------- 57 58 func padBytes(bz []byte, targetBytes int) []byte { 59 return append(bz, bytes.Repeat([]byte{0xFF}, targetBytes-len(bz))...) 60 } 61 62 func TestPoWTarget(t *testing.T) { 63 64 targetBytes := 20 65 cases := []struct { 66 difficulty uint 67 target []byte 68 }{ 69 {0, padBytes([]byte{}, targetBytes)}, 70 {1, padBytes([]byte{127}, targetBytes)}, 71 {8, padBytes([]byte{0}, targetBytes)}, 72 {9, padBytes([]byte{0, 127}, targetBytes)}, 73 {10, padBytes([]byte{0, 63}, targetBytes)}, 74 {16, padBytes([]byte{0, 0}, targetBytes)}, 75 {17, padBytes([]byte{0, 0, 127}, targetBytes)}, 76 } 77 78 for _, c := range cases { 79 assert.Equal(t, MakePoWTarget(c.difficulty, 20*8), c.target) 80 } 81 }