|
|
package schnorr
import ( "math/big" "testing"
"github.com/arnaucube/cryptofun/ecc" "github.com/stretchr/testify/assert" )
func TestHash(t *testing.T) { c := ecc.Point{big.NewInt(int64(7)), big.NewInt(int64(8))} // Generator
h := Hash([]byte("hola"), c) assert.Equal(t, h.String(), "34719153732582497359642109898768696927847420320548121616059449972754491425079") }
func TestSign(t *testing.T) { ec := ecc.NewEC(big.NewInt(int64(0)), big.NewInt(int64(7)), big.NewInt(int64(11))) g := ecc.Point{big.NewInt(int64(7)), big.NewInt(int64(8))} // Generator
r := big.NewInt(int64(7)) // random r
schnorr, sk, err := Gen(ec, g, r) assert.Nil(t, err)
m := []byte("hola")
s, rPoint, err := schnorr.Sign(sk, m) assert.Nil(t, err)
verified, err := Verify(schnorr.EC, sk.PubK, m, s, rPoint) assert.Nil(t, err)
assert.True(t, verified) }
func TestSign2(t *testing.T) { ec := ecc.NewEC(big.NewInt(int64(0)), big.NewInt(int64(7)), big.NewInt(int64(29))) g := ecc.Point{big.NewInt(int64(11)), big.NewInt(int64(27))} // Generator
r := big.NewInt(int64(23)) // random r
schnorr, sk, err := Gen(ec, g, r) assert.Nil(t, err)
m := []byte("hola")
s, rPoint, err := schnorr.Sign(sk, m) assert.Nil(t, err)
verified, err := Verify(schnorr.EC, sk.PubK, m, s, rPoint) assert.Nil(t, err)
assert.True(t, verified) }
|