2023-11-07 09:40:38 +01:00
|
|
|
// SPDX-License-Identifier: UNLICENSED
|
|
|
|
pragma solidity ^0.8.19;
|
|
|
|
|
2024-01-11 14:54:39 +01:00
|
|
|
import { ERC20 } from "@openzeppelin/contracts/token/ERC20/ERC20.sol";
|
|
|
|
|
2023-11-07 09:40:38 +01:00
|
|
|
import { Test } from "forge-std/Test.sol";
|
|
|
|
import { Deploy } from "../script/Deploy.s.sol";
|
2024-01-11 14:54:39 +01:00
|
|
|
import { DeployBroken } from "./script/DeployBroken.s.sol";
|
2023-11-07 09:40:38 +01:00
|
|
|
import { DeploymentConfig } from "../script/DeploymentConfig.s.sol";
|
|
|
|
import { StakeManager } from "../contracts/StakeManager.sol";
|
|
|
|
import { StakeVault } from "../contracts/StakeVault.sol";
|
2023-11-07 09:49:22 +01:00
|
|
|
import { VaultFactory } from "../contracts/VaultFactory.sol";
|
2023-11-07 09:40:38 +01:00
|
|
|
|
|
|
|
contract StakeVaultTest is Test {
|
|
|
|
StakeManager internal stakeManager;
|
|
|
|
|
|
|
|
DeploymentConfig internal deploymentConfig;
|
|
|
|
|
2023-11-07 09:49:22 +01:00
|
|
|
VaultFactory internal vaultFactory;
|
|
|
|
|
2023-11-07 09:40:38 +01:00
|
|
|
StakeVault internal stakeVault;
|
|
|
|
|
|
|
|
address internal deployer;
|
|
|
|
|
|
|
|
address internal testUser = makeAddr("testUser");
|
|
|
|
|
|
|
|
address internal stakeToken;
|
|
|
|
|
|
|
|
function setUp() public virtual {
|
|
|
|
Deploy deployment = new Deploy();
|
2023-11-07 09:49:22 +01:00
|
|
|
(vaultFactory, stakeManager, deploymentConfig) = deployment.run();
|
2023-11-07 09:40:38 +01:00
|
|
|
(deployer, stakeToken) = deploymentConfig.activeNetworkConfig();
|
|
|
|
|
|
|
|
vm.prank(testUser);
|
2023-11-07 09:49:22 +01:00
|
|
|
stakeVault = vaultFactory.createVault();
|
2023-11-07 09:40:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
contract StakedTokenTest is StakeVaultTest {
|
|
|
|
function setUp() public override {
|
|
|
|
StakeVaultTest.setUp();
|
|
|
|
}
|
|
|
|
|
|
|
|
function testStakeToken() public {
|
|
|
|
assertEq(address(stakeVault.stakedToken()), stakeToken);
|
|
|
|
}
|
|
|
|
}
|
2024-01-11 14:54:39 +01:00
|
|
|
|
|
|
|
contract StakeTest is StakeVaultTest {
|
|
|
|
function setUp() public override {
|
|
|
|
DeployBroken deployment = new DeployBroken();
|
|
|
|
(vaultFactory, stakeManager, stakeToken) = deployment.run();
|
|
|
|
|
|
|
|
vm.prank(testUser);
|
|
|
|
stakeVault = vaultFactory.createVault();
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_RevertWhen_StakeTokenTransferFails() public {
|
|
|
|
// ensure user has funds
|
|
|
|
deal(stakeToken, testUser, 1000);
|
|
|
|
|
|
|
|
vm.startPrank(address(testUser));
|
|
|
|
ERC20(stakeToken).approve(address(stakeVault), 100);
|
|
|
|
vm.expectRevert(StakeVault.StakeVault__StakingFailed.selector);
|
|
|
|
stakeVault.stake(100, 0);
|
|
|
|
}
|
|
|
|
}
|