Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(avm-simulator): test cleanup using expect.objectContaining()
Browse files Browse the repository at this point in the history
dbanks12 committed Feb 29, 2024
1 parent e4b1aee commit ea79c0d
Showing 3 changed files with 43 additions and 64 deletions.
36 changes: 18 additions & 18 deletions yarn-project/simulator/src/avm/journal/journal.test.ts
Original file line number Diff line number Diff line change
@@ -70,7 +70,7 @@ describe('journal', () => {
expect(exists).toEqual(false);

const journalUpdates = journal.flush();
expect(journalUpdates.nullifierChecks.map(c => [c.nullifier, c.exists])).toEqual([[utxo, false]]);
expect(journalUpdates.nullifierChecks).toEqual([expect.objectContaining({ nullifier: utxo, exists: false })]);
});
it('checkNullifierExists works for existing nullifiers', async () => {
const contractAddress = new Fr(1);
@@ -82,7 +82,7 @@ describe('journal', () => {
expect(exists).toEqual(true);

const journalUpdates = journal.flush();
expect(journalUpdates.nullifierChecks.map(c => [c.nullifier, c.exists])).toEqual([[utxo, true]]);
expect(journalUpdates.nullifierChecks).toEqual([expect.objectContaining({ nullifier: utxo, exists: true })]);
});
it('Should maintain nullifiers', async () => {
const contractAddress = new Fr(1);
@@ -100,8 +100,8 @@ describe('journal', () => {
expect(exists).toEqual(false);

const journalUpdates = journal.flush();
expect(journalUpdates.l1ToL2MessageChecks.map(c => [c.leafIndex, c.msgHash, c.exists])).toEqual([
[leafIndex, utxo, false],
expect(journalUpdates.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: leafIndex, msgHash: utxo, exists: false }),
]);
});
it('checkL1ToL2MessageExists works for existing nullifiers', async () => {
@@ -113,8 +113,8 @@ describe('journal', () => {
expect(exists).toEqual(true);

const journalUpdates = journal.flush();
expect(journalUpdates.l1ToL2MessageChecks.map(c => [c.leafIndex, c.msgHash, c.exists])).toEqual([
[leafIndex, utxo, true],
expect(journalUpdates.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: leafIndex, msgHash: utxo, exists: true }),
]);
});
it('Should maintain nullifiers', async () => {
@@ -200,14 +200,14 @@ describe('journal', () => {
{ recipient, content: commitment },
{ recipient, content: commitmentT1 },
]);
expect(journalUpdates.nullifierChecks.map(c => [c.nullifier, c.exists])).toEqual([
[commitment, true],
[commitmentT1, true],
expect(journalUpdates.nullifierChecks).toEqual([
expect.objectContaining({ nullifier: commitment, exists: true }),
expect.objectContaining({ nullifier: commitmentT1, exists: true }),
]);
expect(journalUpdates.newNullifiers).toEqual([commitment, commitmentT1]);
expect(journalUpdates.l1ToL2MessageChecks.map(c => [c.leafIndex, c.msgHash, c.exists])).toEqual([
[index, commitment, false],
[indexT1, commitmentT1, false],
expect(journalUpdates.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: index, msgHash: commitment, exists: false }),
expect.objectContaining({ leafIndex: indexT1, msgHash: commitmentT1, exists: false }),
]);
});

@@ -274,14 +274,14 @@ describe('journal', () => {

// Check that the world state _traces_ are merged even on rejection
expect(journalUpdates.newNoteHashes).toEqual([commitment, commitmentT1]);
expect(journalUpdates.nullifierChecks.map(c => [c.nullifier, c.exists])).toEqual([
[commitment, true],
[commitmentT1, true],
expect(journalUpdates.nullifierChecks).toEqual([
expect.objectContaining({ nullifier: commitment, exists: true }),
expect.objectContaining({ nullifier: commitmentT1, exists: true }),
]);
expect(journalUpdates.newNullifiers).toEqual([commitment, commitmentT1]);
expect(journalUpdates.l1ToL2MessageChecks.map(c => [c.leafIndex, c.msgHash, c.exists])).toEqual([
[index, commitment, false],
[indexT1, commitmentT1, false],
expect(journalUpdates.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: index, msgHash: commitment, exists: false }),
expect.objectContaining({ leafIndex: indexT1, msgHash: commitmentT1, exists: false }),
]);

// Check that rejected Accrued Substate is absent
51 changes: 13 additions & 38 deletions yarn-project/simulator/src/avm/journal/trace.test.ts
Original file line number Diff line number Diff line change
@@ -111,29 +111,6 @@ describe('world state access trace', () => {
const isPendingT1 = false;
const leafIndexT1 = new Fr(42);

const expectedNullifierCheck = {
nullifier: commitment,
exists: exists,
isPending: isPending,
leafIndex: leafIndex,
};
const expectedNullifierCheckT1 = {
nullifier: commitmentT1,
exists: existsT1,
isPending: isPendingT1,
leafIndex: leafIndexT1,
};
const expectedMessageCheck = {
leafIndex: leafIndex,
msgHash: commitment,
exists: exists,
};
const expectedMessageCheckT1 = {
leafIndex: leafIndexT1,
msgHash: commitmentT1,
exists: existsT1,
};

trace.tracePublicStorageWrite(contractAddress, slot, value);
trace.tracePublicStorageRead(contractAddress, slot, value);
trace.traceNewNoteHash(contractAddress, commitment);
@@ -158,21 +135,19 @@ describe('world state access trace', () => {
expect(slotReads).toEqual([value, valueT1]);
expect(slotWrites).toEqual([value, valueT1]);
expect(trace.newNoteHashes).toEqual([commitment, commitmentT1]);
expect(
trace.nullifierChecks.map(c => ({
nullifier: c.nullifier,
exists: c.exists,
isPending: c.isPending,
leafIndex: c.leafIndex,
})),
).toEqual([expectedNullifierCheck, expectedNullifierCheckT1]);
expect(trace.nullifierChecks).toEqual([
expect.objectContaining({ nullifier: commitment, exists: exists, isPending: isPending, leafIndex: leafIndex }),
expect.objectContaining({
nullifier: commitmentT1,
exists: existsT1,
isPending: isPendingT1,
leafIndex: leafIndexT1,
}),
]);
expect(trace.newNullifiers).toEqual([commitment, commitmentT1]);
expect(
trace.l1ToL2MessageChecks.map(c => ({
leafIndex: c.leafIndex,
msgHash: c.msgHash,
exists: c.exists,
})),
).toEqual([expectedMessageCheck, expectedMessageCheckT1]);
expect(trace.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: leafIndex, msgHash: commitment, exists: exists }),
expect.objectContaining({ leafIndex: leafIndexT1, msgHash: commitmentT1, exists: existsT1 }),
]);
});
});
20 changes: 12 additions & 8 deletions yarn-project/simulator/src/avm/opcodes/accrued_substate.test.ts
Original file line number Diff line number Diff line change
@@ -91,8 +91,9 @@ describe('Accrued Substate', () => {
expect(exists).toEqual(new Uint8(0));

const journalState = context.persistableState.flush();
expect(journalState.nullifierChecks.length).toEqual(1);
expect(journalState.nullifierChecks[0].exists).toEqual(false);
expect(journalState.nullifierChecks).toEqual([
expect.objectContaining({ nullifier: value.toFr(), exists: false }),
]);
});

it('Should correctly show true when nullifier exists', async () => {
@@ -114,8 +115,9 @@ describe('Accrued Substate', () => {
expect(exists).toEqual(new Uint8(1));

const journalState = context.persistableState.flush();
expect(journalState.nullifierChecks.length).toEqual(1);
expect(journalState.nullifierChecks[0].exists).toEqual(true);
expect(journalState.nullifierChecks).toEqual([
expect.objectContaining({ nullifier: value.toFr(), exists: true }),
]);
});
});

@@ -214,8 +216,9 @@ describe('Accrued Substate', () => {
expect(exists).toEqual(new Uint8(0));

const journalState = context.persistableState.flush();
expect(journalState.l1ToL2MessageChecks.length).toEqual(1);
expect(journalState.l1ToL2MessageChecks[0].exists).toEqual(false);
expect(journalState.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: leafIndex.toFr(), msgHash: msgHash.toFr(), exists: false }),
]);
});

it('Should correctly show true when L1ToL2 message exists', async () => {
@@ -240,8 +243,9 @@ describe('Accrued Substate', () => {
expect(exists).toEqual(new Uint8(1));

const journalState = context.persistableState.flush();
expect(journalState.l1ToL2MessageChecks.length).toEqual(1);
expect(journalState.l1ToL2MessageChecks[0].exists).toEqual(true);
expect(journalState.l1ToL2MessageChecks).toEqual([
expect.objectContaining({ leafIndex: leafIndex.toFr(), msgHash: msgHash.toFr(), exists: true }),
]);
});
});

0 comments on commit ea79c0d

Please sign in to comment.