From bb121a1f5b0be1dea2bffaa0120d157831b2c5ab Mon Sep 17 00:00:00 2001 From: Troy Sankey Date: Wed, 10 Jul 2024 15:20:35 -0700 Subject: [PATCH] fix: make deposit backfill migration defensive against bogus subsidy reference type ENT-9075 --- .../0022_backfill_initial_deposits.py | 5 +- .../apps/subsidy/tests/test_migrations.py | 56 ++++++++++--------- 2 files changed, 35 insertions(+), 26 deletions(-) diff --git a/enterprise_subsidy/apps/subsidy/migrations/0022_backfill_initial_deposits.py b/enterprise_subsidy/apps/subsidy/migrations/0022_backfill_initial_deposits.py index 598cbe3d..04dc48e8 100644 --- a/enterprise_subsidy/apps/subsidy/migrations/0022_backfill_initial_deposits.py +++ b/enterprise_subsidy/apps/subsidy/migrations/0022_backfill_initial_deposits.py @@ -53,7 +53,10 @@ def forwards_func(apps, schema_editor): sales_contract_reference_provider = None try: sales_contract_reference_id = tx.ledger.subsidy.reference_id - sales_contract_reference_provider = sales_contract_reference_providers[tx.ledger.subsidy.reference_type] + # If a pre-established provider is not found, that means it was not defined in + # SubsidyReferenceChoices.CHOICES. We don't really want to pollute the SalesContractReferenceProvider table + # with unofficial test records, so the compromise is to just use get() and fallback to NULL. + sales_contract_reference_provider = sales_contract_reference_providers.get(tx.ledger.subsidy.reference_type) except Ledger.subsidy.RelatedObjectDoesNotExist: logger.warning( "Found a ledger (%s) without a related subsidy, so the initial deposit will not have a sales contract.", diff --git a/enterprise_subsidy/apps/subsidy/tests/test_migrations.py b/enterprise_subsidy/apps/subsidy/tests/test_migrations.py index 591581b0..7f0e180e 100644 --- a/enterprise_subsidy/apps/subsidy/tests/test_migrations.py +++ b/enterprise_subsidy/apps/subsidy/tests/test_migrations.py @@ -11,14 +11,17 @@ @pytest.mark.django_db @pytest.mark.parametrize( - "initial_deposit_exists,subsidy_exists,subsidy_reference_id", + "initial_deposit_exists,subsidy_exists,subsidy_reference_id,subsidy_reference_type", [ - (False, False, None), - (False, True, None), - (False, True, "abc123"), - (True, False, None), - (True, True, None), - (True, True, "abc123"), + (False, False, None, "salesforce_opportunity_line_item"), + (False, True, None, "salesforce_opportunity_line_item"), + # This is the most common case that we're targetting in prod. + (False, True, "abc123", "salesforce_opportunity_line_item"), + # This specific case defends against a case in stage where there was a Subsidy with a bogus reference_type. + (False, True, "abc123", "bogus_made_up"), + (True, False, None, "salesforce_opportunity_line_item"), + (True, True, None, "salesforce_opportunity_line_item"), + (True, True, "abc123", "salesforce_opportunity_line_item"), ], ) def test_migration_0022_backfill_initial_deposits( @@ -26,6 +29,7 @@ def test_migration_0022_backfill_initial_deposits( initial_deposit_exists, subsidy_exists, subsidy_reference_id, + subsidy_reference_type, ): """ Test Backfilling initial deposits via data migration. @@ -49,6 +53,7 @@ def test_migration_0022_backfill_initial_deposits( ledger=ledger, starting_balance=100, reference_id=subsidy_reference_id, + reference_type=subsidy_reference_type, enterprise_customer_uuid=uuid.uuid4(), ) transaction = Transaction.objects.create( @@ -93,24 +98,25 @@ def test_migration_0022_backfill_initial_deposits( assert HistoricalDeposit.objects.all().count() == 1 # Finally check that all the deposit values are correct. - assert Deposit.objects.first().ledger.uuid == ledger.uuid - assert Deposit.objects.first().desired_deposit_quantity == 100 - assert Deposit.objects.first().transaction.uuid == transaction.uuid + deposit = Deposit.objects.first() + assert deposit.ledger.uuid == ledger.uuid + assert deposit.desired_deposit_quantity == 100 + assert deposit.transaction.uuid == transaction.uuid if subsidy_exists: - assert Deposit.objects.first().sales_contract_reference_id == subsidy_reference_id - assert Deposit.objects.first().sales_contract_reference_provider.slug == subsidy.reference_type + assert deposit.sales_contract_reference_id == subsidy_reference_id + if subsidy_reference_type == "salesforce_opportunity_line_item": + assert deposit.sales_contract_reference_provider.slug == subsidy.reference_type + else: + assert Deposit.objects.first().sales_contract_reference_provider is None else: - assert Deposit.objects.first().sales_contract_reference_id is None - assert Deposit.objects.first().sales_contract_reference_provider is None + assert deposit.sales_contract_reference_id is None + assert deposit.sales_contract_reference_provider is None - assert HistoricalDeposit.objects.first().ledger.uuid == ledger.uuid - assert HistoricalDeposit.objects.first().desired_deposit_quantity == 100 - assert HistoricalDeposit.objects.first().transaction.uuid == transaction.uuid - if subsidy_exists: - assert HistoricalDeposit.objects.first().sales_contract_reference_id == subsidy_reference_id - assert HistoricalDeposit.objects.first().sales_contract_reference_provider.slug == subsidy.reference_type - else: - assert HistoricalDeposit.objects.first().sales_contract_reference_id is None - assert HistoricalDeposit.objects.first().sales_contract_reference_provider is None - assert HistoricalDeposit.objects.first().history_type == "+" - assert HistoricalDeposit.objects.first().history_change_reason == "Data migration to backfill initial deposits" + historical_deposit = HistoricalDeposit.objects.first() + assert historical_deposit.ledger.uuid == ledger.uuid + assert historical_deposit.desired_deposit_quantity == 100 + assert historical_deposit.transaction.uuid == transaction.uuid + assert historical_deposit.sales_contract_reference_id == deposit.sales_contract_reference_id + assert historical_deposit.sales_contract_reference_provider == deposit.sales_contract_reference_provider + assert historical_deposit.history_type == "+" + assert historical_deposit.history_change_reason == "Data migration to backfill initial deposits"