From 33b14aaa2344b0fd95d1629627c3d135b24ae102 Mon Sep 17 00:00:00 2001 From: TheSiahxyz <164138827+TheSiahxyz@users.noreply.github.com> Date: Wed, 1 Apr 2026 15:56:35 +0900 Subject: feat: initial trading platform implementation Binance spot crypto trading platform with microservices architecture: - shared: Pydantic models, Redis Streams broker, asyncpg DB layer - data-collector: Binance WebSocket/REST market data collection - strategy-engine: Plugin-based strategy execution (RSI, Grid) - order-executor: Order execution with risk management - portfolio-manager: Position tracking and PnL calculation - backtester: Historical strategy testing with simulator - cli: Click-based CLI for all operations - Docker Compose orchestration with Redis and PostgreSQL - 24 test files covering all modules --- cli/src/trading_cli/commands/backtest.py | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 cli/src/trading_cli/commands/backtest.py (limited to 'cli/src/trading_cli/commands/backtest.py') diff --git a/cli/src/trading_cli/commands/backtest.py b/cli/src/trading_cli/commands/backtest.py new file mode 100644 index 0000000..40617b6 --- /dev/null +++ b/cli/src/trading_cli/commands/backtest.py @@ -0,0 +1,26 @@ +import click + + +@click.group() +def backtest(): + """Backtesting commands.""" + pass + + +@backtest.command() +@click.option("--strategy", required=True, help="Strategy name to backtest") +@click.option("--symbol", required=True, help="Trading symbol (e.g. BTCUSDT)") +@click.option("--from", "from_date", required=True, help="Start date (ISO format)") +@click.option("--to", "to_date", default=None, help="End date (ISO format, defaults to now)") +@click.option("--balance", default=10000.0, show_default=True, help="Initial balance in USDT") +def run(strategy, symbol, from_date, to_date, balance): + """Run a backtest for a strategy.""" + to_label = to_date or "now" + click.echo(f"Running backtest: strategy={strategy}, symbol={symbol}, {from_date} → {to_label}, balance={balance}...") + + +@backtest.command() +@click.option("--id", "backtest_id", required=True, help="Backtest run ID") +def report(backtest_id): + """Show a backtest report by ID.""" + click.echo(f"Showing backtest report for ID: {backtest_id}...") -- cgit v1.2.3