f87f5a40c0
* added initial foundry transformERC20 tests * added foundry tests into CircleCI flow * add verbosity for failing tests in CI * revert wrong CI commands * feat: Foundry, added some more deployments (#558) * Added some more deployments * Rename WETH9 to WETH9V06 * Set to 0.6.x * fix typo * remove commit with bad prettier changes * working bridge Fills through weth transformer * remove unused reference * clean up tests * added working otc fill through transformERC20 in FQT * resolve file imports, add samplers, arbitrumBridgeAdatper, and new FQT version * add extra 'v' for debugging verbosity * add extra 'v' for debugging verbosity in circleci config * remove old traces * refactor rpc's out of foundry.toml and into .env for CI compatibility * remove verbosity from CI command as its now defined in foundry.toml * setup rpc's * ignore foundry artifacts in prettier * change naming in prettierignore * move /samplers to the tests subdirectory, modify remappings to reflext change * one more try 🤞 * change CI steps * remove yarn from CI step * get to the right directory * update foundry before tests * fix tip() deprecation and use deal() * use deal() instead of vm.deal() * try to get foundry to have the right directory structure by updating it * I HATE THIS * remove foundryup * Fix prettier issues * Remove obsoleted import * Use forge native commands to install deps and test and add the --root option * Try using forge with working-directory flag in CI * Use nightly foundry docker image * Update rpc endpoints config in foundry * move tests into /forked and /local * rename tests * add foundry profiles to CI * try to fix CI * 🔧 add foundry local and forked tests to workflow * prettier and lint * revert deps update * remove all samplers and add uniswapV2 sampler to ForkUtils * address jacobs comments * cleanup and comment * prettier and lint * bump contracts-zero-ex version * set func-name-mixedcase to off in solhint for elenas new changes * max line length to warn * add --fix for check-md * Update ci.yml * fix some nitpcks and leftover code * fix inconsistent naming * fix bridge adapter reverts and foundry cache * migrate foundry integration tests to /tests * refactor contract-addresses to use the contract-addresses package style nested json * fix solhint * fix contract linting errors * dont check broken links in libraries * move forge order in gh action for testing * add env instead of vars * try again * fix github actions ordering * update licence and address comments * remove verbosity from foundry.toml * fix contract lint * move back to emitting an event until samplers can be integrated as some chains dont have uniswap as a source * add uniswap v3 sampling code for future use * remove uniswap v3 code as its not used * fix lint Co-authored-by: Noah Khamliche <0xnoah@Noahs-MacBook-Pro-2.local> Co-authored-by: Jacob Evans <jacob@dekz.net> Co-authored-by: elenadimitrova <elena@arenabg.com>
106 lines
4.4 KiB
Solidity
106 lines
4.4 KiB
Solidity
// SPDX-License-Identifier: Apache-2.0
|
|
/*
|
|
Copyright 2023 ZeroEx Intl.
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
pragma solidity ^0.6.5;
|
|
pragma experimental ABIEncoderV2;
|
|
|
|
import "@0x/contracts-utils/contracts/src/v06/LibBytesV06.sol";
|
|
import "@0x/contracts-utils/contracts/src/v06/LibMathV06.sol";
|
|
import "@0x/contracts-utils/contracts/src/v06/LibSafeMathV06.sol";
|
|
import "./tokens/TestMintableERC20Token.sol";
|
|
import "../src/features/libs/LibNativeOrder.sol";
|
|
import "../src/features/libs/LibSignature.sol";
|
|
|
|
contract TestFillQuoteTransformerExchange {
|
|
bytes32 public constant EIP712_EXCHANGE_DOMAIN_HASH =
|
|
0xaa81d881b1adbbf115e15b849cb9cdc643cad3c6a90f30eb505954af943247e6;
|
|
uint256 private constant REVERT_AMOUNT = 0xdeadbeef;
|
|
uint256 private constant PROTOCOL_FEE_MULTIPLIER = 1337;
|
|
|
|
using LibSafeMathV06 for uint256;
|
|
|
|
function fillLimitOrder(
|
|
LibNativeOrder.LimitOrder calldata order,
|
|
LibSignature.Signature calldata signature,
|
|
uint128 takerTokenFillAmount
|
|
) external payable returns (uint128 takerTokenFilledAmount, uint128 makerTokenFilledAmount) {
|
|
// The r field of the signature is the pre-filled amount.
|
|
uint128 takerTokenPreFilledAmount = uint128(uint256(signature.r));
|
|
if (REVERT_AMOUNT == takerTokenPreFilledAmount) {
|
|
revert("REVERT_AMOUNT");
|
|
}
|
|
if (takerTokenPreFilledAmount >= order.takerAmount) {
|
|
revert("FILLED");
|
|
}
|
|
uint256 protocolFee = PROTOCOL_FEE_MULTIPLIER * tx.gasprice;
|
|
// Return excess protocol fee.
|
|
msg.sender.transfer(msg.value - protocolFee);
|
|
takerTokenFilledAmount = LibSafeMathV06.min128(
|
|
order.takerAmount - takerTokenPreFilledAmount,
|
|
takerTokenFillAmount
|
|
);
|
|
|
|
// Take taker tokens.
|
|
order.takerToken.transferFrom(msg.sender, order.maker, takerTokenFilledAmount);
|
|
|
|
// Mint maker tokens.
|
|
makerTokenFilledAmount = LibSafeMathV06.safeDowncastToUint128(
|
|
(uint256(takerTokenFilledAmount) * uint256(order.makerAmount)) / uint256(order.takerAmount)
|
|
);
|
|
TestMintableERC20Token(address(order.makerToken)).mint(msg.sender, makerTokenFilledAmount);
|
|
|
|
// Take taker token fee.
|
|
uint128 takerFee = LibSafeMathV06.safeDowncastToUint128(
|
|
(uint256(takerTokenFilledAmount) * uint256(order.takerTokenFeeAmount)) / uint256(order.takerAmount)
|
|
);
|
|
order.takerToken.transferFrom(msg.sender, order.feeRecipient, takerFee);
|
|
}
|
|
|
|
function fillRfqOrder(
|
|
LibNativeOrder.RfqOrder calldata order,
|
|
LibSignature.Signature calldata signature,
|
|
uint128 takerTokenFillAmount
|
|
) external payable returns (uint128 takerTokenFilledAmount, uint128 makerTokenFilledAmount) {
|
|
// The r field of the signature is the pre-filled amount.
|
|
uint128 takerTokenPreFilledAmount = uint128(uint256(signature.r));
|
|
if (REVERT_AMOUNT == takerTokenPreFilledAmount) {
|
|
revert("REVERT_AMOUNT");
|
|
}
|
|
if (takerTokenPreFilledAmount >= order.takerAmount) {
|
|
revert("FILLED");
|
|
}
|
|
takerTokenFilledAmount = LibSafeMathV06.min128(
|
|
order.takerAmount - takerTokenPreFilledAmount,
|
|
takerTokenFillAmount
|
|
);
|
|
|
|
// Take taker tokens.
|
|
order.takerToken.transferFrom(msg.sender, order.maker, takerTokenFilledAmount);
|
|
|
|
// Mint maker tokens.
|
|
makerTokenFilledAmount = LibSafeMathV06.safeDowncastToUint128(
|
|
(uint256(takerTokenFilledAmount) * uint256(order.makerAmount)) / uint256(order.takerAmount)
|
|
);
|
|
TestMintableERC20Token(address(order.makerToken)).mint(msg.sender, makerTokenFilledAmount);
|
|
}
|
|
|
|
function getProtocolFeeMultiplier() external pure returns (uint256) {
|
|
return PROTOCOL_FEE_MULTIPLIER;
|
|
}
|
|
|
|
function getLimitOrderHash(LibNativeOrder.LimitOrder calldata order) external pure returns (bytes32) {
|
|
return bytes32(order.salt);
|
|
}
|
|
}
|