Files
smom-dbis-138/test/mainnet-checkpoint/CheckpointLeaf.t.sol
defiQUG c336809676
Some checks failed
CI/CD Pipeline / Solidity Contracts (push) Failing after 1m3s
CI/CD Pipeline / Security Scanning (push) Successful in 2m18s
CI/CD Pipeline / Lint and Format (push) Failing after 34s
CI/CD Pipeline / Terraform Validation (push) Failing after 20s
CI/CD Pipeline / Kubernetes Validation (push) Successful in 22s
Deploy ChainID 138 / Deploy ChainID 138 (push) Failing after 40s
HYBX OMNL TypeScript & anchor / token-aggregation build + reconcile artifact (push) Failing after 49s
OMNL reconcile anchor / Run omnl:reconcile and upload artifacts (push) Failing after 21s
Validation / validate-genesis (push) Successful in 25s
Validation / validate-terraform (push) Failing after 21s
Validation / validate-kubernetes (push) Failing after 8s
Validation / validate-smart-contracts (push) Failing after 8s
Validation / validate-security (push) Failing after 1m11s
Validation / validate-documentation (push) Failing after 14s
Verify Deployment / Verify Deployment (push) Failing after 45s
Add mainnet checkpoint stack: ISO attestation, participant Etherscan surface, and services.
Ship AddressActivityRegistry V1/V2, ISO20022IntakeGateway, Chain138ParticipantSurface,
checkpoint hub contracts, checkpoint-core package, aggregator/indexer/sdk services,
relay profile guards, M00 diamond bridge facet, and OMNL compliance contracts.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-25 00:30:45 -07:00

38 lines
1.4 KiB
Solidity

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
import {Test} from "forge-std/Test.sol";
import {CheckpointLeaf} from "../../contracts/mainnet-checkpoint/libraries/CheckpointLeaf.sol";
contract CheckpointLeafTest is Test {
function testBuildMerkleRoot_twoLeaves() public pure {
CheckpointLeaf.PaymentLeafV1 memory a = _leaf(keccak256("a"));
CheckpointLeaf.PaymentLeafV1 memory b = _leaf(keccak256("b"));
bytes32[] memory hashes = new bytes32[](2);
hashes[0] = CheckpointLeaf.paymentLeafV1(138, a);
hashes[1] = CheckpointLeaf.paymentLeafV1(138, b);
bytes32 root = CheckpointLeaf.buildMerkleRoot(hashes);
assertTrue(root != bytes32(0));
}
function testVerifyMerkle_singleLeaf() public pure {
CheckpointLeaf.PaymentLeafV1 memory a = _leaf(keccak256("solo"));
bytes32 leaf = CheckpointLeaf.paymentLeafV1(138, a);
bytes32[] memory proof = new bytes32[](0);
assertTrue(CheckpointLeaf.verifyMerkle(leaf, leaf, proof));
}
function _leaf(bytes32 txHash) private pure returns (CheckpointLeaf.PaymentLeafV1 memory) {
return CheckpointLeaf.PaymentLeafV1({
txHash: txHash,
from: address(1),
to: address(2),
value: 1,
blockNumber: 1,
blockTimestamp: 1,
gasUsed: 21000,
success: true
});
}
}