USSD post-test bug fixes
This commit is contained in:
@@ -75,17 +75,21 @@ def test_transaction_actors(activated_account, transaction_result, valid_recipie
|
||||
def test_validate_transaction_account(activated_account, init_database, transactions_list):
|
||||
sample_transaction = transactions_list[0]
|
||||
recipient_transaction, sender_transaction = transaction_actors(sample_transaction)
|
||||
recipient_account = validate_transaction_account(init_database, recipient_transaction)
|
||||
sender_account = validate_transaction_account(init_database, sender_transaction)
|
||||
recipient_account = validate_transaction_account(
|
||||
recipient_transaction.get('blockchain_address'), recipient_transaction.get('role'), init_database)
|
||||
sender_account = validate_transaction_account(
|
||||
sender_transaction.get('blockchain_address'), sender_transaction.get('role'), init_database)
|
||||
assert isinstance(recipient_account, Account)
|
||||
assert isinstance(sender_account, Account)
|
||||
sample_transaction = transactions_list[1]
|
||||
recipient_transaction, sender_transaction = transaction_actors(sample_transaction)
|
||||
with pytest.raises(UnknownUssdRecipient) as error:
|
||||
validate_transaction_account(init_database, recipient_transaction)
|
||||
validate_transaction_account(
|
||||
recipient_transaction.get('blockchain_address'), recipient_transaction.get('role'), init_database)
|
||||
assert str(
|
||||
error.value) == f'Tx for recipient: {recipient_transaction.get("blockchain_address")} has no matching account in the system.'
|
||||
validate_transaction_account(init_database, sender_transaction)
|
||||
validate_transaction_account(
|
||||
sender_transaction.get('blockchain_address'), sender_transaction.get('role'), init_database)
|
||||
assert f'Tx from sender: {sender_transaction.get("blockchain_address")} has no matching account in system.'
|
||||
|
||||
|
||||
|
||||
@@ -30,8 +30,6 @@ def test_is_valid_recipient(activated_account,
|
||||
valid_recipient):
|
||||
state_machine = ('0112365478', generic_ussd_session, valid_recipient, init_database)
|
||||
assert is_valid_recipient(state_machine) is False
|
||||
state_machine = (pending_account.phone_number, generic_ussd_session, valid_recipient, init_database)
|
||||
assert is_valid_recipient(state_machine) is False
|
||||
state_machine = (valid_recipient.phone_number, generic_ussd_session, activated_account, init_database)
|
||||
assert is_valid_recipient(state_machine) is True
|
||||
|
||||
|
||||
@@ -24,7 +24,8 @@ def test_transaction(celery_session_worker,
|
||||
phone_number = notification_data.get('phone_number')
|
||||
preferred_language = notification_data.get('preferred_language')
|
||||
token_symbol = notification_data.get('token_symbol')
|
||||
transaction_account_metadata = notification_data.get('metadata_id')
|
||||
alt_metadata_id = notification_data.get('alt_metadata_id')
|
||||
metadata_id = notification_data.get('metadata_id')
|
||||
timestamp = datetime.datetime.now().strftime('%d-%m-%y, %H:%M %p')
|
||||
s_transaction = celery.signature(
|
||||
'cic_ussd.tasks.notifications.transaction', [notification_data]
|
||||
@@ -36,7 +37,8 @@ def test_transaction(celery_session_worker,
|
||||
preferred_language=preferred_language,
|
||||
amount=amount,
|
||||
token_symbol=token_symbol,
|
||||
tx_recipient_information=transaction_account_metadata,
|
||||
tx_recipient_information=alt_metadata_id,
|
||||
tx_sender_information=metadata_id,
|
||||
timestamp=timestamp,
|
||||
balance=balance)
|
||||
assert mock_notifier_api.get('message') == message
|
||||
@@ -52,7 +54,8 @@ def test_transaction(celery_session_worker,
|
||||
preferred_language=preferred_language,
|
||||
amount=amount,
|
||||
token_symbol=token_symbol,
|
||||
tx_sender_information=transaction_account_metadata,
|
||||
tx_recipient_information=metadata_id,
|
||||
tx_sender_information=alt_metadata_id,
|
||||
timestamp=timestamp,
|
||||
balance=balance)
|
||||
assert mock_notifier_api.get('message') == message
|
||||
|
||||
9
apps/cic-ussd/tests/fixtures/transaction.py
vendored
9
apps/cic-ussd/tests/fixtures/transaction.py
vendored
@@ -5,12 +5,18 @@ import random
|
||||
import pytest
|
||||
|
||||
# local import
|
||||
from cic_ussd.account.balance import get_cached_available_balance
|
||||
|
||||
# tests imports
|
||||
|
||||
|
||||
@pytest.fixture(scope='function')
|
||||
def notification_data(activated_account, cache_person_metadata, cache_preferences, preferences):
|
||||
def notification_data(activated_account,
|
||||
cache_person_metadata,
|
||||
cache_preferences,
|
||||
cache_balances,
|
||||
preferences,
|
||||
valid_recipient):
|
||||
return {
|
||||
'blockchain_address': activated_account.blockchain_address,
|
||||
'token_symbol': 'GFT',
|
||||
@@ -18,6 +24,7 @@ def notification_data(activated_account, cache_person_metadata, cache_preference
|
||||
'role': 'sender',
|
||||
'action_tag': 'Sent',
|
||||
'direction_tag': 'To',
|
||||
'alt_metadata_id': valid_recipient.standard_metadata_id(),
|
||||
'metadata_id': activated_account.standard_metadata_id(),
|
||||
'phone_number': activated_account.phone_number,
|
||||
'available_balance': 50.0,
|
||||
|
||||
Reference in New Issue
Block a user