Skip to content

Commit 4017b01

Browse files
committed
add test
1 parent f437d4a commit 4017b01

File tree

1 file changed

+43
-2
lines changed

1 file changed

+43
-2
lines changed

tests/exchange/test_bitget.py

Lines changed: 43 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,13 @@
1+
from copy import deepcopy
12
from datetime import timedelta
23
from unittest.mock import MagicMock, PropertyMock
34

45
import pytest
56

6-
from freqtrade.enums import CandleType, MarginMode, TradingMode
7+
from freqtrade.enums import CandleType, MarginMode, RunMode, TradingMode
78
from freqtrade.exceptions import OperationalException, RetryableOrderError
89
from freqtrade.exchange.common import API_RETRY_COUNT
9-
from freqtrade.util import dt_now, dt_ts
10+
from freqtrade.util import dt_now, dt_ts, dt_utc
1011
from tests.conftest import EXMS, get_patched_exchange
1112
from tests.exchange.test_exchange import ccxt_exceptionhandlers
1213

@@ -193,3 +194,43 @@ def test__lev_prep_bitget(default_conf, mocker):
193194
assert api_mock.set_margin_mode.call_count == 0
194195
assert api_mock.set_leverage.call_count == 1
195196
api_mock.set_leverage.assert_called_with(symbol="BTC/USDC:USDC", leverage=19.99)
197+
198+
199+
def test_check_delisting_time_bitget(default_conf_usdt, mocker):
200+
exchange = get_patched_exchange(mocker, default_conf_usdt, exchange="bitget")
201+
exchange._config["runmode"] = RunMode.BACKTEST
202+
delist_fut_mock = MagicMock(return_value=None)
203+
mocker.patch.object(exchange, "_check_delisting_futures", delist_fut_mock)
204+
205+
# Invalid run mode
206+
resp = exchange.check_delisting_time("BTC/USDT")
207+
assert resp is None
208+
assert delist_fut_mock.call_count == 0
209+
210+
# Delist spot called
211+
exchange._config["runmode"] = RunMode.DRY_RUN
212+
resp1 = exchange.check_delisting_time("BTC/USDT")
213+
assert resp1 is None
214+
assert delist_fut_mock.call_count == 0
215+
216+
# Delist futures called
217+
exchange.trading_mode = TradingMode.FUTURES
218+
resp1 = exchange.check_delisting_time("BTC/USDT:USDT")
219+
assert resp1 is None
220+
assert delist_fut_mock.call_count == 1
221+
222+
223+
def test__check_delisting_futures_bitget(default_conf_usdt, mocker, markets):
224+
markets["BTC/USDT:USDT"] = deepcopy(markets["SOL/BUSD:BUSD"])
225+
markets["BTC/USDT:USDT"]["info"]["limitOpenTime"] = "-1"
226+
markets["SOL/BUSD:BUSD"]["info"]["limitOpenTime"] = "-1"
227+
markets["ADA/USDT:USDT"]["info"]["limitOpenTime"] = "1760745600000" # 2025-10-18
228+
exchange = get_patched_exchange(mocker, default_conf_usdt, exchange="bitget")
229+
mocker.patch(f"{EXMS}.markets", PropertyMock(return_value=markets))
230+
231+
resp_sol = exchange._check_delisting_futures("SOL/BUSD:BUSD")
232+
# No delisting date
233+
assert resp_sol is None
234+
# Has a delisting date
235+
resp_ada = exchange._check_delisting_futures("ADA/USDT:USDT")
236+
assert resp_ada == dt_utc(2025, 10, 18)

0 commit comments

Comments
 (0)