- Change file mode from 644 to 755 for all project files - Add chain_id parameter to get_balance RPC endpoint with default "ait-devnet" - Rename Miner.extra_meta_data to extra_metadata for consistency
192 lines
9.4 KiB
Python
Executable File
192 lines
9.4 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
"""
|
|
Test multi-chain functionality for blockchain transaction command
|
|
"""
|
|
|
|
import pytest
|
|
from unittest.mock import patch, MagicMock
|
|
from click.testing import CliRunner
|
|
from aitbc_cli.cli import cli
|
|
|
|
|
|
class TestBlockchainTransactionMultiChain:
|
|
"""Test blockchain transaction multi-chain functionality"""
|
|
|
|
def setup_method(self):
|
|
"""Setup test runner"""
|
|
self.runner = CliRunner()
|
|
|
|
def test_blockchain_transaction_help(self):
|
|
"""Test blockchain transaction help shows new options"""
|
|
result = self.runner.invoke(cli, ['blockchain', 'transaction', '--help'])
|
|
success = result.exit_code == 0
|
|
has_chain_option = '--chain-id' in result.output
|
|
has_all_chains_option = '--all-chains' in result.output
|
|
|
|
print(f" {'✅' if success else '❌'} blockchain transaction help: {'Working' if success else 'Failed'}")
|
|
print(f" {'✅' if has_chain_option else '❌'} --chain-id option: {'Available' if has_chain_option else 'Missing'}")
|
|
print(f" {'✅' if has_all_chains_option else '❌'} --all-chains option: {'Available' if has_all_chains_option else 'Missing'}")
|
|
|
|
return success and has_chain_option and has_all_chains_option
|
|
|
|
@patch('httpx.Client')
|
|
def test_blockchain_transaction_single_chain(self, mock_client):
|
|
"""Test blockchain transaction for single chain"""
|
|
mock_response = MagicMock()
|
|
mock_response.status_code = 200
|
|
mock_response.json.return_value = {"hash": "0xabc123", "from": "0xsender", "to": "0xreceiver"}
|
|
|
|
mock_client.return_value.__enter__.return_value.get.return_value = mock_response
|
|
|
|
result = self.runner.invoke(cli, ['blockchain', 'transaction', '0xabc123', '--chain-id', 'ait-devnet'])
|
|
success = result.exit_code == 0
|
|
has_chain_id = 'ait-devnet' in result.output
|
|
has_tx_data = 'tx_data' in result.output
|
|
has_query_type = 'single_chain' in result.output
|
|
|
|
print(f" {'✅' if success else '❌'} blockchain transaction single chain: {'Working' if success else 'Failed'}")
|
|
print(f" {'✅' if has_chain_id else '❌'} chain ID in output: {'Present' if has_chain_id else 'Missing'}")
|
|
print(f" {'✅' if has_tx_data else '❌'} transaction data: {'Present' if has_tx_data else 'Missing'}")
|
|
print(f" {'✅' if has_query_type else '❌'} query type: {'Present' if has_query_type else 'Missing'}")
|
|
|
|
return success and has_chain_id and has_tx_data and has_query_type
|
|
|
|
@patch('httpx.Client')
|
|
def test_blockchain_transaction_all_chains(self, mock_client):
|
|
"""Test blockchain transaction across all chains"""
|
|
mock_response = MagicMock()
|
|
mock_response.status_code = 200
|
|
mock_response.json.return_value = {"hash": "0xabc123", "from": "0xsender"}
|
|
|
|
mock_client.return_value.__enter__.return_value.get.return_value = mock_response
|
|
|
|
result = self.runner.invoke(cli, ['blockchain', 'transaction', '0xabc123', '--all-chains'])
|
|
success = result.exit_code == 0
|
|
has_multiple_chains = 'chains' in result.output
|
|
has_total_chains = 'total_chains' in result.output
|
|
has_successful_searches = 'successful_searches' in result.output
|
|
has_found_in_chains = 'found_in_chains' in result.output
|
|
|
|
print(f" {'✅' if success else '❌'} blockchain transaction all chains: {'Working' if success else 'Failed'}")
|
|
print(f" {'✅' if has_multiple_chains else '❌'} multiple chains data: {'Present' if has_multiple_chains else 'Missing'}")
|
|
print(f" {'✅' if has_total_chains else '❌'} total chains count: {'Present' if has_total_chains else 'Missing'}")
|
|
print(f" {'✅' if has_successful_searches else '❌'} successful searches: {'Present' if has_successful_searches else 'Missing'}")
|
|
print(f" {'✅' if has_found_in_chains else '❌'} found in chains: {'Present' if has_found_in_chains else 'Missing'}")
|
|
|
|
return success and has_multiple_chains and has_total_chains and has_successful_searches and has_found_in_chains
|
|
|
|
@patch('httpx.Client')
|
|
def test_blockchain_transaction_default_chain(self, mock_client):
|
|
"""Test blockchain transaction uses default chain when none specified"""
|
|
mock_response = MagicMock()
|
|
mock_response.status_code = 200
|
|
mock_response.json.return_value = {"hash": "0xabc123", "from": "0xsender"}
|
|
|
|
mock_client.return_value.__enter__.return_value.get.return_value = mock_response
|
|
|
|
result = self.runner.invoke(cli, ['blockchain', 'transaction', '0xabc123'])
|
|
success = result.exit_code == 0
|
|
has_default_chain = 'ait-devnet' in result.output
|
|
|
|
print(f" {'✅' if success else '❌'} blockchain transaction default chain: {'Working' if success else 'Failed'}")
|
|
print(f" {'✅' if has_default_chain else '❌'} default chain (ait-devnet): {'Used' if has_default_chain else 'Not used'}")
|
|
|
|
return success and has_default_chain
|
|
|
|
@patch('httpx.Client')
|
|
def test_blockchain_transaction_not_found(self, mock_client):
|
|
"""Test blockchain transaction not found in specific chain"""
|
|
mock_response = MagicMock()
|
|
mock_response.status_code = 404
|
|
mock_response.text = "Transaction not found"
|
|
|
|
mock_client.return_value.__enter__.return_value.get.return_value = mock_response
|
|
|
|
result = self.runner.invoke(cli, ['blockchain', 'transaction', '0xinvalid', '--chain-id', 'ait-devnet'])
|
|
success = result.exit_code != 0 # Should fail
|
|
has_error = 'Transaction not found' in result.output
|
|
has_chain_specified = 'ait-devnet' in result.output
|
|
|
|
print(f" {'✅' if success else '❌'} blockchain transaction not found: {'Working' if success else 'Failed'}")
|
|
print(f" {'✅' if has_error else '❌'} error message: {'Present' if has_error else 'Missing'}")
|
|
print(f" {'✅' if has_chain_specified else '❌'} chain specified in error: {'Present' if has_chain_specified else 'Missing'}")
|
|
|
|
return success and has_error and has_chain_specified
|
|
|
|
@patch('httpx.Client')
|
|
def test_blockchain_transaction_partial_success_all_chains(self, mock_client):
|
|
"""Test blockchain transaction found in some chains but not others"""
|
|
def side_effect(*args, **kwargs):
|
|
mock_resp = MagicMock()
|
|
if 'ait-devnet' in str(args[0]):
|
|
mock_resp.status_code = 200
|
|
mock_resp.json.return_value = {"hash": "0xabc123", "from": "0xsender"}
|
|
else:
|
|
mock_resp.status_code = 404
|
|
mock_resp.text = "Transaction not found"
|
|
return mock_resp
|
|
|
|
mock_client.return_value.__enter__.return_value.get.side_effect = side_effect
|
|
|
|
result = self.runner.invoke(cli, ['blockchain', 'transaction', '0xabc123', '--all-chains'])
|
|
success = result.exit_code == 0
|
|
has_partial_success = 'successful_searches' in result.output
|
|
has_found_chains = 'found_in_chains' in result.output
|
|
|
|
print(f" {'✅' if success else '❌'} blockchain transaction partial success: {'Working' if success else 'Failed'}")
|
|
print(f" {'✅' if has_partial_success else '❌'} partial success indicator: {'Present' if has_partial_success else 'Missing'}")
|
|
print(f" {'✅' if has_found_chains else '❌'} found chains list: {'Present' if has_found_chains else 'Missing'}")
|
|
|
|
return success and has_partial_success and has_found_chains
|
|
|
|
|
|
def run_blockchain_transaction_multichain_tests():
|
|
"""Run all blockchain transaction multi-chain tests"""
|
|
print("🔗 Testing Blockchain Transaction Multi-Chain Functionality")
|
|
print("=" * 60)
|
|
|
|
test_instance = TestBlockchainTransactionMultiChain()
|
|
|
|
tests = [
|
|
("Help Options", test_instance.test_blockchain_transaction_help),
|
|
("Single Chain Query", test_instance.test_blockchain_transaction_single_chain),
|
|
("All Chains Query", test_instance.test_blockchain_transaction_all_chains),
|
|
("Default Chain", test_instance.test_blockchain_transaction_default_chain),
|
|
("Transaction Not Found", test_instance.test_blockchain_transaction_not_found),
|
|
("Partial Success", test_instance.test_blockchain_transaction_partial_success_all_chains),
|
|
]
|
|
|
|
results = []
|
|
for test_name, test_func in tests:
|
|
print(f"\n📋 {test_name}:")
|
|
try:
|
|
result = test_func()
|
|
results.append(result)
|
|
except Exception as e:
|
|
print(f" ❌ Test failed with exception: {e}")
|
|
results.append(False)
|
|
|
|
# Summary
|
|
passed = sum(results)
|
|
total = len(results)
|
|
success_rate = (passed / total) * 100 if total > 0 else 0
|
|
|
|
print("\n" + "=" * 60)
|
|
print("📊 BLOCKCHAIN TRANSACTION MULTI-CHAIN TEST SUMMARY")
|
|
print("=" * 60)
|
|
print(f"Tests Passed: {passed}/{total}")
|
|
print(f"Success Rate: {success_rate:.1f}%")
|
|
|
|
if success_rate >= 80:
|
|
print("✅ Multi-chain functionality is working well!")
|
|
elif success_rate >= 60:
|
|
print("⚠️ Multi-chain functionality has some issues")
|
|
else:
|
|
print("❌ Multi-chain functionality needs significant work")
|
|
|
|
return success_rate
|
|
|
|
|
|
if __name__ == "__main__":
|
|
run_blockchain_transaction_multichain_tests()
|