Updates proof checking test to match new format

This commit is contained in:
benbierens 2023-11-27 16:37:50 +01:00 committed by Dmitriy Ryajov
parent a4cafa6317
commit b4654ff938
No known key found for this signature in database
GPG Key ID: DA8C680CE7C657A4
3 changed files with 36 additions and 28 deletions

View File

@ -146,7 +146,7 @@ proc getProofInput*(self: DataSampler, challenge: FieldElement, nSamples: int):
var
slotToBlockProofs: seq[MerkleProof]
blockToCellProofs: seq[MerkleProof]
sampleData: seq[byte]
samples: seq[ProofSample]
let slotCellIndices = self.findSlotCellIndices(challenge, nSamples)
@ -175,7 +175,14 @@ proc getProofInput*(self: DataSampler, challenge: FieldElement, nSamples: int):
blockToCellProofs.add(cellProof)
let cell = self.getCellFromBlock(blk, slotCellIndex)
sampleData = sampleData & cell
proc combine(bottom: MerkleProof, top: MerkleProof): MerkleProof =
return bottom
samples.add(ProofSample(
cellData: cell,
merkleProof: combine(cellProof, blockProof)
))
trace "Successfully collected proof input"
success(ProofInput(
@ -186,9 +193,5 @@ proc getProofInput*(self: DataSampler, challenge: FieldElement, nSamples: int):
datasetSlotIndex: self.datasetSlotIndex,
slotRoot: self.slotRootHash,
datasetToSlotProof: self.datasetToSlotProof,
#proofSamples: yeah!
# slotToBlockProofs: slotToBlockProofs,
# blockToCellProofs: blockToCellProofs,
# sampleData: sampleData
proofSamples: samples
))

View File

@ -272,16 +272,15 @@ asyncchecksuite "Test proof datasampler - main":
nSamples = 3
input = (await dataSampler.getProofInput(challenge, nSamples)).tryget()
proc equal(a: FieldElement, b: FieldElement): bool =
a.toDecimal() == b.toDecimal()
proc toStr(proof: MerkleProof): string =
toHex(proof.nodesBuffer)
let
expectedSlotToBlockProofs = getExpectedSlotToBlockProofs()
expectedBlockToCellProofs = getExpectedBlockToCellProofs()
expectedSampleData = getExpectedSampleData()
proc equal(a: FieldElement, b: FieldElement): bool =
a.toDecimal() == b.toDecimal()
expectedMerkleProofs = getExpectedSlotToBlockProofs()
expectedCellData = getExpectedCellData()
check:
# datasetRoot*: FieldElement
@ -299,9 +298,13 @@ asyncchecksuite "Test proof datasampler - main":
# datasetToSlotProof*: MerkleProof
input.datasetToSlotProof == datasetToSlotProof
# proofSamples*: seq[ProofSample]
# yeah
toStr(input.proofSamples[0].merkleProof) == expectedMerkleProofs[0]
toStr(input.proofSamples[1].merkleProof) == expectedMerkleProofs[1]
toStr(input.proofSamples[2].merkleProof) == expectedMerkleProofs[2]
# cell data
toHex(input.proofSamples[0].cellData) == expectedCellData[0]
toHex(input.proofSamples[1].cellData) == expectedCellData[1]
toHex(input.proofSamples[2].cellData) == expectedCellData[2]
# input.slotToBlockProofs.mapIt(toStr(it)) == expectedSlotToBlockProofs
# input.blockToCellProofs.mapIt(toStr(it)) == expectedBlockToCellProofs

View File

