key_store_test.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. package crypto
  2. import (
  3. "encoding/hex"
  4. "fmt"
  5. "reflect"
  6. "testing"
  7. "github.com/ethereum/go-ethereum/common"
  8. "github.com/ethereum/go-ethereum/crypto/randentropy"
  9. )
  10. func TestKeyStorePlain(t *testing.T) {
  11. ks := NewKeyStorePlain(common.DefaultDataDir())
  12. pass := "" // not used but required by API
  13. k1, err := ks.GenerateNewKey(randentropy.Reader, pass)
  14. if err != nil {
  15. t.Fatal(err)
  16. }
  17. k2 := new(Key)
  18. k2, err = ks.GetKey(k1.Address, pass)
  19. if err != nil {
  20. t.Fatal(err)
  21. }
  22. if !reflect.DeepEqual(k1.Address, k2.Address) {
  23. t.Fatal(err)
  24. }
  25. if !reflect.DeepEqual(k1.PrivateKey, k2.PrivateKey) {
  26. t.Fatal(err)
  27. }
  28. err = ks.DeleteKey(k2.Address, pass)
  29. if err != nil {
  30. t.Fatal(err)
  31. }
  32. }
  33. func TestKeyStorePassphrase(t *testing.T) {
  34. ks := NewKeyStorePassphrase(common.DefaultDataDir())
  35. pass := "foo"
  36. k1, err := ks.GenerateNewKey(randentropy.Reader, pass)
  37. if err != nil {
  38. t.Fatal(err)
  39. }
  40. k2 := new(Key)
  41. k2, err = ks.GetKey(k1.Address, pass)
  42. if err != nil {
  43. t.Fatal(err)
  44. }
  45. if !reflect.DeepEqual(k1.Address, k2.Address) {
  46. t.Fatal(err)
  47. }
  48. if !reflect.DeepEqual(k1.PrivateKey, k2.PrivateKey) {
  49. t.Fatal(err)
  50. }
  51. err = ks.DeleteKey(k2.Address, pass) // also to clean up created files
  52. if err != nil {
  53. t.Fatal(err)
  54. }
  55. }
  56. func TestKeyStorePassphraseDecryptionFail(t *testing.T) {
  57. ks := NewKeyStorePassphrase(common.DefaultDataDir())
  58. pass := "foo"
  59. k1, err := ks.GenerateNewKey(randentropy.Reader, pass)
  60. if err != nil {
  61. t.Fatal(err)
  62. }
  63. _, err = ks.GetKey(k1.Address, "bar") // wrong passphrase
  64. if err == nil {
  65. t.Fatal(err)
  66. }
  67. err = ks.DeleteKey(k1.Address, "bar") // wrong passphrase
  68. if err == nil {
  69. t.Fatal(err)
  70. }
  71. err = ks.DeleteKey(k1.Address, pass) // to clean up
  72. if err != nil {
  73. t.Fatal(err)
  74. }
  75. }
  76. func TestImportPreSaleKey(t *testing.T) {
  77. // file content of a presale key file generated with:
  78. // python pyethsaletool.py genwallet
  79. // with password "foo"
  80. fileContent := "{\"encseed\": \"26d87f5f2bf9835f9a47eefae571bc09f9107bb13d54ff12a4ec095d01f83897494cf34f7bed2ed34126ecba9db7b62de56c9d7cd136520a0427bfb11b8954ba7ac39b90d4650d3448e31185affcd74226a68f1e94b1108e6e0a4a91cdd83eba\", \"ethaddr\": \"d4584b5f6229b7be90727b0fc8c6b91bb427821f\", \"email\": \"gustav.simonsson@gmail.com\", \"btcaddr\": \"1EVknXyFC68kKNLkh6YnKzW41svSRoaAcx\"}"
  81. ks := NewKeyStorePassphrase(common.DefaultDataDir())
  82. pass := "foo"
  83. _, err := ImportPreSaleKey(ks, []byte(fileContent), pass)
  84. if err != nil {
  85. t.Fatal(err)
  86. }
  87. }
  88. // Test and utils for the key store tests in the Ethereum JSON tests;
  89. // tests/KeyStoreTests/basic_tests.json
  90. type KeyStoreTestV3 struct {
  91. Json encryptedKeyJSONV3
  92. Password string
  93. Priv string
  94. }
  95. type KeyStoreTestV1 struct {
  96. Json encryptedKeyJSONV1
  97. Password string
  98. Priv string
  99. }
  100. func TestV3_PBKDF2_1(t *testing.T) {
  101. tests := loadKeyStoreTestV3("tests/v3_test_vector.json", t)
  102. testDecryptV3(tests["wikipage_test_vector_pbkdf2"], t)
  103. }
  104. func TestV3_PBKDF2_2(t *testing.T) {
  105. tests := loadKeyStoreTestV3("../tests/files/KeyStoreTests/basic_tests.json", t)
  106. testDecryptV3(tests["test1"], t)
  107. }
  108. func TestV3_PBKDF2_3(t *testing.T) {
  109. tests := loadKeyStoreTestV3("../tests/files/KeyStoreTests/basic_tests.json", t)
  110. testDecryptV3(tests["python_generated_test_with_odd_iv"], t)
  111. }
  112. func TestV3_PBKDF2_4(t *testing.T) {
  113. tests := loadKeyStoreTestV3("../tests/files/KeyStoreTests/basic_tests.json", t)
  114. testDecryptV3(tests["evilnonce"], t)
  115. }
  116. func TestV3_Scrypt_1(t *testing.T) {
  117. tests := loadKeyStoreTestV3("tests/v3_test_vector.json", t)
  118. testDecryptV3(tests["wikipage_test_vector_scrypt"], t)
  119. }
  120. func TestV3_Scrypt_2(t *testing.T) {
  121. tests := loadKeyStoreTestV3("../tests/files/KeyStoreTests/basic_tests.json", t)
  122. testDecryptV3(tests["test2"], t)
  123. }
  124. func TestV1_1(t *testing.T) {
  125. tests := loadKeyStoreTestV1("tests/v1_test_vector.json", t)
  126. testDecryptV1(tests["test1"], t)
  127. }
  128. func TestV1_2(t *testing.T) {
  129. ks := NewKeyStorePassphrase("tests/v1")
  130. addr := common.HexToAddress("cb61d5a9c4896fb9658090b597ef0e7be6f7b67e")
  131. k, err := ks.GetKey(addr, "g")
  132. if err != nil {
  133. t.Fatal(err)
  134. }
  135. if k.Address != addr {
  136. t.Fatal(fmt.Errorf("Unexpected address: %v, expected %v", k.Address, addr))
  137. }
  138. privHex := hex.EncodeToString(FromECDSA(k.PrivateKey))
  139. expectedHex := "d1b1178d3529626a1a93e073f65028370d14c7eb0936eb42abef05db6f37ad7d"
  140. if privHex != expectedHex {
  141. t.Fatal(fmt.Errorf("Unexpected privkey: %v, expected %v", privHex, expectedHex))
  142. }
  143. }
  144. func testDecryptV3(test KeyStoreTestV3, t *testing.T) {
  145. privBytes, _, err := decryptKeyV3(&test.Json, test.Password)
  146. if err != nil {
  147. t.Fatal(err)
  148. }
  149. privHex := hex.EncodeToString(privBytes)
  150. if test.Priv != privHex {
  151. t.Fatal(fmt.Errorf("Decrypted bytes not equal to test, expected %v have %v", test.Priv, privHex))
  152. }
  153. }
  154. func testDecryptV1(test KeyStoreTestV1, t *testing.T) {
  155. privBytes, _, err := decryptKeyV1(&test.Json, test.Password)
  156. if err != nil {
  157. t.Fatal(err)
  158. }
  159. privHex := hex.EncodeToString(privBytes)
  160. if test.Priv != privHex {
  161. t.Fatal(fmt.Errorf("Decrypted bytes not equal to test, expected %v have %v", test.Priv, privHex))
  162. }
  163. }
  164. func loadKeyStoreTestV3(file string, t *testing.T) map[string]KeyStoreTestV3 {
  165. tests := make(map[string]KeyStoreTestV3)
  166. err := common.LoadJSON(file, &tests)
  167. if err != nil {
  168. t.Fatal(err)
  169. }
  170. return tests
  171. }
  172. func loadKeyStoreTestV1(file string, t *testing.T) map[string]KeyStoreTestV1 {
  173. tests := make(map[string]KeyStoreTestV1)
  174. err := common.LoadJSON(file, &tests)
  175. if err != nil {
  176. t.Fatal(err)
  177. }
  178. return tests
  179. }