logos-storage-nim/tests/codex/slots/backends/testcircomcompat.nim
Dmitriy Ryajov e25a4e7e1b
wip
2025-03-05 10:25:26 -06:00

147 lines
3.9 KiB
Nim

import std/options
import ../../../asynctest
import pkg/chronos
import pkg/poseidon2
import pkg/serde/json
import pkg/codex/slots {.all.}
import pkg/codex/slots/types {.all.}
import pkg/codex/merkletree
import pkg/codex/codextypes
import pkg/codex/manifest
import pkg/codex/stores
import ./helpers
import ../helpers
import ../../helpers
# suite "Test Circom Compat Backend - control inputs":
# let
# r1cs = "tests/circuits/fixtures/proof_main.r1cs"
# wasm = "tests/circuits/fixtures/proof_main.wasm"
# zkey = "tests/circuits/fixtures/proof_main.zkey"
# var
# circom: CircomCompat
# proofInputs: ProofInputs[Poseidon2Hash]
# taskpool: Taskpool
# setup:
# let
# inputData = readFile("tests/circuits/fixtures/input.json")
# inputJson = !JsonNode.parse(inputData)
# taskpool = Taskpool.new()
# proofInputs = Poseidon2Hash.jsonToProofInput(inputJson)
# circom = CircomCompat.init(r1cs, wasm, zkey, taskpool = taskpool)
# teardown:
# circom.release() # this comes from the rust FFI
# taskpool.shutdown()
# test "Should verify with correct inputs":
# let proof = (await circom.prove(proofInputs)).tryGet
# var resp = (await circom.verify(proof, proofInputs)).tryGet
# check resp
# test "Should not verify with incorrect inputs":
# proofInputs.slotIndex = 1 # change slot index
# let proof = (await circom.prove(proofInputs)).tryGet
# var resp = (await circom.verify(proof, proofInputs)).tryGet
# check resp == false
suite "Test Circom Compat Backend - full flow":
let
ecK = 2
ecM = 2
slotId = 3
samples = 5
numDatasetBlocks = 8
blockSize = DefaultBlockSize
cellSize = DefaultCellSize
r1cs = "tests/circuits/fixtures/proof_main.r1cs"
wasm = "tests/circuits/fixtures/proof_main.wasm"
zkey = "tests/circuits/fixtures/proof_main.zkey"
repoTmp = TempLevelDb.new()
metaTmp = TempLevelDb.new()
var
store: BlockStore
manifest: Manifest
protected: Manifest
verifiable: Manifest
circom: CircomCompat
proofInputs: ProofInputs[Poseidon2Hash]
challenge: array[32, byte]
builder: Poseidon2Builder
sampler: Poseidon2Sampler
taskpool: Taskpool
setup:
let
repoDs = repoTmp.newDb()
metaDs = metaTmp.newDb()
store = RepoStore.new(repoDs, metaDs)
(manifest, protected, verifiable) = await createVerifiableManifest(
store, numDatasetBlocks, ecK, ecM, blockSize, cellSize
)
builder = Poseidon2Builder.new(store, verifiable).tryGet
sampler = Poseidon2Sampler.new(slotId, store, builder).tryGet
taskpool = Taskpool.new()
circom = CircomCompat.init(r1cs, wasm, zkey, taskpool = taskpool)
challenge = 1234567.toF.toBytes.toArray32
proofInputs = (await sampler.getProofInput(challenge, samples)).tryGet
teardown:
circom.release() # this comes from the rust FFI
await repoTmp.destroyDb()
await metaTmp.destroyDb()
taskpool.shutdown()
# test "Should verify with correct input":
# var proof = (await circom.prove(proofInputs)).tryGet
# var resp = (await circom.verify(proof, proofInputs)).tryGet
# check resp == true
# test "Should not verify with incorrect input":
# proofInputs.slotIndex = 1 # change slot index
# let proof = (await circom.prove(proofInputs)).tryGet
# var resp = (await circom.verify(proof, proofInputs)).tryGet
# check resp == false
test "Should concurrently prove/verify":
var proveTasks = newSeq[Future[?!CircomProof]]()
var verifyTasks = newSeq[Future[?!bool]]()
for i in 0 ..< 5:
proveTasks.add(circom.prove(proofInputs))
let proveResults = await allFinished(proveTasks)
for i in 0 ..< 5:
var proof = proveTasks[i].read().tryGet()
verifyTasks.add(circom.verify(proof, proofInputs))
let verifyResults = await allFinished(verifyTasks)
for i in 0 ..< 5:
check:
verifyResults[i].read().tryGet() == true