Merge branch 'feat/short' into funding-fee-dry-run
This commit is contained in:
commit
a2b1838c60
@ -1,7 +1,8 @@
|
|||||||
""" Gate.io exchange subclass """
|
""" Gate.io exchange subclass """
|
||||||
import logging
|
import logging
|
||||||
from typing import Dict, List, Optional
|
from typing import Dict, List, Optional, Tuple
|
||||||
|
|
||||||
|
from freqtrade.enums import Collateral, TradingMode
|
||||||
from freqtrade.exceptions import OperationalException
|
from freqtrade.exceptions import OperationalException
|
||||||
from freqtrade.exchange import Exchange
|
from freqtrade.exchange import Exchange
|
||||||
|
|
||||||
@ -27,6 +28,31 @@ class Gateio(Exchange):
|
|||||||
|
|
||||||
funding_fee_times: List[int] = [0, 8, 16] # hours of the day
|
funding_fee_times: List[int] = [0, 8, 16] # hours of the day
|
||||||
|
|
||||||
|
_supported_trading_mode_collateral_pairs: List[Tuple[TradingMode, Collateral]] = [
|
||||||
|
# TradingMode.SPOT always supported and not required in this list
|
||||||
|
# (TradingMode.MARGIN, Collateral.CROSS), # TODO-lev: Uncomment once supported
|
||||||
|
# (TradingMode.FUTURES, Collateral.CROSS), # TODO-lev: Uncomment once supported
|
||||||
|
# (TradingMode.FUTURES, Collateral.ISOLATED) # TODO-lev: Uncomment once supported
|
||||||
|
]
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _ccxt_config(self) -> Dict:
|
||||||
|
# Parameters to add directly to ccxt sync/async initialization.
|
||||||
|
if self.trading_mode == TradingMode.MARGIN:
|
||||||
|
return {
|
||||||
|
"options": {
|
||||||
|
"defaultType": "margin"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elif self.trading_mode == TradingMode.FUTURES:
|
||||||
|
return {
|
||||||
|
"options": {
|
||||||
|
"defaultType": "swap"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
return {}
|
||||||
|
|
||||||
def validate_ordertypes(self, order_types: Dict) -> None:
|
def validate_ordertypes(self, order_types: Dict) -> None:
|
||||||
super().validate_ordertypes(order_types)
|
super().validate_ordertypes(order_types)
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ from tests.conftest import get_mock_coro, get_patched_exchange, log_has, log_has
|
|||||||
|
|
||||||
|
|
||||||
# Make sure to always keep one exchange here which is NOT subclassed!!
|
# Make sure to always keep one exchange here which is NOT subclassed!!
|
||||||
EXCHANGES = ['bittrex', 'binance', 'kraken', 'ftx']
|
EXCHANGES = ['bittrex', 'binance', 'kraken', 'ftx', 'gateio']
|
||||||
|
|
||||||
|
|
||||||
def ccxt_exceptionhandlers(mocker, default_conf, api_mock, exchange_name,
|
def ccxt_exceptionhandlers(mocker, default_conf, api_mock, exchange_name,
|
||||||
@ -3206,6 +3206,7 @@ def test_set_margin_mode(mocker, default_conf, collateral):
|
|||||||
("bittrex", TradingMode.MARGIN, Collateral.ISOLATED, True),
|
("bittrex", TradingMode.MARGIN, Collateral.ISOLATED, True),
|
||||||
("bittrex", TradingMode.FUTURES, Collateral.CROSS, True),
|
("bittrex", TradingMode.FUTURES, Collateral.CROSS, True),
|
||||||
("bittrex", TradingMode.FUTURES, Collateral.ISOLATED, True),
|
("bittrex", TradingMode.FUTURES, Collateral.ISOLATED, True),
|
||||||
|
("gateio", TradingMode.MARGIN, Collateral.ISOLATED, True),
|
||||||
|
|
||||||
# TODO-lev: Remove once implemented
|
# TODO-lev: Remove once implemented
|
||||||
("binance", TradingMode.MARGIN, Collateral.CROSS, True),
|
("binance", TradingMode.MARGIN, Collateral.CROSS, True),
|
||||||
@ -3215,6 +3216,9 @@ def test_set_margin_mode(mocker, default_conf, collateral):
|
|||||||
("kraken", TradingMode.FUTURES, Collateral.CROSS, True),
|
("kraken", TradingMode.FUTURES, Collateral.CROSS, True),
|
||||||
("ftx", TradingMode.MARGIN, Collateral.CROSS, True),
|
("ftx", TradingMode.MARGIN, Collateral.CROSS, True),
|
||||||
("ftx", TradingMode.FUTURES, Collateral.CROSS, True),
|
("ftx", TradingMode.FUTURES, Collateral.CROSS, True),
|
||||||
|
("gateio", TradingMode.MARGIN, Collateral.CROSS, True),
|
||||||
|
("gateio", TradingMode.FUTURES, Collateral.CROSS, True),
|
||||||
|
("gateio", TradingMode.FUTURES, Collateral.ISOLATED, True),
|
||||||
|
|
||||||
# TODO-lev: Uncomment once implemented
|
# TODO-lev: Uncomment once implemented
|
||||||
# ("binance", TradingMode.MARGIN, Collateral.CROSS, False),
|
# ("binance", TradingMode.MARGIN, Collateral.CROSS, False),
|
||||||
@ -3223,7 +3227,10 @@ def test_set_margin_mode(mocker, default_conf, collateral):
|
|||||||
# ("kraken", TradingMode.MARGIN, Collateral.CROSS, False),
|
# ("kraken", TradingMode.MARGIN, Collateral.CROSS, False),
|
||||||
# ("kraken", TradingMode.FUTURES, Collateral.CROSS, False),
|
# ("kraken", TradingMode.FUTURES, Collateral.CROSS, False),
|
||||||
# ("ftx", TradingMode.MARGIN, Collateral.CROSS, False),
|
# ("ftx", TradingMode.MARGIN, Collateral.CROSS, False),
|
||||||
# ("ftx", TradingMode.FUTURES, Collateral.CROSS, False)
|
# ("ftx", TradingMode.FUTURES, Collateral.CROSS, False),
|
||||||
|
# ("gateio", TradingMode.MARGIN, Collateral.CROSS, False),
|
||||||
|
# ("gateio", TradingMode.FUTURES, Collateral.CROSS, False),
|
||||||
|
# ("gateio", TradingMode.FUTURES, Collateral.ISOLATED, False),
|
||||||
])
|
])
|
||||||
def test_validate_trading_mode_and_collateral(
|
def test_validate_trading_mode_and_collateral(
|
||||||
default_conf,
|
default_conf,
|
||||||
@ -3253,8 +3260,9 @@ def test_validate_trading_mode_and_collateral(
|
|||||||
("ftx", "margin", {}),
|
("ftx", "margin", {}),
|
||||||
("ftx", "futures", {}),
|
("ftx", "futures", {}),
|
||||||
("bittrex", "spot", {}),
|
("bittrex", "spot", {}),
|
||||||
("bittrex", "margin", {}),
|
("gateio", "spot", {}),
|
||||||
("bittrex", "futures", {}),
|
("gateio", "margin", {"options": {"defaultType": "margin"}}),
|
||||||
|
("gateio", "futures", {"options": {"defaultType": "swap"}}),
|
||||||
])
|
])
|
||||||
def test__ccxt_config(
|
def test__ccxt_config(
|
||||||
default_conf,
|
default_conf,
|
||||||
|
Loading…
Reference in New Issue
Block a user