Increase FreqtradeBot() code coverage

This commit is contained in:
Gerald Lonlas 2018-03-05 00:11:13 -08:00
parent ba664c4341
commit 1d43e04725
2 changed files with 86 additions and 24 deletions

View File

@ -115,7 +115,7 @@ class FreqtradeBot(object):
if new_state == State.STOPPED: if new_state == State.STOPPED:
time.sleep(1) time.sleep(1)
elif new_state == State.RUNNING: elif new_state == State.RUNNING:
min_secs = self.config['internals'].get( min_secs = self.config.get('internals', {}).get(
'process_throttle_secs', 'process_throttle_secs',
Constants.PROCESS_THROTTLE_SECS Constants.PROCESS_THROTTLE_SECS
) )

View File

@ -12,6 +12,7 @@ from typing import Dict, Optional
import arrow import arrow
import pytest import pytest
import requests import requests
import re
from sqlalchemy import create_engine from sqlalchemy import create_engine
from freqtrade.tests.conftest import log_has from freqtrade.tests.conftest import log_has
@ -110,20 +111,52 @@ def test_freqtradebot(mocker, default_conf) -> None:
assert freqtrade.get_state() is State.STOPPED assert freqtrade.get_state() is State.STOPPED
@pytest.mark.skip(reason="Test not implemented") def test_clean(mocker, default_conf, caplog) -> None:
def test_clean() -> None:
""" """
Test clean() method Test clean() method
""" """
pass mock_cleanup = MagicMock()
mocker.patch('freqtrade.persistence.cleanup', mock_cleanup)
freqtrade = get_patched_freqtradebot(mocker, default_conf)
assert freqtrade.get_state() == State.RUNNING
assert freqtrade.clean()
assert freqtrade.get_state() == State.STOPPED
assert log_has('Stopping trader and cleaning up modules...', caplog.record_tuples)
assert mock_cleanup.call_count == 1
@pytest.mark.skip(reason="Test not implemented") def test_worker_running(mocker, default_conf, caplog) -> None:
def test_worker() -> None:
""" """
Test worker() method Test worker() method. Test when we start the bot
""" """
pass mock_throttle = MagicMock()
mocker.patch('freqtrade.freqtradebot.FreqtradeBot._throttle', mock_throttle)
freqtrade = get_patched_freqtradebot(mocker, default_conf)
state = freqtrade.worker(old_state=None)
assert state is State.RUNNING
assert log_has('Changing state to: RUNNING', caplog.record_tuples)
assert mock_throttle.call_count == 1
def test_worker_stopped(mocker, default_conf, caplog) -> None:
"""
Test worker() method. Test when we stop the bot
"""
mock_throttle = MagicMock()
mocker.patch('freqtrade.freqtradebot.FreqtradeBot._throttle', mock_throttle)
mock_sleep = mocker.patch('time.sleep', return_value=None)
freqtrade = get_patched_freqtradebot(mocker, default_conf)
freqtrade.update_state(State.STOPPED)
state = freqtrade.worker(old_state=State.RUNNING)
assert state is State.STOPPED
assert log_has('Changing state to: STOPPED', caplog.record_tuples)
assert mock_throttle.call_count == 0
assert mock_sleep.call_count == 1
def test_throttle(mocker, default_conf, caplog) -> None: def test_throttle(mocker, default_conf, caplog) -> None:
@ -170,14 +203,6 @@ def test_throttle_with_assets(mocker, default_conf) -> None:
assert result == -1 assert result == -1
@pytest.mark.skip(reason="Test not implemented")
def test_process() -> None:
"""
Test _process() method
"""
pass
def test_gen_pair_whitelist(mocker, default_conf, get_market_summaries_data) -> None: def test_gen_pair_whitelist(mocker, default_conf, get_market_summaries_data) -> None:
""" """
Test _gen_pair_whitelist() method Test _gen_pair_whitelist() method
@ -478,14 +503,6 @@ def test_process_trade_handling(default_conf, ticker, limit_buy_order, health, m
assert result is False assert result is False
@pytest.mark.skip(reason="Test not implemented")
def test_get_target_bid():
"""
Test get_target_bid() method
"""
pass
def test_balance_fully_ask_side(mocker) -> None: def test_balance_fully_ask_side(mocker) -> None:
""" """
Test get_target_bid() method Test get_target_bid() method
@ -874,6 +891,51 @@ def test_check_handle_timedout_partial(default_conf, ticker, limit_buy_order_old
assert trades[0].stake_amount == trade_buy.open_rate * trades[0].amount assert trades[0].stake_amount == trade_buy.open_rate * trades[0].amount
def test_check_handle_timedout_exception(default_conf, ticker, mocker, caplog) -> None:
"""
Test check_handle_timedout() method when get_order throw an exception
"""
patch_RPCManager(mocker)
cancel_order_mock = MagicMock()
patch_pymarketcap(mocker)
mocker.patch.multiple(
'freqtrade.freqtradebot.FreqtradeBot',
handle_timedout_limit_buy=MagicMock(),
handle_timedout_limit_sell=MagicMock(),
)
mocker.patch.multiple(
'freqtrade.freqtradebot.exchange',
validate_pairs=MagicMock(),
get_ticker=ticker,
get_order=MagicMock(side_effect=requests.exceptions.RequestException('Oh snap')),
cancel_order=cancel_order_mock
)
freqtrade = FreqtradeBot(default_conf, create_engine('sqlite://'))
trade_buy = Trade(
pair='BTC_ETH',
open_rate=0.00001099,
exchange='BITTREX',
open_order_id='123456789',
amount=90.99181073,
fee=0.0,
stake_amount=1,
open_date=arrow.utcnow().shift(minutes=-601).datetime,
is_open=True
)
Trade.session.add(trade_buy)
regexp = re.compile(
'Cannot query order for Trade(id=1, pair=BTC_ETH, amount=90.99181073, '
'open_rate=0.00001099, open_since=10 hours ago) due to Traceback (most '
'recent call last):\n.*'
)
freqtrade.check_handle_timedout(600)
assert filter(regexp.match, caplog.record_tuples)
def test_handle_timedout_limit_buy(mocker, default_conf) -> None: def test_handle_timedout_limit_buy(mocker, default_conf) -> None:
""" """
Test handle_timedout_limit_buy() method Test handle_timedout_limit_buy() method