* crypto/bn256: full switchover to cloudflare's code * crypto/bn256: only use cloudflare for optimized architectures * crypto/bn256: upstream fallback for non-optimized code * .travis, build: drop support for Go 1.8 (need type aliases) * crypto/bn256/cloudflare: enable curve mul lattice optimization
		
			
				
	
	
		
			30 lines
		
	
	
		
			731 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			731 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package bn256
 | |
| 
 | |
| import (
 | |
| 	"crypto/rand"
 | |
| 
 | |
| 	"testing"
 | |
| )
 | |
| 
 | |
| func TestLatticeReduceCurve(t *testing.T) {
 | |
| 	k, _ := rand.Int(rand.Reader, Order)
 | |
| 	ks := curveLattice.decompose(k)
 | |
| 
 | |
| 	if ks[0].BitLen() > 130 || ks[1].BitLen() > 130 {
 | |
| 		t.Fatal("reduction too large")
 | |
| 	} else if ks[0].Sign() < 0 || ks[1].Sign() < 0 {
 | |
| 		t.Fatal("reduction must be positive")
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestLatticeReduceTarget(t *testing.T) {
 | |
| 	k, _ := rand.Int(rand.Reader, Order)
 | |
| 	ks := targetLattice.decompose(k)
 | |
| 
 | |
| 	if ks[0].BitLen() > 66 || ks[1].BitLen() > 66 || ks[2].BitLen() > 66 || ks[3].BitLen() > 66 {
 | |
| 		t.Fatal("reduction too large")
 | |
| 	} else if ks[0].Sign() < 0 || ks[1].Sign() < 0 || ks[2].Sign() < 0 || ks[3].Sign() < 0 {
 | |
| 		t.Fatal("reduction must be positive")
 | |
| 	}
 | |
| }
 |