@ -3,21 +3,23 @@
import std/strutils
import pkg/codex/proof/types
# proc getExpectedBlockToCellProofs*(): seq[string] =
# @[
# "43AAA4A0B89548E8694C5C266BEBCC7BD0758F25005E606EDF559536D2227A7261CD0E8636D0CA8B899A070ABA5D9F815C6678877FAF71B984F5CF15300357E1C4C4A35D47EB0BECF6FB31E6C33CDB8A04D7EA0B29C2021678361F27CFBC96B355B36B13CC749463F14A7A0452A2F765E5951547B16CFB53D3824888226EE5D7FDB433239D7F55029C2C97C635A6B1214D1257C7D85C1C649758BA1AF8700E24",
# "F5D40D9722D943D936AF8EFDE070C5E5D8BD0EC57A89F7BF0AA864DCD8BC77D9D8BC10DDDEB897A82318994242DCF2E07BC631B063DD6F9D4D13133FDED2127DC5840256978CA55F93AF0D6C730660813CF6A29C9B0C0153C8E01D152196A03E94AF1258C023CC638A060314259FA97B5CB743CBCE7AA483839BEA37DB71DF97C4F0DD83C0F38D791C75A1406EC9CFC212E7B302508CDD5780728B55CD5F132E",
# "BB4E5BB9F2E0E104F04E2F49D8D39A9259C1419252A0B1150D9F0FE077A2A2258F594C0DC1A29099A3E3AAEB21C0BF00823383FC06F8A09C25462FC2DA11D51EAD968AA8200FBEA0A62FA1F83A46B3EA5D24859FF028351BEB15EA4D94F987D0CCD48366D7038EF9B0BD35FE287E111DB85A19F0E82E93CB9D40423776164D72332992C2849E7EF3AC7685A8DB37F3C44EFF9366BFE3F5FD80AF2B047C62E4A0"
# ]
proc getExpectedSlotToBlockProofs*(): seq[string] =
@[
"6ABAF89654125BBA9B99CA2635D605167D27D89641CE7E4ECF4F08E898C669B8DB784CEC822621E2DCB502F0135D48FEBACB228379FAC5ED295ED9F7A369107C",
"AD85DD1D1A218A253DAF27CC7874E63C162838C7F8D676F0689212D7C3A5E2EADB784CEC822621E2DCB502F0135D48FEBACB228379FAC5ED295ED9F7A369107C",
"BB8629AA6FF8B5818A2A3C260CB3F028E5E61DC9819DD415B168194736E23229B77FD63AEB6A517F5AE514C8A9CCBAFED5500E595572018ECC9C4205F06140E8"
"9863C3BE0A21CC49A03E3E7B4A134CBBE1F7A241EB61BFAE7478080A4B84E338EC99F9EE1D95A2F6126CE5FD7476E85790A95E03F4D9B63B827854CFF55F1E5236CA91969A70839AF19329616627803B29EA52185FFA8AE50FCC84C0BA8C69C4BA43F4397D2D50DD2982EDC3AF08E4762F34958645DC4749265DA9FC89874A86FFCEAB3B21F48386C75FCDA49656FE73F15C0E4AEE84479A880CA74817861A93",
"1F6B7B8B46ACE123F53BBFBF96999B7EED1A4F07D2BA2831AF8855B312260D39D4E9996BD5F7FD83E293168DEC32B57AD08A54D38A748DD46FD21D2685A194087237F6493DD03FBA989C356E9BD35CF1E833E66E6FF06C212FF5FCB603E59AA762A338CE5CE3BD68D68E4A4A6C799FF935F3829085C86E07A12B27278E7A5AAD77CDFAD51D9B8B13C44646E01450D2140924211CBE62520B7C4916C4E4C955F5",
"F2972FCDA69A1FF6B71BD487618FF1AB871C4D4861724F1B01574E414EB3C1D761CD0E8636D0CA8B899A070ABA5D9F815C6678877FAF71B984F5CF15300357E1C4C4A35D47EB0BECF6FB31E6C33CDB8A04D7EA0B29C2021678361F27CFBC96B355B36B13CC749463F14A7A0452A2F765E5951547B16CFB53D3824888226EE5D7FDB433239D7F55029C2C97C635A6B1214D1257C7D85C1C649758BA1AF8700E24"
]
proc getExpectedBlockToCellProofs*(): seq[string] =
proc getExpectedCellData*(): seq[string] =
@[
"43AAA4A0B89548E8694C5C266BEBCC7BD0758F25005E606EDF559536D2227A7261CD0E8636D0CA8B899A070ABA5D9F815C6678877FAF71B984F5CF15300357E1C4C4A35D47EB0BECF6FB31E6C33CDB8A04D7EA0B29C2021678361F27CFBC96B355B36B13CC749463F14A7A0452A2F765E5951547B16CFB53D3824888226EE5D7FDB433239D7F55029C2C97C635A6B1214D1257C7D85C1C649758BA1AF8700E24",
"F5D40D9722D943D936AF8EFDE070C5E5D8BD0EC57A89F7BF0AA864DCD8BC77D9D8BC10DDDEB897A82318994242DCF2E07BC631B063DD6F9D4D13133FDED2127DC5840256978CA55F93AF0D6C730660813CF6A29C9B0C0153C8E01D152196A03E94AF1258C023CC638A060314259FA97B5CB743CBCE7AA483839BEA37DB71DF97C4F0DD83C0F38D791C75A1406EC9CFC212E7B302508CDD5780728B55CD5F132E",
"BB4E5BB9F2E0E104F04E2F49D8D39A9259C1419252A0B1150D9F0FE077A2A2258F594C0DC1A29099A3E3AAEB21C0BF00823383FC06F8A09C25462FC2DA11D51EAD968AA8200FBEA0A62FA1F83A46B3EA5D24859FF028351BEB15EA4D94F987D0CCD48366D7038EF9B0BD35FE287E111DB85A19F0E82E93CB9D40423776164D72332992C2849E7EF3AC7685A8DB37F3C44EFF9366BFE3F5FD80AF2B047C62E4A0"
"CA".repeat(CellSize),
"A9".repeat(CellSize),
"B3".repeat(CellSize)
]
proc getExpectedSampleData*(): string =
"B2".repeat(CellSize) &
"95".repeat(CellSize) &
"EE".repeat(CellSize)