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
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>
38 lines
1.4 KiB
Solidity
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
|
|
});
|
|
}
|
|
}
|