inital commit for edwards25519
This commit is contained in:
50
field/fe_extra_test.go
Normal file
50
field/fe_extra_test.go
Normal file
@@ -0,0 +1,50 @@
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Source: https://sources.truenas.cloud/code
|
||||
// Import: sources.truenas.cloud/code/edwards25519/field
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Copyright (c) 2019 The Go Authors. All rights Reserved.
|
||||
// Use of this source code is goverened by a BSD-style
|
||||
// license that can be found in the LICENSE file.
|
||||
//
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
package field
|
||||
|
||||
import (
|
||||
"math/big"
|
||||
"testing"
|
||||
"testing/quick"
|
||||
)
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
var bigP = new(big.Int).Sub(new(big.Int).Lsh(big.NewInt(1), 255), big.NewInt(19))
|
||||
|
||||
func TestSetWideBytes(t *testing.T) {
|
||||
f1 := func(in [64]byte, fe Element) bool {
|
||||
fe1 := new(Element).Set(&fe)
|
||||
|
||||
if out, err := fe.SetWideBytes([]byte{42}); err == nil || out != nil ||
|
||||
fe.Equal(fe1) != 1 {
|
||||
return false
|
||||
}
|
||||
|
||||
if out, err := fe.SetWideBytes(in[:]); err != nil || out != &fe {
|
||||
return false
|
||||
}
|
||||
|
||||
b := new(big.Int).SetBytes(swapEndianness(in[:]))
|
||||
fe1.fromBig(b.Mod(b, bigP))
|
||||
|
||||
return fe.Equal(fe1) == 1 && isInBounds(&fe) && isInBounds(fe1)
|
||||
}
|
||||
if err := quick.Check(f1, nil); err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
Reference in New Issue
Block a user