forked from TrueCloudLab/neoneo-go
Merge pull request #516 from nspcc-dev/feat/crypto_invalid
crypto: add more test for error cases
This commit is contained in:
commit
821c9b2851
8 changed files with 123 additions and 7 deletions
|
@ -1,10 +1,12 @@
|
||||||
package hash
|
package hash
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/binary"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSha256(t *testing.T) {
|
func TestSha256(t *testing.T) {
|
||||||
|
@ -47,3 +49,18 @@ func TestHash160(t *testing.T) {
|
||||||
actual := hex.EncodeToString(data.Bytes())
|
actual := hex.EncodeToString(data.Bytes())
|
||||||
assert.Equal(t, expected, actual)
|
assert.Equal(t, expected, actual)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestChecksum(t *testing.T) {
|
||||||
|
testCases := []struct {
|
||||||
|
data []byte
|
||||||
|
sum uint32
|
||||||
|
}{
|
||||||
|
{nil, 0xe2e0f65d},
|
||||||
|
{[]byte{}, 0xe2e0f65d},
|
||||||
|
{[]byte{1, 2, 3, 4}, 0xe272e48d},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tc := range testCases {
|
||||||
|
require.Equal(t, tc.sum, binary.LittleEndian.Uint32(Checksum(tc.data)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -11,6 +11,11 @@ func TestNEP2Encrypt(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
|
|
||||||
privKey, err := NewPrivateKeyFromHex(testCase.PrivateKey)
|
privKey, err := NewPrivateKeyFromHex(testCase.PrivateKey)
|
||||||
|
if testCase.Invalid {
|
||||||
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
|
|
||||||
encryptedWif, err := NEP2Encrypt(privKey, testCase.Passphrase)
|
encryptedWif, err := NEP2Encrypt(privKey, testCase.Passphrase)
|
||||||
|
@ -24,6 +29,11 @@ func TestNEP2Decrypt(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
|
|
||||||
privKeyString, err := NEP2Decrypt(testCase.EncryptedWif, testCase.Passphrase)
|
privKeyString, err := NEP2Decrypt(testCase.EncryptedWif, testCase.Passphrase)
|
||||||
|
if testCase.Invalid {
|
||||||
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
|
|
||||||
privKey, err := NewPrivateKeyFromWIF(privKeyString)
|
privKey, err := NewPrivateKeyFromWIF(privKeyString)
|
||||||
|
|
|
@ -12,6 +12,11 @@ import (
|
||||||
func TestPrivateKey(t *testing.T) {
|
func TestPrivateKey(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
privKey, err := NewPrivateKeyFromHex(testCase.PrivateKey)
|
privKey, err := NewPrivateKeyFromHex(testCase.PrivateKey)
|
||||||
|
if testCase.Invalid {
|
||||||
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
address := privKey.Address()
|
address := privKey.Address()
|
||||||
assert.Equal(t, testCase.Address, address)
|
assert.Equal(t, testCase.Address, address)
|
||||||
|
@ -26,6 +31,11 @@ func TestPrivateKey(t *testing.T) {
|
||||||
func TestPrivateKeyFromWIF(t *testing.T) {
|
func TestPrivateKeyFromWIF(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
key, err := NewPrivateKeyFromWIF(testCase.Wif)
|
key, err := NewPrivateKeyFromWIF(testCase.Wif)
|
||||||
|
if testCase.Invalid {
|
||||||
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.Equal(t, testCase.PrivateKey, key.String())
|
assert.Equal(t, testCase.PrivateKey, key.String())
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,8 @@ package keys
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
|
"math/rand"
|
||||||
|
"sort"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/CityOfZion/neo-go/pkg/io"
|
"github.com/CityOfZion/neo-go/pkg/io"
|
||||||
|
@ -35,6 +37,16 @@ func TestEncodeDecodePublicKey(t *testing.T) {
|
||||||
require.NoError(t, pDecode.DecodeBytes(b))
|
require.NoError(t, pDecode.DecodeBytes(b))
|
||||||
require.Equal(t, p.X, pDecode.X)
|
require.Equal(t, p.X, pDecode.X)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errCases := [][]byte{{}, {0x02}, {0x04}}
|
||||||
|
|
||||||
|
for _, tc := range errCases {
|
||||||
|
r := io.NewBinReaderFromBuf(tc)
|
||||||
|
|
||||||
|
var pDecode PublicKey
|
||||||
|
pDecode.DecodeBinary(r)
|
||||||
|
require.Error(t, r.Err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDecodeFromString(t *testing.T) {
|
func TestDecodeFromString(t *testing.T) {
|
||||||
|
@ -42,6 +54,13 @@ func TestDecodeFromString(t *testing.T) {
|
||||||
pubKey, err := NewPublicKeyFromString(str)
|
pubKey, err := NewPublicKeyFromString(str)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, str, hex.EncodeToString(pubKey.Bytes()))
|
require.Equal(t, str, hex.EncodeToString(pubKey.Bytes()))
|
||||||
|
|
||||||
|
_, err = NewPublicKeyFromString(str[2:])
|
||||||
|
require.Error(t, err)
|
||||||
|
|
||||||
|
str = "zzb209fd4f53a7170ea4444e0cb0a6bb6a53c2bd016926989cf85f9b0fba17a70c"
|
||||||
|
_, err = NewPublicKeyFromString(str)
|
||||||
|
require.Error(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPubkeyToAddress(t *testing.T) {
|
func TestPubkeyToAddress(t *testing.T) {
|
||||||
|
@ -60,6 +79,28 @@ func TestDecodeBytes(t *testing.T) {
|
||||||
require.Equal(t, pubKey,decodedPubKey)
|
require.Equal(t, pubKey,decodedPubKey)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSort(t *testing.T) {
|
||||||
|
pubs1 := make(PublicKeys, 10)
|
||||||
|
for i := range pubs1 {
|
||||||
|
priv, err := NewPrivateKey()
|
||||||
|
require.NoError(t, err)
|
||||||
|
pubs1[i] = priv.PublicKey()
|
||||||
|
}
|
||||||
|
|
||||||
|
pubs2 := make(PublicKeys, len(pubs1))
|
||||||
|
copy(pubs2, pubs1)
|
||||||
|
|
||||||
|
sort.Sort(pubs1)
|
||||||
|
|
||||||
|
rand.Shuffle(len(pubs2), func(i, j int) {
|
||||||
|
pubs2[i], pubs2[j] = pubs2[j], pubs2[i]
|
||||||
|
})
|
||||||
|
sort.Sort(pubs2)
|
||||||
|
|
||||||
|
// Check that sort on the same set of values produce the same result.
|
||||||
|
require.Equal(t, pubs1, pubs2)
|
||||||
|
}
|
||||||
|
|
||||||
func TestContains(t *testing.T) {
|
func TestContains(t *testing.T) {
|
||||||
pubKey := getPubKey(t)
|
pubKey := getPubKey(t)
|
||||||
pubKeys := &PublicKeys{getPubKey(t)}
|
pubKeys := &PublicKeys{getPubKey(t)}
|
||||||
|
|
|
@ -19,6 +19,9 @@ func TestPubKeyVerify(t *testing.T) {
|
||||||
result := pubKey.Verify(signedData, hashedData.Bytes())
|
result := pubKey.Verify(signedData, hashedData.Bytes())
|
||||||
expected := true
|
expected := true
|
||||||
assert.Equal(t, expected, result)
|
assert.Equal(t, expected, result)
|
||||||
|
|
||||||
|
pubKey = &PublicKey{}
|
||||||
|
assert.False(t, pubKey.Verify(signedData, hashedData.Bytes()))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestWrongPubKey(t *testing.T) {
|
func TestWrongPubKey(t *testing.T) {
|
||||||
|
|
|
@ -5,6 +5,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
type wifTestCase struct {
|
type wifTestCase struct {
|
||||||
|
@ -33,6 +34,12 @@ var wifTestCases = []wifTestCase{
|
||||||
privateKey: "2bfe58ab6d9fd575bdc3a624e4825dd2b375d64ac033fbc46ea79dbab4f69a3e",
|
privateKey: "2bfe58ab6d9fd575bdc3a624e4825dd2b375d64ac033fbc46ea79dbab4f69a3e",
|
||||||
version: 0x80,
|
version: 0x80,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
wif: "KxhEDBQyyEFymvfJD96q8stMbJMbZUb6D1PmXqBWZDU2WvbvVs9o",
|
||||||
|
compressed: true,
|
||||||
|
privateKey: "2bfe58ab6d9fd575bdc3a624e4825dd2b375d64ac033fbc46ea79dbab4f69a3e",
|
||||||
|
version: 0x00,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestWIFEncodeDecode(t *testing.T) {
|
func TestWIFEncodeDecode(t *testing.T) {
|
||||||
|
@ -47,6 +54,14 @@ func TestWIFEncodeDecode(t *testing.T) {
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
assert.Equal(t, testCase.privateKey, WIF.PrivateKey.String())
|
assert.Equal(t, testCase.privateKey, WIF.PrivateKey.String())
|
||||||
assert.Equal(t, testCase.compressed, WIF.Compressed)
|
assert.Equal(t, testCase.compressed, WIF.Compressed)
|
||||||
assert.Equal(t, testCase.version, WIF.Version)
|
if testCase.version != 0 {
|
||||||
|
assert.Equal(t, testCase.version, WIF.Version)
|
||||||
|
} else {
|
||||||
|
assert.EqualValues(t, WIFVersion, WIF.Version)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wifInv := []byte{0, 1, 2}
|
||||||
|
_, err := WIFEncode(wifInv, 0, true)
|
||||||
|
require.Error(t, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ type Ktype struct {
|
||||||
Wif,
|
Wif,
|
||||||
Passphrase,
|
Passphrase,
|
||||||
EncryptedWif string
|
EncryptedWif string
|
||||||
|
Invalid bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// Arr contains a set of known keys in Ktype format.
|
// Arr contains a set of known keys in Ktype format.
|
||||||
|
@ -36,4 +37,13 @@ var Arr = []Ktype{
|
||||||
Passphrase: "MyL33tP@33w0rd",
|
Passphrase: "MyL33tP@33w0rd",
|
||||||
EncryptedWif: "6PYNoc1EG5J38MTqGN9Anphfdd6UwbS4cpFCzHhrkSKBBbV1qkbJJZQnkn",
|
EncryptedWif: "6PYNoc1EG5J38MTqGN9Anphfdd6UwbS4cpFCzHhrkSKBBbV1qkbJJZQnkn",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Address: "xdf4UGKevVrMR1j3UkPsuoYKSC4ocoAkKx",
|
||||||
|
PrivateKey: "zzdee7036b8fd9cef91de47386b191dd76db2888a553e7736bb02808932a915b",
|
||||||
|
PublicKey: "zz232ce8d2e2063dce0451131851d47421bfc4fc1da4db116fca5302c0756462fa",
|
||||||
|
Wif: "zzKvWLZsNwBJx5j9nurHYRwhYfdQUu9tTEDsLCUHDbYBL8cHxMiG",
|
||||||
|
Passphrase: "zzL33tP@33w0rd",
|
||||||
|
EncryptedWif: "6PYNoc1EG5J38MTqGN9Anphfdd6UwbS4cpFCzHhrkSKBBbV1qkbJJZQnkn",
|
||||||
|
Invalid: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,14 +5,18 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/CityOfZion/neo-go/pkg/internal/keytestcases"
|
"github.com/CityOfZion/neo-go/pkg/internal/keytestcases"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestNewAccount(t *testing.T) {
|
func TestNewAccount(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
acc, err := NewAccountFromWIF(testCase.Wif)
|
acc, err := NewAccountFromWIF(testCase.Wif)
|
||||||
if err != nil {
|
if testCase.Invalid {
|
||||||
t.Fatal(err)
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert.NoError(t, err)
|
||||||
compareFields(t, testCase, acc)
|
compareFields(t, testCase, acc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,9 +24,12 @@ func TestNewAccount(t *testing.T) {
|
||||||
func TestDecryptAccount(t *testing.T) {
|
func TestDecryptAccount(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
acc, err := DecryptAccount(testCase.EncryptedWif, testCase.Passphrase)
|
acc, err := DecryptAccount(testCase.EncryptedWif, testCase.Passphrase)
|
||||||
if err != nil {
|
if testCase.Invalid {
|
||||||
t.Fatal(err)
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert.NoError(t, err)
|
||||||
compareFields(t, testCase, acc)
|
compareFields(t, testCase, acc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,9 +37,12 @@ func TestDecryptAccount(t *testing.T) {
|
||||||
func TestNewFromWif(t *testing.T) {
|
func TestNewFromWif(t *testing.T) {
|
||||||
for _, testCase := range keytestcases.Arr {
|
for _, testCase := range keytestcases.Arr {
|
||||||
acc, err := NewAccountFromWIF(testCase.Wif)
|
acc, err := NewAccountFromWIF(testCase.Wif)
|
||||||
if err != nil {
|
if testCase.Invalid {
|
||||||
t.Fatal(err)
|
assert.Error(t, err)
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
assert.NoError(t, err)
|
||||||
compareFields(t, testCase, acc)
|
compareFields(t, testCase, acc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue