%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/local/go/src/crypto/elliptic/internal/fiat/
Upload File :
Create Path :
Current File : //usr/local/go/src/crypto/elliptic/internal/fiat/p521_test.go

// Copyright 2021 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

package fiat_test

import (
	"crypto/elliptic/internal/fiat"
	"crypto/rand"
	"testing"
)

func p521Random(t *testing.T) *fiat.P521Element {
	buf := make([]byte, 66)
	if _, err := rand.Read(buf); err != nil {
		t.Fatal(err)
	}
	buf[65] &= 1
	e, err := new(fiat.P521Element).SetBytes(buf)
	if err != nil {
		t.Fatal(err)
	}
	return e
}

func TestP521Invert(t *testing.T) {
	a := p521Random(t)
	inv := new(fiat.P521Element).Invert(a)
	one := new(fiat.P521Element).Mul(a, inv)
	if new(fiat.P521Element).One().Equal(one) != 1 {
		t.Errorf("a * 1/a != 1; got %x for %x", one.Bytes(), a.Bytes())
	}
	inv.Invert(new(fiat.P521Element))
	if new(fiat.P521Element).Equal(inv) != 1 {
		t.Errorf("1/0 != 0; got %x", inv.Bytes())
	}
}

Zerion Mini Shell 1.0