2019-08-27 16:29:42 +03:00
|
|
|
package keys
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2020-03-03 17:21:42 +03:00
|
|
|
"github.com/nspcc-dev/neo-go/pkg/crypto/hash"
|
2019-08-27 16:29:42 +03:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2019-08-27 17:06:32 +03:00
|
|
|
func TestPubKeyVerify(t *testing.T) {
|
|
|
|
var data = []byte("sample")
|
2019-08-27 16:29:42 +03:00
|
|
|
hashedData := hash.Sha256(data)
|
|
|
|
|
|
|
|
privKey, err := NewPrivateKey()
|
2019-08-27 17:06:32 +03:00
|
|
|
assert.Nil(t, err)
|
2020-01-16 18:30:16 +03:00
|
|
|
signedData := privKey.Sign(data)
|
2019-09-05 09:35:02 +03:00
|
|
|
pubKey := privKey.PublicKey()
|
2019-11-27 12:23:18 +03:00
|
|
|
result := pubKey.Verify(signedData, hashedData.BytesBE())
|
2019-08-27 16:29:42 +03:00
|
|
|
expected := true
|
2019-08-27 17:06:32 +03:00
|
|
|
assert.Equal(t, expected, result)
|
2019-11-24 18:40:07 +03:00
|
|
|
|
|
|
|
pubKey = &PublicKey{}
|
2019-11-27 12:23:18 +03:00
|
|
|
assert.False(t, pubKey.Verify(signedData, hashedData.BytesBE()))
|
2019-08-27 16:29:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestWrongPubKey(t *testing.T) {
|
|
|
|
privKey, _ := NewPrivateKey()
|
|
|
|
sample := []byte("sample")
|
|
|
|
hashedData := hash.Sha256(sample)
|
2020-01-16 18:30:16 +03:00
|
|
|
signedData := privKey.Sign(sample)
|
2019-08-27 16:29:42 +03:00
|
|
|
|
|
|
|
secondPrivKey, _ := NewPrivateKey()
|
2019-09-05 09:35:02 +03:00
|
|
|
wrongPubKey := secondPrivKey.PublicKey()
|
2019-08-27 16:29:42 +03:00
|
|
|
|
2019-11-27 12:23:18 +03:00
|
|
|
actual := wrongPubKey.Verify(signedData, hashedData.BytesBE())
|
2019-08-27 16:29:42 +03:00
|
|
|
expcted := false
|
|
|
|
assert.Equal(t, expcted, actual)
|
|
|
|
}
|