From 24ffc3c41aa3919cb2f5044658969aa7254b69a4 Mon Sep 17 00:00:00 2001 From: Kevin Heifner Date: Wed, 18 Dec 2024 13:21:10 -0600 Subject: [PATCH] GH-1078 Since distributed-transactions-test.py running with --activate-if has an irreversible node, wait for finalization before validation. --- tests/TestHarness/Cluster.py | 17 +++++++++++------ tests/distributed-transactions-test.py | 3 ++- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/tests/TestHarness/Cluster.py b/tests/TestHarness/Cluster.py index 139821f5b1..65fb829cfc 100644 --- a/tests/TestHarness/Cluster.py +++ b/tests/TestHarness/Cluster.py @@ -756,7 +756,7 @@ def launchUnstarted(self, numToLaunch=1): # Spread funds across accounts with transactions spread through cluster nodes. # Validate transactions are synchronized on root node - def spreadFunds(self, source, accounts, amount=1): + def spreadFunds(self, source, accounts, amount=1, waitForFinalization=False): assert(source) assert(isinstance(source, Account)) assert(accounts) @@ -819,9 +819,14 @@ def spreadFunds(self, source, accounts, amount=1): # As an extra step wait for last transaction on the root node node=self.nodes[0] if Utils.Debug: Utils.Print("Wait for transaction id %s on node port %d" % (transId, node.port)) - if node.waitForTransactionInBlock(transId) is False: - Utils.Print("ERROR: Failed to validate transaction %s got rolled into a block on server port %d." % (transId, node.port)) - return False + if waitForFinalization: + if node.waitForTransFinalization(transId) is False: + Utils.Print("ERROR: Failed to validate transaction %s got rolled into a final block on server port %d." % (transId, node.port)) + return False + else: + if node.waitForTransactionInBlock(transId) is False: + Utils.Print("ERROR: Failed to validate transaction %s got rolled into a block on server port %d." % (transId, node.port)) + return False return True @@ -850,7 +855,7 @@ def validateSpreadFunds(self, initialBalances, transferAmount, source, accounts) return True - def spreadFundsAndValidate(self, transferAmount=1): + def spreadFundsAndValidate(self, transferAmount=1, waitForFinalization=False): """Sprays 'transferAmount' funds across configured accounts and validates action. The spray is done in a trickle down fashion with account 1 receiving transferAmount*n SYS and forwarding x-transferAmount funds. Transfer actions are spread round-robin across the cluster to vaidate system cohesiveness.""" @@ -859,7 +864,7 @@ def spreadFundsAndValidate(self, transferAmount=1): assert(initialBalances) assert(isinstance(initialBalances, dict)) - if False == self.spreadFunds(self.defproduceraAccount, self.accounts, transferAmount): + if False == self.spreadFunds(self.defproduceraAccount, self.accounts, transferAmount, waitForFinalization=waitForFinalization): Utils.Print("ERROR: Failed to spread funds across nodes.") return False diff --git a/tests/distributed-transactions-test.py b/tests/distributed-transactions-test.py index b383f51035..91b28b9272 100755 --- a/tests/distributed-transactions-test.py +++ b/tests/distributed-transactions-test.py @@ -100,7 +100,8 @@ errorExit("Accounts creation failed.") Print("Spread funds and validate") - if not cluster.spreadFundsAndValidate(10): + # if activateIF then irreversible node needs funds to be irreversible before validation + if not cluster.spreadFundsAndValidate(10, waitForFinalization=activateIF): errorExit("Failed to spread and validate funds.") print("Funds spread validated")