|
|
package verifier
import ( "io/ioutil" "testing"
"github.com/iden3/go-circom-prover-verifier/parsers"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" )
func TestVerify(t *testing.T) { testVerifyCircuit(t, "circuit1k") testVerifyCircuit(t, "circuit5k") // testVerifyCircuit(t, "circuit10k")
// testVerifyCircuit(t, "circuit20k")
}
func testVerifyCircuit(t *testing.T, circuit string) { proofJson, err := ioutil.ReadFile("../testdata/" + circuit + "/proof.json") require.Nil(t, err) vkJson, err := ioutil.ReadFile("../testdata/" + circuit + "/verification_key.json") require.Nil(t, err) publicJson, err := ioutil.ReadFile("../testdata/" + circuit + "/public.json") require.Nil(t, err)
public, err := parsers.ParsePublicSignals(publicJson) require.Nil(t, err) proof, err := parsers.ParseProof(proofJson) require.Nil(t, err) vk, err := parsers.ParseVk(vkJson) require.Nil(t, err)
v := Verify(vk, proof, public) assert.True(t, v)
// Verify again to check that `Verify` hasn't mutated the inputs
v = Verify(vk, proof, public) assert.True(t, v) }
func BenchmarkVerify(b *testing.B) { // benchmark with circuit2 (10000 constraints)
proofJson, err := ioutil.ReadFile("../testdata/circuit2/proof.json") require.Nil(b, err) vkJson, err := ioutil.ReadFile("../testdata/circuit2/verification_key.json") require.Nil(b, err) publicJson, err := ioutil.ReadFile("../testdata/circuit2/public.json") require.Nil(b, err)
public, err := parsers.ParsePublicSignals(publicJson) require.Nil(b, err) proof, err := parsers.ParseProof(proofJson) require.Nil(b, err) vk, err := parsers.ParseVk(vkJson) require.Nil(b, err)
for i := 0; i < b.N; i++ { Verify(vk, proof, public) } }
|