From 4f7e2f9ec56c3be7243c47e0da53c5bc14fe5170 Mon Sep 17 00:00:00 2001 From: Guillaume De Saint Martin Date: Tue, 3 Oct 2023 11:25:34 +0200 Subject: [PATCH] [HistoryCollector] improve error description --- .../exchange_history_collector/history_collector.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/Backtesting/collectors/exchanges/exchange_history_collector/history_collector.py b/Backtesting/collectors/exchanges/exchange_history_collector/history_collector.py index 200ba080f..c4e54e3ac 100644 --- a/Backtesting/collectors/exchanges/exchange_history_collector/history_collector.py +++ b/Backtesting/collectors/exchanges/exchange_history_collector/history_collector.py @@ -184,6 +184,12 @@ async def check_timestamps(self): raise errors.DataCollectorError("start_timestamp is higher than end_timestamp") async def get_first_candle_timestamp(self, ideal_start_timestamp, symbol, time_frame): - return ( - await self.exchange.get_symbol_prices(str(symbol), time_frame, limit=1, since=ideal_start_timestamp) - )[0][commons_enums.PriceIndexes.IND_PRICE_TIME.value] + try: + return ( + await self.exchange.get_symbol_prices(str(symbol), time_frame, limit=1, since=ideal_start_timestamp) + )[0][commons_enums.PriceIndexes.IND_PRICE_TIME.value] + except (trading_errors.FailedRequest, IndexError) as err: + raise errors.DataCollectorError( + f"Impossible to initialize {self.exchange_name} data collector: {err}. This means that {symbol} " + f"for the {time_frame.value} time frame is not supported in this context on {self.exchange_name}." + )