temp test commit

This commit is contained in:
misagh 2019-01-09 16:23:13 +01:00
parent 1a27258469
commit e025ad3918
2 changed files with 69 additions and 1 deletions

View File

@ -656,12 +656,14 @@ class FreqtradeBot(object):
# This is a guard: there is a situation where market is going doing down fast # This is a guard: there is a situation where market is going doing down fast
# the stoploss on exchange checked previously is not hit but # the stoploss on exchange checked previously is not hit but
# it is too late and too risky to cancel the previous stoploss # it is too late and too risky to cancel the previous stoploss
if trade.stop_loss <= self.exchange.get_ticker(trade.pair)['bid']: if trade.stop_loss > self.exchange.get_ticker(trade.pair)['bid']:
logger.info('stoploss on exchange update: too risky to update stoploss as ' logger.info('stoploss on exchange update: too risky to update stoploss as '
'current best bid price (%s) is higher than stoploss value (%s)', 'current best bid price (%s) is higher than stoploss value (%s)',
self.exchange.get_ticker(trade.pair)['bid'], trade.stop_loss) self.exchange.get_ticker(trade.pair)['bid'], trade.stop_loss)
return result return result
print(trade.stop_loss)
print(order['info']['stopPrice'])
if trade.stop_loss > order['info']['stopPrice']: if trade.stop_loss > order['info']['stopPrice']:
# we check also if the update is neccesary # we check also if the update is neccesary
update_beat = self.strategy.order_types['stoploss_on_exchange_interval'] update_beat = self.strategy.order_types['stoploss_on_exchange_interval']

View File

@ -1014,6 +1014,72 @@ def test_handle_stoploss_on_exchange(mocker, default_conf, fee, caplog,
assert trade.is_open is False assert trade.is_open is False
def test_handle_stoploss_on_exchange_trailing(mocker, default_conf, fee, caplog,
markets, limit_buy_order, limit_sell_order) -> None:
# When trailing stoploss is set
stoploss_limit = MagicMock(return_value={'id': 13434334})
patch_RPCManager(mocker)
patch_exchange(mocker)
mocker.patch.multiple(
'freqtrade.exchange.Exchange',
get_ticker=MagicMock(return_value={
'bid': 0.00001172,
'ask': 0.00001173,
'last': 0.00001172
}),
buy=MagicMock(return_value={'id': limit_buy_order['id']}),
sell=MagicMock(return_value={'id': limit_sell_order['id']}),
get_fee=fee,
get_markets=markets,
stoploss_limit=stoploss_limit
)
default_conf['trailing_stop'] = True
freqtrade = FreqtradeBot(default_conf)
freqtrade.strategy.stoploss = -0.05
patch_get_signal(freqtrade)
freqtrade.create_trade()
trade = Trade.query.first()
trade.is_open = True
trade.open_order_id = None
trade.stoploss_order_id = 100
stoploss_order_hanging = MagicMock(return_value={
'id': 100,
'status': 'open',
'type': 'stop_loss_limit',
'price': 3,
'average': 2,
'info' : {
'stopPrice': 1.113399999
}
})
mocker.patch('freqtrade.exchange.Exchange.get_order', stoploss_order_hanging)
# stoploss initially at 5%
assert freqtrade.handle_trade(trade) is False
# price jumped 2x
trade.max_rate = trade.open_rate * 2
assert freqtrade.handle_trade(trade) is False
assert freqtrade.handle_stoploss_on_exchange(trade) is False
assert trade.stop_loss == (trade.open_rate * 2) * 0.95
stoploss_order_hit = MagicMock(return_value={
'status': 'open',
'type': 'stop_loss_limit',
'price': 3,
'average': 2
})
mocker.patch('freqtrade.exchange.Exchange.get_order', stoploss_order_hit)
assert freqtrade.handle_stoploss_on_exchange(trade) is False
assert log_has('STOP_LOSS_LIMIT is hit for {}.'.format(trade), caplog.record_tuples)
assert trade.stoploss_order_id is None
assert trade.is_open is False
def test_process_maybe_execute_buy(mocker, default_conf) -> None: def test_process_maybe_execute_buy(mocker, default_conf) -> None:
freqtrade = get_patched_freqtradebot(mocker, default_conf) freqtrade = get_patched_freqtradebot(mocker, default_conf)