feat: productionize local service — fix signal pipeline, lower thresholds, add company-name ticker extraction
- Point Ollama to local instance via host.docker.internal, use gemma3 model - Remove Docker Ollama service (using host's Ollama instead) - Add company-name-to-ticker mapping (Apple→AAPL, Tesla→TSLA, etc.) for RSS articles - Lower signal thresholds for faster feedback with paper trading: - FinBERT confidence: 0.6→0.4, signal strength: 0.3→0.15 - News strategy: article_count 2→1, confidence 0.5→0.3, score ±0.3→±0.15 - Fix market data BarSet access bug (BarSet.__contains__ returns False incorrectly) - Fix market data SIP feed error by switching to IEX feed for free Alpaca accounts - Fix nginx proxy routing for /api/auth/* to api-gateway /auth/* - Add seed_sample_data script - Update tests for new thresholds and alpaca mock modules
This commit is contained in:
parent
67e64fab18
commit
d36ae40df1
18 changed files with 749 additions and 185 deletions
|
|
@ -188,9 +188,10 @@ class TestTradesListEndpoint:
|
|||
trade.signal_id = None
|
||||
trade.created_at = datetime(2024, 1, 1, tzinfo=timezone.utc)
|
||||
|
||||
# session.execute will be called twice: count + data
|
||||
# session.execute is called twice: count + data (now returns tuples)
|
||||
count_result = _make_execute_result([], scalar=1)
|
||||
data_result = _make_execute_result([trade])
|
||||
data_result = MagicMock()
|
||||
data_result.all.return_value = [(trade, None)] # (Trade, strategy_name)
|
||||
session.execute = AsyncMock(side_effect=[count_result, data_result])
|
||||
|
||||
resp = client.get("/api/trades")
|
||||
|
|
@ -242,8 +243,11 @@ class TestStrategiesEndpoint:
|
|||
strategy.active = True
|
||||
strategy.created_at = datetime(2024, 1, 1, tzinfo=timezone.utc)
|
||||
|
||||
# First call: list strategies; subsequent calls: trades per strategy
|
||||
strategies_result = _make_execute_result([strategy])
|
||||
trades_result = _make_execute_result([]) # no trades
|
||||
session.execute = AsyncMock(
|
||||
return_value=_make_execute_result([strategy])
|
||||
side_effect=[strategies_result, trades_result]
|
||||
)
|
||||
|
||||
resp = client.get("/api/strategies")
|
||||
|
|
|
|||
|
|
@ -97,6 +97,9 @@ def _install_alpaca_mocks():
|
|||
historical_mod = ModuleType("alpaca.data.historical")
|
||||
historical_mod.StockHistoricalDataClient = MagicMock
|
||||
|
||||
enums_mod = ModuleType("alpaca.data.enums")
|
||||
enums_mod.DataFeed = MagicMock()
|
||||
|
||||
# Build the package hierarchy
|
||||
alpaca_mod = sys.modules.get("alpaca") or ModuleType("alpaca")
|
||||
data_mod = sys.modules.get("alpaca.data") or ModuleType("alpaca.data")
|
||||
|
|
@ -106,6 +109,7 @@ def _install_alpaca_mocks():
|
|||
sys.modules["alpaca.data.timeframe"] = timeframe_mod
|
||||
sys.modules["alpaca.data.requests"] = requests_mod
|
||||
sys.modules["alpaca.data.historical"] = historical_mod
|
||||
sys.modules["alpaca.data.enums"] = enums_mod
|
||||
|
||||
|
||||
# Install mocks before importing from market_data.main
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue