Skip to content

Commit

Permalink
refactor: change order of array counts in custom error
Browse files Browse the repository at this point in the history
test: createMultiple function
  • Loading branch information
andreivladbrg committed Apr 22, 2024
1 parent c7cc864 commit 409cd67
Show file tree
Hide file tree
Showing 4 changed files with 156 additions and 3 deletions.
4 changes: 2 additions & 2 deletions src/SablierV2OpenEnded.sol
Original file line number Diff line number Diff line change
Expand Up @@ -181,8 +181,8 @@ contract SablierV2OpenEnded is ISablierV2OpenEnded, NoDelegateCall, SablierV2Ope

// Check: count of `senders`, `recipients`, `ratesPerSecond` matches.
if (recipientsCount != sendersCount || recipientsCount != ratesPerSecondCount) {
revert Errors.SablierV2OpenEnded_CreateArrayCountsNotEqual(
sendersCount, recipientsCount, ratesPerSecondCount
revert Errors.SablierV2OpenEnded_CreateMultipleArrayCountsNotEqual(
recipientsCount, sendersCount, ratesPerSecondCount
);
}

Expand Down
2 changes: 1 addition & 1 deletion src/libraries/Errors.sol
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ library Errors {

/// @notice Thrown when trying to create multiple streams and the number of senders, recipients and rates per second
/// does not match.
error SablierV2OpenEnded_CreateArrayCountsNotEqual(
error SablierV2OpenEnded_CreateMultipleArrayCountsNotEqual(
uint256 recipientsCount, uint256 sendersCount, uint256 ratesPerSecondCount
);

Expand Down
138 changes: 138 additions & 0 deletions test/integration/create-multiple/createMultiple.t.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
// SPDX-License-Identifier: UNLICENSED
pragma solidity >=0.8.22;

import { ISablierV2OpenEnded } from "src/interfaces/ISablierV2OpenEnded.sol";
import { Errors } from "src/libraries/Errors.sol";
import { OpenEnded } from "src/types/DataTypes.sol";

import { Integration_Test } from "../Integration.t.sol";

contract CreateMultiple_Integration_Test is Integration_Test {
address[] internal defaultRecipients;
address[] internal defaultSenders;
uint128[] internal defaultRatesPerSecond;

function setUp() public override {
Integration_Test.setUp();

defaultRecipients.push(users.recipient);
defaultRecipients.push(users.recipient);
defaultSenders.push(users.sender);
defaultSenders.push(users.sender);
defaultRatesPerSecond.push(RATE_PER_SECOND);
defaultRatesPerSecond.push(RATE_PER_SECOND);
}

function test_RevertWhen_DelegateCall() external {
bytes memory callData = abi.encodeCall(
ISablierV2OpenEnded.createMultiple, (defaultRecipients, defaultSenders, defaultRatesPerSecond, dai)
);
_test_RevertWhen_DelegateCall(callData);
}

modifier whenArrayCountsNotEqual() {
_;
}

function test_RevertWhen_RecipientsCountNotEqual() external whenNotDelegateCalled whenArrayCountsNotEqual {
address[] memory recipients = new address[](1);

vm.expectRevert(
abi.encodeWithSelector(
Errors.SablierV2OpenEnded_CreateMultipleArrayCountsNotEqual.selector,
recipients.length,
defaultSenders.length,
defaultRatesPerSecond.length
)
);
openEnded.createMultiple(recipients, defaultSenders, defaultRatesPerSecond, dai);
}

function test_RevertWhen_SendersCountNotEqual() external whenNotDelegateCalled whenArrayCountsNotEqual {
address[] memory senders = new address[](1);

vm.expectRevert(
abi.encodeWithSelector(
Errors.SablierV2OpenEnded_CreateMultipleArrayCountsNotEqual.selector,
defaultRecipients.length,
senders.length,
defaultRatesPerSecond.length
)
);
openEnded.createMultiple(defaultRecipients, senders, defaultRatesPerSecond, dai);
}

function test_RevertWhen_RatesPerSecondCountNotEqual() external whenNotDelegateCalled whenArrayCountsNotEqual {
uint128[] memory ratesPerSecond = new uint128[](1);

vm.expectRevert(
abi.encodeWithSelector(
Errors.SablierV2OpenEnded_CreateMultipleArrayCountsNotEqual.selector,
defaultRecipients.length,
defaultSenders.length,
ratesPerSecond.length
)
);
openEnded.createMultiple(defaultRecipients, defaultSenders, ratesPerSecond, dai);
}

modifier whenArrayCountsEqual() {
_;
}

function test_CreateMultiple() external whenNotDelegateCalled whenArrayCountsEqual {
uint256 beforeNextStreamId = openEnded.nextStreamId();

vm.expectEmit({ emitter: address(openEnded) });
emit CreateOpenEndedStream({
streamId: beforeNextStreamId,
sender: users.sender,
recipient: users.recipient,
ratePerSecond: RATE_PER_SECOND,
asset: dai,
lastTimeUpdate: uint40(block.timestamp)
});
vm.expectEmit({ emitter: address(openEnded) });
emit CreateOpenEndedStream({
streamId: beforeNextStreamId + 1,
sender: users.sender,
recipient: users.recipient,
ratePerSecond: RATE_PER_SECOND,
asset: dai,
lastTimeUpdate: uint40(block.timestamp)
});

uint256[] memory streamIds =
openEnded.createMultiple(defaultRecipients, defaultSenders, defaultRatesPerSecond, dai);

uint256 afterNextStreamId = openEnded.nextStreamId();

assertEq(streamIds[0], beforeNextStreamId, "streamIds[0] != beforeNextStreamId");
assertEq(streamIds[1], beforeNextStreamId + 1, "streamIds[1] != beforeNextStreamId + 1");

assertEq(streamIds.length, defaultRecipients.length, "streamIds.length != defaultRecipients.length");
assertEq(
beforeNextStreamId + defaultRecipients.length,
afterNextStreamId,
"afterNextStreamId != beforeNextStreamId + defaultRecipients.length"
);

OpenEnded.Stream memory expectedStream = OpenEnded.Stream({
ratePerSecond: RATE_PER_SECOND,
asset: dai,
assetDecimals: 18,
balance: 0,
lastTimeUpdate: uint40(block.timestamp),
isCanceled: false,
isStream: true,
recipient: users.recipient,
sender: users.sender
});

OpenEnded.Stream memory actualStream = openEnded.getStream(streamIds[0]);
assertEq(actualStream, expectedStream);

actualStream = openEnded.getStream(streamIds[1]);
assertEq(actualStream, expectedStream);
}
}
15 changes: 15 additions & 0 deletions test/integration/create-multiple/createMultiple.tree
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
createMultiple.t.sol
β”œβ”€β”€ when delegate called
β”‚ └── it should revert
└── when not delegate called
β”œβ”€β”€ when arrays counts are not equal
β”‚ β”œβ”€β”€ when the recipients array is not equal
β”‚ β”‚ └── it should revert
β”‚ β”œβ”€β”€ when the senders array is not equal
β”‚ β”‚ └── it should revert
β”‚ └── when the rates per second array is not equal
β”‚ └── it should revert
└── when arrays counts are equal
β”œβ”€β”€ it should create multiple streams
β”œβ”€β”€ it should bump the next stream id multiple times
└── it should emit multiple {CreateOpenEndedStream} events

0 comments on commit 409cd67

Please sign in to comment.