github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/accounts/keystore/keystore_passphrase_test.go (about)

     1  
     2  //此源码被清华学神尹成大魔王专业翻译分析并修改
     3  //尹成QQ77025077
     4  //尹成微信18510341407
     5  //尹成所在QQ群721929980
     6  //尹成邮箱 yinc13@mails.tsinghua.edu.cn
     7  //尹成毕业于清华大学,微软区块链领域全球最有价值专家
     8  //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620
     9  //版权所有2016 Go Ethereum作者
    10  //此文件是Go以太坊库的一部分。
    11  //
    12  //Go-Ethereum库是免费软件:您可以重新分发它和/或修改
    13  //根据GNU发布的较低通用公共许可证的条款
    14  //自由软件基金会,或者许可证的第3版,或者
    15  //(由您选择)任何更高版本。
    16  //
    17  //Go以太坊图书馆的发行目的是希望它会有用,
    18  //但没有任何保证;甚至没有
    19  //适销性或特定用途的适用性。见
    20  //GNU较低的通用公共许可证,了解更多详细信息。
    21  //
    22  //你应该收到一份GNU较低级别的公共许可证副本
    23  //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。
    24  
    25  package keystore
    26  
    27  import (
    28  	"io/ioutil"
    29  	"testing"
    30  
    31  	"github.com/ethereum/go-ethereum/common"
    32  )
    33  
    34  const (
    35  	veryLightScryptN = 2
    36  	veryLightScryptP = 1
    37  )
    38  
    39  //测试JSON密钥文件是否可以在多轮中解密和加密。
    40  func TestKeyEncryptDecrypt(t *testing.T) {
    41  	keyjson, err := ioutil.ReadFile("testdata/very-light-scrypt.json")
    42  	if err != nil {
    43  		t.Fatal(err)
    44  	}
    45  	password := ""
    46  	address := common.HexToAddress("45dea0fb0bba44f4fcf290bba71fd57d7117cbb8")
    47  
    48  //做几轮解密和加密
    49  	for i := 0; i < 3; i++ {
    50  //先尝试一个错误的密码
    51  		if _, err := DecryptKey(keyjson, password+"bad"); err == nil {
    52  			t.Errorf("test %d: json key decrypted with bad password", i)
    53  		}
    54  //用正确的密码解密
    55  		key, err := DecryptKey(keyjson, password)
    56  		if err != nil {
    57  			t.Fatalf("test %d: json key failed to decrypt: %v", i, err)
    58  		}
    59  		if key.Address != address {
    60  			t.Errorf("test %d: key address mismatch: have %x, want %x", i, key.Address, address)
    61  		}
    62  //用新密码重新加密并重新开始
    63  		password += "new data appended"
    64  		if keyjson, err = EncryptKey(key, password, veryLightScryptN, veryLightScryptP); err != nil {
    65  			t.Errorf("test %d: failed to recrypt key %v", i, err)
    66  		}
    67  	}
    68  }