From f41792c1915766832f69779f9b426fe34a9c773f Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Thu, 16 Feb 2023 11:29:32 -0800 Subject: [PATCH 1/3] fix occasional test failure --- .../test/tokenomics/proofReward.test.ts | 88 ++++++++----------- 1 file changed, 37 insertions(+), 51 deletions(-) diff --git a/packages/protocol/test/tokenomics/proofReward.test.ts b/packages/protocol/test/tokenomics/proofReward.test.ts index 4a34c34d9e0..e9fd36c06b9 100644 --- a/packages/protocol/test/tokenomics/proofReward.test.ts +++ b/packages/protocol/test/tokenomics/proofReward.test.ts @@ -225,64 +225,50 @@ describe("tokenomics: proofReward", function () { await seedTko(provers, tkoTokenL1.connect(l1Signer)); - l2Provider.on("block", blockListener(chan, genesisHeight)); + const blockNumber = genesisHeight + 1; - /* eslint-disable-next-line */ - for await (const blockNumber of chan) { - if ( - blockNumber > - genesisHeight + (config.maxNumBlocks.toNumber() - 1) - ) { - break; - } + const block = await l2Provider.getBlock(blockNumber); - const block = await l2Provider.getBlock(blockNumber); + // commit and propose block, so our provers can prove it. + const { proposedEvent } = await proposer.commitThenProposeBlock(block); - // commit and propose block, so our provers can prove it. - const { proposedEvent } = await proposer.commitThenProposeBlock( - block + // submit a proof for each prover + for (const prover of provers) { + await prover.prove( + proposedEvent.args.id.toNumber(), + blockNumber, + proposedEvent.args.meta as any as BlockMetadata ); + } - // submit a proof for each prover - for (const prover of provers) { - await prover.prove( - proposedEvent.args.id.toNumber(), - blockNumber, - proposedEvent.args.meta as any as BlockMetadata - ); - } + const forkChoice = await taikoL1.getForkChoice( + proposedEvent.args.id.toNumber(), + block.parentHash + ); + expect(forkChoice).not.to.be.undefined; + expect(forkChoice.provers.length).to.be.eq( + config.maxProofsPerForkChoice.toNumber() + ); - const forkChoice = await taikoL1.getForkChoice( - proposedEvent.args.id.toNumber(), - block.parentHash - ); - expect(forkChoice).not.to.be.undefined; - expect(forkChoice.provers.length).to.be.eq( - config.maxProofsPerForkChoice.toNumber() - ); + await sleepUntilBlockIsVerifiable( + taikoL1, + proposedEvent.args.id.toNumber(), + 0 + ); + await verifyBlocks(taikoL1, 1); + + // all provers had same initial TKO balance. + // each prover in order should have less balance than the previous. + for (let i = 0; i < forkChoice.provers.length; i++) { + if (i !== 0) { + const proverBalance = await tkoTokenL1.balanceOf( + forkChoice.provers[i] + ); + const previousProverBalance = await tkoTokenL1.balanceOf( + forkChoice.provers[i - 1] + ); - await sleepUntilBlockIsVerifiable( - taikoL1, - proposedEvent.args.id.toNumber(), - 0 - ); - await verifyBlocks(taikoL1, 1); - - // all provers had same initial TKO balance. - // each prover in order should have less balance than the previous. - for (let i = 0; i < forkChoice.provers.length; i++) { - if (i !== 0) { - const proverBalance = await tkoTokenL1.balanceOf( - forkChoice.provers[i] - ); - const previousProverBalance = await tkoTokenL1.balanceOf( - forkChoice.provers[i - 1] - ); - - expect(previousProverBalance.gt(proverBalance)).to.be.eq( - true - ); - } + expect(previousProverBalance.gt(proverBalance)).to.be.eq(true); } } }); From a213543390fd396a9a2238c44b852dda7be067c2 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Thu, 16 Feb 2023 11:46:07 -0800 Subject: [PATCH 2/3] addtl test --- .../test/L1/TaikoL1.integration.test.ts | 68 ++++++++----------- 1 file changed, 29 insertions(+), 39 deletions(-) diff --git a/packages/protocol/test/L1/TaikoL1.integration.test.ts b/packages/protocol/test/L1/TaikoL1.integration.test.ts index 581d970b99a..a2439dae1e7 100644 --- a/packages/protocol/test/L1/TaikoL1.integration.test.ts +++ b/packages/protocol/test/L1/TaikoL1.integration.test.ts @@ -194,51 +194,41 @@ describe("integration:TaikoL1", function () { await seedTko(provers, tkoTokenL1.connect(l1Signer)); - l2Provider.on("block", blockListener(chan, genesisHeight)); - + const blockNumber = genesisHeight + 1; /* eslint-disable-next-line */ - for await (const blockNumber of chan) { - if ( - blockNumber > - genesisHeight + config.maxNumBlocks.toNumber() - 1 - ) { - break; - } + const block = await l2Provider.getBlock(blockNumber); - const block = await l2Provider.getBlock(blockNumber); - - // commit and propose block, so our provers can prove it. - const { proposedEvent } = await proposer.commitThenProposeBlock( - block - ); + // commit and propose block, so our provers can prove it. + const { proposedEvent } = await proposer.commitThenProposeBlock( + block + ); - await provers[0].prove( - proposedEvent.args.id.toNumber(), - blockNumber, - proposedEvent.args.meta as any as BlockMetadata - ); + await provers[0].prove( + proposedEvent.args.id.toNumber(), + blockNumber, + proposedEvent.args.meta as any as BlockMetadata + ); - let forkChoice = await taikoL1.getForkChoice( - proposedEvent.args.id.toNumber(), - block.parentHash - ); - expect(forkChoice).not.to.be.undefined; - expect(forkChoice.provers.length).to.be.eq(1); + let forkChoice = await taikoL1.getForkChoice( + proposedEvent.args.id.toNumber(), + block.parentHash + ); + expect(forkChoice).not.to.be.undefined; + expect(forkChoice.provers.length).to.be.eq(1); - await sleepUntilBlockIsVerifiable( - taikoL1, - proposedEvent.args.id.toNumber(), - 0 - ); - const verifiedEvent = await verifyBlocks(taikoL1, 1); - expect(verifiedEvent).not.to.be.undefined; + await sleepUntilBlockIsVerifiable( + taikoL1, + proposedEvent.args.id.toNumber(), + 0 + ); + const verifiedEvent = await verifyBlocks(taikoL1, 1); + expect(verifiedEvent).not.to.be.undefined; - forkChoice = await taikoL1.getForkChoice( - proposedEvent.args.id.toNumber(), - block.parentHash - ); - expect(forkChoice.provers.length).to.be.eq(0); - } + forkChoice = await taikoL1.getForkChoice( + proposedEvent.args.id.toNumber(), + block.parentHash + ); + expect(forkChoice.provers.length).to.be.eq(0); }); }); From 976d9607bdf38a9f4a4f90ff417f6ff3e35bb864 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Thu, 16 Feb 2023 12:27:03 -0800 Subject: [PATCH 3/3] unnecessary provers array for test --- .../protocol/test/L1/TaikoL1.integration.test.ts | 14 +++----------- 1 file changed, 3 insertions(+), 11 deletions(-) diff --git a/packages/protocol/test/L1/TaikoL1.integration.test.ts b/packages/protocol/test/L1/TaikoL1.integration.test.ts index a2439dae1e7..7ada5c16fa4 100644 --- a/packages/protocol/test/L1/TaikoL1.integration.test.ts +++ b/packages/protocol/test/L1/TaikoL1.integration.test.ts @@ -17,11 +17,7 @@ import { buildProposeBlockInputs } from "../utils/propose"; import Proposer from "../utils/proposer"; import { buildProveBlockInputs, proveBlock } from "../utils/prove"; import Prover from "../utils/prover"; -import { - createAndSeedWallets, - seedTko, - sendTinyEtherToZeroAddress, -} from "../utils/seed"; +import { seedTko, sendTinyEtherToZeroAddress } from "../utils/seed"; import { commitProposeProveAndVerify, sleepUntilBlockIsVerifiable, @@ -188,11 +184,7 @@ describe("integration:TaikoL1", function () { }); it("returns empty after a block is verified", async function () { - const provers = (await createAndSeedWallets(2, l1Signer)).map( - (p: ethersLib.Wallet) => new Prover(taikoL1, l2Provider, p) - ); - - await seedTko(provers, tkoTokenL1.connect(l1Signer)); + await seedTko([prover], tkoTokenL1.connect(l1Signer)); const blockNumber = genesisHeight + 1; /* eslint-disable-next-line */ @@ -203,7 +195,7 @@ describe("integration:TaikoL1", function () { block ); - await provers[0].prove( + await prover.prove( proposedEvent.args.id.toNumber(), blockNumber, proposedEvent.args.meta as any as BlockMetadata