// 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. //go:build amd64 || arm64 || ppc64le || s390x package nistec import ( "fmt" "testing" ) func TestP256PrecomputedTable(t *testing.T) { base := NewP256Point().SetGenerator() for i := 0; i < 43; i++ { t.Run(fmt.Sprintf("table[%d]", i), func(t *testing.T) { testP256AffineTable(t, base, &p256Precomputed[i]) }) for k := 0; k < 6; k++ { base.Double(base) } } } func testP256AffineTable(t *testing.T, base *P256Point, table *p256AffineTable) { p := NewP256Point() zInv := new(p256Element) zInvSq := new(p256Element) for j := 0; j < 32; j++ { p.Add(p, base) // Convert p to affine coordinates. p256Inverse(zInv, &p.z) p256Sqr(zInvSq, zInv, 1) p256Mul(zInv, zInv, zInvSq) p256Mul(&p.x, &p.x, zInvSq) p256Mul(&p.y, &p.y, zInv) p.z = p256One if p256Equal(&table[j].x, &p.x) != 1 || p256Equal(&table[j].y, &p.y) != 1 { t.Fatalf("incorrect table entry at index %d", j) } } }