Update tests
This commit is contained in:
parent
3039f3eed2
commit
a1fd035de8
@ -8,6 +8,9 @@ from mev_inspect.schemas.classifiers import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
BALANCER_V1_POOL_ABI_NAME = "BPool"
|
||||||
|
|
||||||
|
|
||||||
class BalancerSwapClassifier(SwapClassifier):
|
class BalancerSwapClassifier(SwapClassifier):
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_swap_recipient(trace: DecodedCallTrace) -> str:
|
def get_swap_recipient(trace: DecodedCallTrace) -> str:
|
||||||
@ -16,7 +19,7 @@ class BalancerSwapClassifier(SwapClassifier):
|
|||||||
|
|
||||||
BALANCER_V1_SPECS = [
|
BALANCER_V1_SPECS = [
|
||||||
ClassifierSpec(
|
ClassifierSpec(
|
||||||
abi_name="BPool",
|
abi_name=BALANCER_V1_POOL_ABI_NAME,
|
||||||
protocol=Protocol.balancer_v1,
|
protocol=Protocol.balancer_v1,
|
||||||
classifiers={
|
classifiers={
|
||||||
"swapExactAmountIn(address,uint256,address,uint256,uint256)": BalancerSwapClassifier,
|
"swapExactAmountIn(address,uint256,address,uint256,uint256)": BalancerSwapClassifier,
|
||||||
|
@ -8,6 +8,10 @@ from mev_inspect.schemas.classifiers import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
UNISWAP_V2_PAIR_ABI_NAME = "UniswapV2Pair"
|
||||||
|
UNISWAP_V3_POOL_ABI_NAME = "UniswapV3Pool"
|
||||||
|
|
||||||
|
|
||||||
class UniswapV3SwapClassifier(SwapClassifier):
|
class UniswapV3SwapClassifier(SwapClassifier):
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_swap_recipient(trace: DecodedCallTrace) -> str:
|
def get_swap_recipient(trace: DecodedCallTrace) -> str:
|
||||||
@ -86,7 +90,7 @@ UNISWAP_V3_CONTRACT_SPECS = [
|
|||||||
|
|
||||||
UNISWAP_V3_GENERAL_SPECS = [
|
UNISWAP_V3_GENERAL_SPECS = [
|
||||||
ClassifierSpec(
|
ClassifierSpec(
|
||||||
abi_name="UniswapV3Pool",
|
abi_name=UNISWAP_V3_POOL_ABI_NAME,
|
||||||
classifiers={
|
classifiers={
|
||||||
"swap(address,bool,int256,uint160,bytes)": UniswapV3SwapClassifier,
|
"swap(address,bool,int256,uint160,bytes)": UniswapV3SwapClassifier,
|
||||||
},
|
},
|
||||||
@ -117,7 +121,7 @@ UNISWAPPY_V2_CONTRACT_SPECS = [
|
|||||||
]
|
]
|
||||||
|
|
||||||
UNISWAPPY_V2_PAIR_SPEC = ClassifierSpec(
|
UNISWAPPY_V2_PAIR_SPEC = ClassifierSpec(
|
||||||
abi_name="UniswapV2Pair",
|
abi_name=UNISWAP_V2_PAIR_ABI_NAME,
|
||||||
classifiers={
|
classifiers={
|
||||||
"swap(uint256,uint256,address,bytes)": UniswapV2SwapClassifier,
|
"swap(uint256,uint256,address,bytes)": UniswapV2SwapClassifier,
|
||||||
},
|
},
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
from typing import List
|
from typing import List, Optional
|
||||||
|
|
||||||
from mev_inspect.schemas.blocks import TraceType
|
from mev_inspect.schemas.blocks import TraceType
|
||||||
from mev_inspect.schemas.classified_traces import (
|
from mev_inspect.schemas.classified_traces import (
|
||||||
Classification,
|
Classification,
|
||||||
ClassifiedTrace,
|
ClassifiedTrace,
|
||||||
CallTrace,
|
|
||||||
DecodedCallTrace,
|
DecodedCallTrace,
|
||||||
|
Protocol,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ def make_transfer_trace(
|
|||||||
token_address: str,
|
token_address: str,
|
||||||
amount: int,
|
amount: int,
|
||||||
):
|
):
|
||||||
return CallTrace(
|
return DecodedCallTrace(
|
||||||
transaction_hash=transaction_hash,
|
transaction_hash=transaction_hash,
|
||||||
block_number=block_number,
|
block_number=block_number,
|
||||||
type=TraceType.call,
|
type=TraceType.call,
|
||||||
@ -26,6 +26,9 @@ def make_transfer_trace(
|
|||||||
classification=Classification.transfer,
|
classification=Classification.transfer,
|
||||||
from_address=from_address,
|
from_address=from_address,
|
||||||
to_address=token_address,
|
to_address=token_address,
|
||||||
|
abi_name="ERC20",
|
||||||
|
function_name="transfer",
|
||||||
|
function_signature="transfer(address,uint256)",
|
||||||
inputs={
|
inputs={
|
||||||
"recipient": to_address,
|
"recipient": to_address,
|
||||||
"amount": amount,
|
"amount": amount,
|
||||||
@ -43,6 +46,8 @@ def make_swap_trace(
|
|||||||
from_address: str,
|
from_address: str,
|
||||||
pool_address: str,
|
pool_address: str,
|
||||||
abi_name: str,
|
abi_name: str,
|
||||||
|
function_signature: str,
|
||||||
|
protocol: Optional[Protocol],
|
||||||
recipient_address: str,
|
recipient_address: str,
|
||||||
recipient_input_key: str,
|
recipient_input_key: str,
|
||||||
):
|
):
|
||||||
@ -57,9 +62,10 @@ def make_swap_trace(
|
|||||||
from_address=from_address,
|
from_address=from_address,
|
||||||
to_address=pool_address,
|
to_address=pool_address,
|
||||||
function_name="swap",
|
function_name="swap",
|
||||||
function_signature="swap()",
|
function_signature=function_signature,
|
||||||
inputs={recipient_input_key: recipient_address},
|
inputs={recipient_input_key: recipient_address},
|
||||||
abi_name=abi_name,
|
abi_name=abi_name,
|
||||||
|
protocol=protocol,
|
||||||
block_hash=str(block_number),
|
block_hash=str(block_number),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
from mev_inspect.arbitrages import get_arbitrages
|
from mev_inspect.arbitrages import get_arbitrages
|
||||||
from mev_inspect.schemas.swaps import Swap
|
from mev_inspect.classifiers.specs.uniswap import (
|
||||||
from mev_inspect.swaps import (
|
|
||||||
UNISWAP_V2_PAIR_ABI_NAME,
|
UNISWAP_V2_PAIR_ABI_NAME,
|
||||||
UNISWAP_V3_POOL_ABI_NAME,
|
UNISWAP_V3_POOL_ABI_NAME,
|
||||||
)
|
)
|
||||||
|
from mev_inspect.schemas.swaps import Swap
|
||||||
|
|
||||||
|
|
||||||
def test_two_pool_arbitrage(get_transaction_hashes, get_addresses):
|
def test_two_pool_arbitrage(get_transaction_hashes, get_addresses):
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
from mev_inspect.swaps import (
|
from mev_inspect.swaps import get_swaps
|
||||||
get_swaps,
|
from mev_inspect.classifiers.specs.balancer import BALANCER_V1_POOL_ABI_NAME
|
||||||
|
from mev_inspect.classifiers.specs.uniswap import (
|
||||||
UNISWAP_V2_PAIR_ABI_NAME,
|
UNISWAP_V2_PAIR_ABI_NAME,
|
||||||
UNISWAP_V3_POOL_ABI_NAME,
|
UNISWAP_V3_POOL_ABI_NAME,
|
||||||
BALANCER_V1_POOL_ABI_NAME,
|
|
||||||
)
|
)
|
||||||
|
from mev_inspect.schemas.classified_traces import Protocol
|
||||||
|
|
||||||
from .helpers import (
|
from .helpers import (
|
||||||
make_unknown_trace,
|
make_unknown_trace,
|
||||||
@ -64,6 +65,8 @@ def test_swaps(
|
|||||||
from_address=alice_address,
|
from_address=alice_address,
|
||||||
pool_address=first_pool_address,
|
pool_address=first_pool_address,
|
||||||
abi_name=UNISWAP_V2_PAIR_ABI_NAME,
|
abi_name=UNISWAP_V2_PAIR_ABI_NAME,
|
||||||
|
protocol=None,
|
||||||
|
function_signature="swap(uint256,uint256,address,bytes)",
|
||||||
recipient_address=bob_address,
|
recipient_address=bob_address,
|
||||||
recipient_input_key="to",
|
recipient_input_key="to",
|
||||||
),
|
),
|
||||||
@ -83,6 +86,8 @@ def test_swaps(
|
|||||||
from_address=bob_address,
|
from_address=bob_address,
|
||||||
pool_address=second_pool_address,
|
pool_address=second_pool_address,
|
||||||
abi_name=UNISWAP_V3_POOL_ABI_NAME,
|
abi_name=UNISWAP_V3_POOL_ABI_NAME,
|
||||||
|
protocol=None,
|
||||||
|
function_signature="swap(address,bool,int256,uint160,bytes)",
|
||||||
recipient_address=carl_address,
|
recipient_address=carl_address,
|
||||||
recipient_input_key="recipient",
|
recipient_input_key="recipient",
|
||||||
),
|
),
|
||||||
@ -129,6 +134,8 @@ def test_swaps(
|
|||||||
from_address=bob_address,
|
from_address=bob_address,
|
||||||
pool_address=third_pool_address,
|
pool_address=third_pool_address,
|
||||||
abi_name=BALANCER_V1_POOL_ABI_NAME,
|
abi_name=BALANCER_V1_POOL_ABI_NAME,
|
||||||
|
protocol=Protocol.balancer_v1,
|
||||||
|
function_signature="swapExactAmountIn(address,uint256,address,uint256,uint256)",
|
||||||
recipient_address=bob_address,
|
recipient_address=bob_address,
|
||||||
recipient_input_key="recipient",
|
recipient_input_key="recipient",
|
||||||
),
|
),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user