Files
aitbc/apps/blockchain-event-bridge/tests/test_contract_subscriber.py
aitbc e60cc3226c
Some checks failed
API Endpoint Tests / test-api-endpoints (push) Successful in 9s
Blockchain Synchronization Verification / sync-verification (push) Failing after 1s
CLI Tests / test-cli (push) Failing after 3s
Documentation Validation / validate-docs (push) Successful in 6s
Documentation Validation / validate-policies-strict (push) Successful in 2s
Integration Tests / test-service-integration (push) Successful in 40s
Multi-Node Blockchain Health Monitoring / health-check (push) Successful in 1s
P2P Network Verification / p2p-verification (push) Successful in 2s
Production Tests / Production Integration Tests (push) Successful in 21s
Python Tests / test-python (push) Successful in 13s
Security Scanning / security-scan (push) Failing after 46s
Smart Contract Tests / test-solidity (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Successful in 17s
Smart Contract Tests / lint-solidity (push) Successful in 10s
Add sys import to test files and remove obsolete integration tests
- Add sys import to 29 test files across agent-coordinator, blockchain-event-bridge, blockchain-node, and coordinator-api
- Remove apps/blockchain-event-bridge/tests/test_integration.py (obsolete bridge integration tests)
- Remove apps/coordinator-api/tests/test_integration.py (obsolete API integration tests)
- Implement GPU registration in marketplace_gpu.py with GPURegistry model persistence
2026-04-23 16:43:17 +02:00

105 lines
3.0 KiB
Python

"""Tests for contract event subscriber."""
import pytest
from unittest.mock import Mock, AsyncMock, patch
import sys
from blockchain_event_bridge.event_subscribers.contracts import ContractEventSubscriber
@pytest.mark.asyncio
async def test_contract_subscriber_initialization():
"""Test contract subscriber initialization."""
from blockchain_event_bridge.config import Settings
settings = Settings()
subscriber = ContractEventSubscriber(settings)
assert subscriber.settings == settings
assert subscriber._running is False
assert subscriber.contract_addresses is not None
@pytest.mark.asyncio
async def test_contract_subscriber_set_bridge():
"""Test setting bridge on contract subscriber."""
from blockchain_event_bridge.config import Settings
from blockchain_event_bridge.bridge import BlockchainEventBridge
settings = Settings()
subscriber = ContractEventSubscriber(settings)
bridge = Mock(spec=BlockchainEventBridge)
subscriber.set_bridge(bridge)
assert subscriber._bridge == bridge
@pytest.mark.asyncio
async def test_contract_subscriber_disabled():
"""Test contract subscriber when disabled."""
from blockchain_event_bridge.config import Settings
settings = Settings(subscribe_contracts=False)
subscriber = ContractEventSubscriber(settings)
await subscriber.run()
assert subscriber._running is False
@pytest.mark.asyncio
async def test_contract_subscriber_stop():
"""Test stopping contract subscriber."""
from blockchain_event_bridge.config import Settings
settings = Settings(subscribe_contracts=False)
subscriber = ContractEventSubscriber(settings)
await subscriber.stop()
assert subscriber._running is False
@pytest.mark.asyncio
async def test_process_staking_event():
"""Test processing staking event."""
from blockchain_event_bridge.config import Settings
from blockchain_event_bridge.bridge import BlockchainEventBridge
settings = Settings()
subscriber = ContractEventSubscriber(settings)
bridge = Mock(spec=BlockchainEventBridge)
bridge.handle_staking_event = AsyncMock()
subscriber.set_bridge(bridge)
event_log = {
"topics": ["StakeCreated"],
"data": "{}",
"address": "0x123"
}
await subscriber._handle_staking_event(event_log)
bridge.handle_staking_event.assert_called_once_with(event_log)
@pytest.mark.asyncio
async def test_process_performance_event():
"""Test processing performance event."""
from blockchain_event_bridge.config import Settings
from blockchain_event_bridge.bridge import BlockchainEventBridge
settings = Settings()
subscriber = ContractEventSubscriber(settings)
bridge = Mock(spec=BlockchainEventBridge)
bridge.handle_performance_event = AsyncMock()
subscriber.set_bridge(bridge)
event_log = {
"topics": ["PerformanceVerified"],
"data": "{}",
"address": "0x123"
}
await subscriber._handle_performance_event(event_log)
bridge.handle_performance_event.assert_called_once_with(event_log)