mirror of
https://github.com/wassname/catalyst.git
synced 2026-06-30 22:01:30 +08:00
145 lines
4.4 KiB
Python
145 lines
4.4 KiB
Python
import random
|
|
|
|
import pandas as pd
|
|
from logbook import Logger
|
|
from pandas.util.testing import assert_frame_equal
|
|
|
|
from catalyst import get_calendar
|
|
from catalyst.exchange.exchange_asset_finder import ExchangeAssetFinder
|
|
from catalyst.exchange.exchange_data_portal import DataPortalExchangeBacktest
|
|
from catalyst.exchange.exchange_utils import get_candles_df
|
|
from catalyst.exchange.factory import get_exchange
|
|
from catalyst.exchange.test_utils import output_df, \
|
|
select_random_assets
|
|
|
|
log = Logger('TestSuiteExchange')
|
|
|
|
pd.set_option('display.expand_frame_repr', False)
|
|
pd.set_option('precision', 8)
|
|
pd.set_option('display.width', 1000)
|
|
pd.set_option('display.max_colwidth', 1000)
|
|
|
|
|
|
class TestSuiteBundle:
|
|
@staticmethod
|
|
def get_data_portal(exchange_names):
|
|
open_calendar = get_calendar('OPEN')
|
|
asset_finder = ExchangeAssetFinder()
|
|
|
|
data_portal = DataPortalExchangeBacktest(
|
|
exchange_names=exchange_names,
|
|
asset_finder=asset_finder,
|
|
trading_calendar=open_calendar,
|
|
first_trading_day=None # will set dynamically based on assets
|
|
)
|
|
return data_portal
|
|
|
|
def compare_bundle_with_exchange(self, exchange, assets, end_dt, bar_count,
|
|
freq, data_frequency, data_portal):
|
|
"""
|
|
Creates DataFrames from the bundle and exchange for the specified
|
|
data set.
|
|
|
|
Parameters
|
|
----------
|
|
exchange: Exchange
|
|
assets
|
|
end_dt
|
|
bar_count
|
|
sample_minutes
|
|
|
|
Returns
|
|
-------
|
|
|
|
"""
|
|
data = dict()
|
|
|
|
log.info('creating data sample from bundle')
|
|
data['bundle'] = data_portal.get_history_window(
|
|
assets=assets,
|
|
end_dt=end_dt,
|
|
bar_count=bar_count,
|
|
frequency=freq,
|
|
field='close',
|
|
data_frequency=data_frequency,
|
|
)
|
|
log.info('bundle data:\n{}'.format(
|
|
data['bundle'].tail(10))
|
|
)
|
|
|
|
log.info('creating data sample from exchange api')
|
|
candles = exchange.get_candles(
|
|
end_dt=end_dt,
|
|
freq=freq,
|
|
assets=assets,
|
|
bar_count=bar_count,
|
|
)
|
|
data['exchange'] = get_candles_df(
|
|
candles=candles,
|
|
field='close',
|
|
freq=freq,
|
|
bar_count=bar_count,
|
|
end_dt=end_dt,
|
|
)
|
|
log.info('exchange data:\n{}'.format(
|
|
data['exchange'].tail(10))
|
|
)
|
|
for source in data:
|
|
df = data[source]
|
|
path = output_df(df, assets, '{}_{}'.format(freq, source))
|
|
log.info('saved {}:\n{}'.format(source, path))
|
|
|
|
assert_frame_equal(
|
|
right=data['bundle'],
|
|
left=data['exchange'],
|
|
check_less_precise=True,
|
|
)
|
|
|
|
def test_validate_bundles(self):
|
|
exchange_population = 3
|
|
asset_population = 3
|
|
data_frequency = random.choice(['minute', 'daily'])
|
|
|
|
bundle = 'dailyBundle' if data_frequency == 'daily' else 'minuteBundle'
|
|
# exchanges = select_random_exchanges(
|
|
# population=exchange_population,
|
|
# features=[bundle],
|
|
# ) # Type: list[Exchange]
|
|
exchanges = [get_exchange('bitfinex', skip_init=True)]
|
|
|
|
data_portal = TestSuiteBundle.get_data_portal(
|
|
[exchange.name for exchange in exchanges]
|
|
)
|
|
for exchange in exchanges:
|
|
exchange.init()
|
|
|
|
frequencies = exchange.get_candle_frequencies(data_frequency)
|
|
freq = random.sample(frequencies, 1)[0]
|
|
|
|
bar_count = random.randint(1, 10)
|
|
|
|
assets = select_random_assets(
|
|
exchange.assets, asset_population
|
|
)
|
|
end_dt = None
|
|
for asset in assets:
|
|
attribute = 'end_{}'.format(data_frequency)
|
|
asset_end_dt = getattr(asset, attribute)
|
|
|
|
if end_dt is None or asset_end_dt < end_dt:
|
|
end_dt = asset_end_dt
|
|
|
|
dt_range = pd.date_range(
|
|
end=end_dt, periods=bar_count, freq=freq
|
|
)
|
|
self.compare_bundle_with_exchange(
|
|
exchange=exchange,
|
|
assets=assets,
|
|
end_dt=dt_range[-1],
|
|
bar_count=bar_count,
|
|
freq=freq,
|
|
data_frequency=data_frequency,
|
|
data_portal=data_portal,
|
|
)
|
|
pass
|