parameterized TradingMode in persistence

This commit is contained in:
Sam Germain 2021-09-29 22:56:10 -06:00
parent 157223f6ab
commit ba60aad89d
2 changed files with 126 additions and 109 deletions

View File

@ -4421,3 +4421,7 @@ def test_get_valid_price(mocker, default_conf) -> None:
assert valid_price_at_min_alwd > custom_price_under_min_alwd assert valid_price_at_min_alwd > custom_price_under_min_alwd
assert valid_price_at_min_alwd < proposed_price assert valid_price_at_min_alwd < proposed_price
def test_update_funding_fees():
return

View File

@ -18,6 +18,9 @@ from tests.conftest import (create_mock_trades, create_mock_trades_with_leverage
log_has, log_has_re) log_has, log_has_re)
spot, margin = TradingMode.SPOT, TradingMode.MARGIN
def test_init_create_session(default_conf): def test_init_create_session(default_conf):
# Check if init create a session # Check if init create a session
init_db(default_conf['db_url'], default_conf['dry_run']) init_db(default_conf['db_url'], default_conf['dry_run'])
@ -83,7 +86,7 @@ def test_enter_exit_side(fee, is_short):
exchange='binance', exchange='binance',
is_short=is_short, is_short=is_short,
leverage=2.0, leverage=2.0,
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
assert trade.enter_side == enter_side assert trade.enter_side == enter_side
assert trade.exit_side == exit_side assert trade.exit_side == exit_side
@ -104,7 +107,7 @@ def test_set_stop_loss_isolated_liq(fee):
exchange='binance', exchange='binance',
is_short=False, is_short=False,
leverage=2.0, leverage=2.0,
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
trade.set_isolated_liq(0.09) trade.set_isolated_liq(0.09)
assert trade.isolated_liq == 0.09 assert trade.isolated_liq == 0.09
@ -171,32 +174,33 @@ def test_set_stop_loss_isolated_liq(fee):
assert trade.initial_stop_loss == 0.09 assert trade.initial_stop_loss == 0.09
@pytest.mark.parametrize('exchange,is_short,lev,minutes,rate,interest', [ @pytest.mark.parametrize('exchange,is_short,lev,minutes,rate,interest,trading_mode', [
("binance", False, 3, 10, 0.0005, round(0.0008333333333333334, 8)), ("binance", False, 3, 10, 0.0005, round(0.0008333333333333334, 8), margin),
("binance", True, 3, 10, 0.0005, 0.000625), ("binance", True, 3, 10, 0.0005, 0.000625, margin),
("binance", False, 3, 295, 0.0005, round(0.004166666666666667, 8)), ("binance", False, 3, 295, 0.0005, round(0.004166666666666667, 8), margin),
("binance", True, 3, 295, 0.0005, round(0.0031249999999999997, 8)), ("binance", True, 3, 295, 0.0005, round(0.0031249999999999997, 8), margin),
("binance", False, 3, 295, 0.00025, round(0.0020833333333333333, 8)), ("binance", False, 3, 295, 0.00025, round(0.0020833333333333333, 8), margin),
("binance", True, 3, 295, 0.00025, round(0.0015624999999999999, 8)), ("binance", True, 3, 295, 0.00025, round(0.0015624999999999999, 8), margin),
("binance", False, 5, 295, 0.0005, 0.005), ("binance", False, 5, 295, 0.0005, 0.005, margin),
("binance", True, 5, 295, 0.0005, round(0.0031249999999999997, 8)), ("binance", True, 5, 295, 0.0005, round(0.0031249999999999997, 8), margin),
("binance", False, 1, 295, 0.0005, 0.0), ("binance", False, 1, 295, 0.0005, 0.0, spot),
("binance", True, 1, 295, 0.0005, 0.003125), ("binance", True, 1, 295, 0.0005, 0.003125, margin),
("kraken", False, 3, 10, 0.0005, 0.040), ("kraken", False, 3, 10, 0.0005, 0.040, margin),
("kraken", True, 3, 10, 0.0005, 0.030), ("kraken", True, 3, 10, 0.0005, 0.030, margin),
("kraken", False, 3, 295, 0.0005, 0.06), ("kraken", False, 3, 295, 0.0005, 0.06, margin),
("kraken", True, 3, 295, 0.0005, 0.045), ("kraken", True, 3, 295, 0.0005, 0.045, margin),
("kraken", False, 3, 295, 0.00025, 0.03), ("kraken", False, 3, 295, 0.00025, 0.03, margin),
("kraken", True, 3, 295, 0.00025, 0.0225), ("kraken", True, 3, 295, 0.00025, 0.0225, margin),
("kraken", False, 5, 295, 0.0005, round(0.07200000000000001, 8)), ("kraken", False, 5, 295, 0.0005, round(0.07200000000000001, 8), margin),
("kraken", True, 5, 295, 0.0005, 0.045), ("kraken", True, 5, 295, 0.0005, 0.045, margin),
("kraken", False, 1, 295, 0.0005, 0.0), ("kraken", False, 1, 295, 0.0005, 0.0, spot),
("kraken", True, 1, 295, 0.0005, 0.045), ("kraken", True, 1, 295, 0.0005, 0.045, margin),
]) ])
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")
def test_interest(market_buy_order_usdt, fee, exchange, is_short, lev, minutes, rate, interest): def test_interest(market_buy_order_usdt, fee, exchange, is_short, lev, minutes, rate, interest,
trading_mode):
""" """
10min, 5hr limit trade on Binance/Kraken at 3x,5x leverage 10min, 5hr limit trade on Binance/Kraken at 3x,5x leverage
fee: 0.25 % quote fee: 0.25 % quote
@ -262,21 +266,21 @@ def test_interest(market_buy_order_usdt, fee, exchange, is_short, lev, minutes,
leverage=lev, leverage=lev,
interest_rate=rate, interest_rate=rate,
is_short=is_short, is_short=is_short,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
assert round(float(trade.calculate_interest()), 8) == interest assert round(float(trade.calculate_interest()), 8) == interest
@pytest.mark.parametrize('is_short,lev,borrowed', [ @pytest.mark.parametrize('is_short,lev,borrowed,trading_mode', [
(False, 1.0, 0.0), (False, 1.0, 0.0, spot),
(True, 1.0, 30.0), (True, 1.0, 30.0, margin),
(False, 3.0, 40.0), (False, 3.0, 40.0, margin),
(True, 3.0, 30.0), (True, 3.0, 30.0, margin),
]) ])
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")
def test_borrowed(limit_buy_order_usdt, limit_sell_order_usdt, fee, def test_borrowed(limit_buy_order_usdt, limit_sell_order_usdt, fee,
caplog, is_short, lev, borrowed): caplog, is_short, lev, borrowed, trading_mode):
""" """
10 minute limit trade on Binance/Kraken at 1x, 3x leverage 10 minute limit trade on Binance/Kraken at 1x, 3x leverage
fee: 0.25% quote fee: 0.25% quote
@ -352,18 +356,18 @@ def test_borrowed(limit_buy_order_usdt, limit_sell_order_usdt, fee,
exchange='binance', exchange='binance',
is_short=is_short, is_short=is_short,
leverage=lev, leverage=lev,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
assert trade.borrowed == borrowed assert trade.borrowed == borrowed
@pytest.mark.parametrize('is_short,open_rate,close_rate,lev,profit', [ @pytest.mark.parametrize('is_short,open_rate,close_rate,lev,profit,trading_mode', [
(False, 2.0, 2.2, 1.0, round(0.0945137157107232, 8)), (False, 2.0, 2.2, 1.0, round(0.0945137157107232, 8), spot),
(True, 2.2, 2.0, 3.0, round(0.2589996297562085, 8)) (True, 2.2, 2.0, 3.0, round(0.2589996297562085, 8), margin),
]) ])
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")
def test_update_limit_order(fee, caplog, limit_buy_order_usdt, limit_sell_order_usdt, def test_update_limit_order(fee, caplog, limit_buy_order_usdt, limit_sell_order_usdt,
is_short, open_rate, close_rate, lev, profit): is_short, open_rate, close_rate, lev, profit, trading_mode):
""" """
10 minute limit trade on Binance/Kraken at 1x, 3x leverage 10 minute limit trade on Binance/Kraken at 1x, 3x leverage
fee: 0.25% quote fee: 0.25% quote
@ -451,7 +455,7 @@ def test_update_limit_order(fee, caplog, limit_buy_order_usdt, limit_sell_order_
is_short=is_short, is_short=is_short,
interest_rate=0.0005, interest_rate=0.0005,
leverage=lev, leverage=lev,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
assert trade.open_order_id is None assert trade.open_order_id is None
assert trade.close_profit is None assert trade.close_profit is None
@ -497,7 +501,7 @@ def test_update_market_order(market_buy_order_usdt, market_sell_order_usdt, fee,
fee_close=fee.return_value, fee_close=fee.return_value,
open_date=arrow.utcnow().datetime, open_date=arrow.utcnow().datetime,
exchange='binance', exchange='binance',
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
trade.open_order_id = 'something' trade.open_order_id = 'something'
@ -525,20 +529,22 @@ def test_update_market_order(market_buy_order_usdt, market_sell_order_usdt, fee,
caplog) caplog)
@pytest.mark.parametrize('exchange,is_short,lev,open_value,close_value,profit,profit_ratio', [ @pytest.mark.parametrize(
("binance", False, 1, 60.15, 65.835, 5.685, 0.0945137157107232), 'exchange,is_short,lev,open_value,close_value,profit,profit_ratio,trading_mode', [
("binance", True, 1, 59.850, 66.1663784375, -6.316378437500013, -0.1055368159983292), ("binance", False, 1, 60.15, 65.835, 5.685, 0.0945137157107232, spot),
("binance", False, 3, 60.15, 65.83416667, 5.684166670000003, 0.2834995845386534), ("binance", True, 1, 59.850, 66.1663784375, -6.316378437500013, -0.105536815998329, margin),
("binance", True, 3, 59.85, 66.1663784375, -6.316378437500013, -0.3166104479949876), ("binance", False, 3, 60.15, 65.83416667, 5.684166670000003, 0.2834995845386534, margin),
("binance", True, 3, 59.85, 66.1663784375, -6.316378437500013, -0.3166104479949876, margin),
("kraken", False, 1, 60.15, 65.835, 5.685, 0.0945137157107232), ("kraken", False, 1, 60.15, 65.835, 5.685, 0.0945137157107232, spot),
("kraken", True, 1, 59.850, 66.231165, -6.381165, -0.106619298245614), ("kraken", True, 1, 59.850, 66.231165, -6.381165, -0.106619298245614, margin),
("kraken", False, 3, 60.15, 65.795, 5.645, 0.2815461346633419), ("kraken", False, 3, 60.15, 65.795, 5.645, 0.2815461346633419, margin),
("kraken", True, 3, 59.850, 66.231165, -6.381165000000003, -0.319857894736842), ("kraken", True, 3, 59.850, 66.231165, -6.381165000000003, -0.319857894736842, margin),
]) ])
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")
def test_calc_open_close_trade_price(limit_buy_order_usdt, limit_sell_order_usdt, fee, exchange, def test_calc_open_close_trade_price(
is_short, lev, open_value, close_value, profit, profit_ratio): limit_buy_order_usdt, limit_sell_order_usdt, fee, exchange, is_short, lev,
open_value, close_value, profit, profit_ratio, trading_mode
):
trade: Trade = Trade( trade: Trade = Trade(
pair='ADA/USDT', pair='ADA/USDT',
stake_amount=60.0, stake_amount=60.0,
@ -551,7 +557,7 @@ def test_calc_open_close_trade_price(limit_buy_order_usdt, limit_sell_order_usdt
exchange=exchange, exchange=exchange,
is_short=is_short, is_short=is_short,
leverage=lev, leverage=lev,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
trade.open_order_id = f'something-{is_short}-{lev}-{exchange}' trade.open_order_id = f'something-{is_short}-{lev}-{exchange}'
@ -580,7 +586,7 @@ def test_trade_close(limit_buy_order_usdt, limit_sell_order_usdt, fee):
open_date=datetime.now(tz=timezone.utc) - timedelta(minutes=10), open_date=datetime.now(tz=timezone.utc) - timedelta(minutes=10),
interest_rate=0.0005, interest_rate=0.0005,
exchange='binance', exchange='binance',
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
assert trade.close_profit is None assert trade.close_profit is None
assert trade.close_date is None assert trade.close_date is None
@ -609,7 +615,7 @@ def test_calc_close_trade_price_exception(limit_buy_order_usdt, fee):
fee_open=fee.return_value, fee_open=fee.return_value,
fee_close=fee.return_value, fee_close=fee.return_value,
exchange='binance', exchange='binance',
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
trade.open_order_id = 'something' trade.open_order_id = 'something'
@ -627,7 +633,7 @@ def test_update_open_order(limit_buy_order_usdt):
fee_open=0.1, fee_open=0.1,
fee_close=0.1, fee_close=0.1,
exchange='binance', exchange='binance',
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
assert trade.open_order_id is None assert trade.open_order_id is None
@ -652,7 +658,7 @@ def test_update_invalid_order(limit_buy_order_usdt):
fee_open=0.1, fee_open=0.1,
fee_close=0.1, fee_close=0.1,
exchange='binance', exchange='binance',
trading_mode=TradingMode.MARGIN trading_mode=margin
) )
limit_buy_order_usdt['type'] = 'invalid' limit_buy_order_usdt['type'] = 'invalid'
with pytest.raises(ValueError, match=r'Unknown order type'): with pytest.raises(ValueError, match=r'Unknown order type'):
@ -660,6 +666,7 @@ def test_update_invalid_order(limit_buy_order_usdt):
@pytest.mark.parametrize('exchange', ['binance', 'kraken']) @pytest.mark.parametrize('exchange', ['binance', 'kraken'])
@pytest.mark.parametrize('trading_mode', [spot, margin])
@pytest.mark.parametrize('lev', [1, 3]) @pytest.mark.parametrize('lev', [1, 3])
@pytest.mark.parametrize('is_short,fee_rate,result', [ @pytest.mark.parametrize('is_short,fee_rate,result', [
(False, 0.003, 60.18), (False, 0.003, 60.18),
@ -678,7 +685,8 @@ def test_calc_open_trade_value(
lev, lev,
is_short, is_short,
fee_rate, fee_rate,
result result,
trading_mode
): ):
# 10 minute limit trade on Binance/Kraken at 1x, 3x leverage # 10 minute limit trade on Binance/Kraken at 1x, 3x leverage
# fee: 0.25 %, 0.3% quote # fee: 0.25 %, 0.3% quote
@ -705,7 +713,7 @@ def test_calc_open_trade_value(
exchange=exchange, exchange=exchange,
leverage=lev, leverage=lev,
is_short=is_short, is_short=is_short,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
trade.open_order_id = 'open_trade' trade.open_order_id = 'open_trade'
@ -713,26 +721,29 @@ def test_calc_open_trade_value(
assert trade._calc_open_trade_value() == result assert trade._calc_open_trade_value() == result
@pytest.mark.parametrize('exchange,is_short,lev,open_rate,close_rate,fee_rate,result', [ @pytest.mark.parametrize(
('binance', False, 1, 2.0, 2.5, 0.0025, 74.8125), 'exchange,is_short,lev,open_rate,close_rate,fee_rate,result,trading_mode', [
('binance', False, 1, 2.0, 2.5, 0.003, 74.775), ('binance', False, 1, 2.0, 2.5, 0.0025, 74.8125, spot),
('binance', False, 1, 2.0, 2.2, 0.005, 65.67), ('binance', False, 1, 2.0, 2.5, 0.003, 74.775, spot),
('binance', False, 3, 2.0, 2.5, 0.0025, 74.81166667), ('binance', False, 1, 2.0, 2.2, 0.005, 65.67, margin),
('binance', False, 3, 2.0, 2.5, 0.003, 74.77416667), ('binance', False, 3, 2.0, 2.5, 0.0025, 74.81166667, margin),
('kraken', False, 3, 2.0, 2.5, 0.0025, 74.7725), ('binance', False, 3, 2.0, 2.5, 0.003, 74.77416667, margin),
('kraken', False, 3, 2.0, 2.5, 0.003, 74.735), ('kraken', False, 3, 2.0, 2.5, 0.0025, 74.7725, margin),
('kraken', True, 3, 2.2, 2.5, 0.0025, 75.2626875), ('kraken', False, 3, 2.0, 2.5, 0.003, 74.735, margin),
('kraken', True, 3, 2.2, 2.5, 0.003, 75.300225), ('kraken', True, 3, 2.2, 2.5, 0.0025, 75.2626875, margin),
('binance', True, 3, 2.2, 2.5, 0.0025, 75.18906641), ('kraken', True, 3, 2.2, 2.5, 0.003, 75.300225, margin),
('binance', True, 3, 2.2, 2.5, 0.003, 75.22656719), ('binance', True, 3, 2.2, 2.5, 0.0025, 75.18906641, margin),
('binance', True, 1, 2.2, 2.5, 0.0025, 75.18906641), ('binance', True, 3, 2.2, 2.5, 0.003, 75.22656719, margin),
('binance', True, 1, 2.2, 2.5, 0.003, 75.22656719), ('binance', True, 1, 2.2, 2.5, 0.0025, 75.18906641, margin),
('kraken', True, 1, 2.2, 2.5, 0.0025, 75.2626875), ('binance', True, 1, 2.2, 2.5, 0.003, 75.22656719, margin),
('kraken', True, 1, 2.2, 2.5, 0.003, 75.300225), ('kraken', True, 1, 2.2, 2.5, 0.0025, 75.2626875, margin),
]) ('kraken', True, 1, 2.2, 2.5, 0.003, 75.300225, margin),
])
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")
def test_calc_close_trade_price(limit_buy_order_usdt, limit_sell_order_usdt, open_rate, def test_calc_close_trade_price(
exchange, is_short, lev, close_rate, fee_rate, result): limit_buy_order_usdt, limit_sell_order_usdt, open_rate, exchange, is_short,
lev, close_rate, fee_rate, result, trading_mode
):
trade = Trade( trade = Trade(
pair='ADA/USDT', pair='ADA/USDT',
stake_amount=60.0, stake_amount=60.0,
@ -745,47 +756,48 @@ def test_calc_close_trade_price(limit_buy_order_usdt, limit_sell_order_usdt, ope
interest_rate=0.0005, interest_rate=0.0005,
is_short=is_short, is_short=is_short,
leverage=lev, leverage=lev,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
trade.open_order_id = 'close_trade' trade.open_order_id = 'close_trade'
assert round(trade.calc_close_trade_value(rate=close_rate, fee=fee_rate), 8) == result assert round(trade.calc_close_trade_value(rate=close_rate, fee=fee_rate), 8) == result
@pytest.mark.parametrize('exchange,is_short,lev,close_rate,fee_close,profit,profit_ratio', [ @pytest.mark.parametrize(
('binance', False, 1, 2.1, 0.0025, 2.6925, 0.04476309226932673), 'exchange,is_short,lev,close_rate,fee_close,profit,profit_ratio,trading_mode', [
('binance', False, 3, 2.1, 0.0025, 2.69166667, 0.13424771421446402), ('binance', False, 1, 2.1, 0.0025, 2.6925, 0.04476309226932673, spot),
('binance', True, 1, 2.1, 0.0025, -3.308815781249997, -0.05528514254385963), ('binance', False, 3, 2.1, 0.0025, 2.69166667, 0.13424771421446402, margin),
('binance', True, 3, 2.1, 0.0025, -3.308815781249997, -0.1658554276315789), ('binance', True, 1, 2.1, 0.0025, -3.308815781249997, -0.05528514254385963, margin),
('binance', True, 3, 2.1, 0.0025, -3.308815781249997, -0.1658554276315789, margin),
('binance', False, 1, 1.9, 0.0025, -3.2925, -0.05473815461346632), ('binance', False, 1, 1.9, 0.0025, -3.2925, -0.05473815461346632, margin),
('binance', False, 3, 1.9, 0.0025, -3.29333333, -0.16425602643391513), ('binance', False, 3, 1.9, 0.0025, -3.29333333, -0.16425602643391513, margin),
('binance', True, 1, 1.9, 0.0025, 2.7063095312499996, 0.045218204365079395), ('binance', True, 1, 1.9, 0.0025, 2.7063095312499996, 0.045218204365079395, margin),
('binance', True, 3, 1.9, 0.0025, 2.7063095312499996, 0.13565461309523819), ('binance', True, 3, 1.9, 0.0025, 2.7063095312499996, 0.13565461309523819, margin),
('binance', False, 1, 2.2, 0.0025, 5.685, 0.0945137157107232), ('binance', False, 1, 2.2, 0.0025, 5.685, 0.0945137157107232, margin),
('binance', False, 3, 2.2, 0.0025, 5.68416667, 0.2834995845386534), ('binance', False, 3, 2.2, 0.0025, 5.68416667, 0.2834995845386534, margin),
('binance', True, 1, 2.2, 0.0025, -6.316378437499999, -0.1055368159983292), ('binance', True, 1, 2.2, 0.0025, -6.316378437499999, -0.1055368159983292, margin),
('binance', True, 3, 2.2, 0.0025, -6.316378437499999, -0.3166104479949876), ('binance', True, 3, 2.2, 0.0025, -6.316378437499999, -0.3166104479949876, margin),
('kraken', False, 1, 2.1, 0.0025, 2.6925, 0.04476309226932673), ('kraken', False, 1, 2.1, 0.0025, 2.6925, 0.04476309226932673, spot),
('kraken', False, 3, 2.1, 0.0025, 2.6525, 0.13229426433915248), ('kraken', False, 3, 2.1, 0.0025, 2.6525, 0.13229426433915248, margin),
('kraken', True, 1, 2.1, 0.0025, -3.3706575, -0.05631842105263152), ('kraken', True, 1, 2.1, 0.0025, -3.3706575, -0.05631842105263152, margin),
('kraken', True, 3, 2.1, 0.0025, -3.3706575, -0.16895526315789455), ('kraken', True, 3, 2.1, 0.0025, -3.3706575, -0.16895526315789455, margin),
('kraken', False, 1, 1.9, 0.0025, -3.2925, -0.05473815461346632), ('kraken', False, 1, 1.9, 0.0025, -3.2925, -0.05473815461346632, margin),
('kraken', False, 3, 1.9, 0.0025, -3.3325, -0.16620947630922667), ('kraken', False, 3, 1.9, 0.0025, -3.3325, -0.16620947630922667, margin),
('kraken', True, 1, 1.9, 0.0025, 2.6503575, 0.04428333333333334), ('kraken', True, 1, 1.9, 0.0025, 2.6503575, 0.04428333333333334, margin),
('kraken', True, 3, 1.9, 0.0025, 2.6503575, 0.13285000000000002), ('kraken', True, 3, 1.9, 0.0025, 2.6503575, 0.13285000000000002, margin),
('kraken', False, 1, 2.2, 0.0025, 5.685, 0.0945137157107232), ('kraken', False, 1, 2.2, 0.0025, 5.685, 0.0945137157107232, margin),
('kraken', False, 3, 2.2, 0.0025, 5.645, 0.2815461346633419), ('kraken', False, 3, 2.2, 0.0025, 5.645, 0.2815461346633419, margin),
('kraken', True, 1, 2.2, 0.0025, -6.381165, -0.106619298245614), ('kraken', True, 1, 2.2, 0.0025, -6.381165, -0.106619298245614, margin),
('kraken', True, 3, 2.2, 0.0025, -6.381165, -0.319857894736842), ('kraken', True, 3, 2.2, 0.0025, -6.381165, -0.319857894736842, margin),
('binance', False, 1, 2.1, 0.003, 2.6610000000000014, 0.04423940149625927), ('binance', False, 1, 2.1, 0.003, 2.6610000000000014, 0.04423940149625927, spot),
('binance', False, 1, 1.9, 0.003, -3.320999999999998, -0.05521197007481293), ('binance', False, 1, 1.9, 0.003, -3.320999999999998, -0.05521197007481293, spot),
('binance', False, 1, 2.2, 0.003, 5.652000000000008, 0.09396508728179565), ('binance', False, 1, 2.2, 0.003, 5.652000000000008, 0.09396508728179565, spot),
]) ])
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")
def test_calc_profit( def test_calc_profit(
limit_buy_order_usdt, limit_buy_order_usdt,
@ -797,7 +809,8 @@ def test_calc_profit(
close_rate, close_rate,
fee_close, fee_close,
profit, profit,
profit_ratio profit_ratio,
trading_mode
): ):
""" """
10 minute limit trade on Binance/Kraken at 1x, 3x leverage 10 minute limit trade on Binance/Kraken at 1x, 3x leverage
@ -940,7 +953,7 @@ def test_calc_profit(
leverage=lev, leverage=lev,
fee_open=0.0025, fee_open=0.0025,
fee_close=fee_close, fee_close=fee_close,
trading_mode=TradingMode.MARGIN trading_mode=trading_mode
) )
trade.open_order_id = 'something' trade.open_order_id = 'something'