diff options
author | Florian Dold <florian@dold.me> | 2023-06-20 16:19:53 +0200 |
---|---|---|
committer | Florian Dold <florian@dold.me> | 2023-06-20 16:19:57 +0200 |
commit | 1f60ac76f920da9c710c4a6116741f4412350f4a (patch) | |
tree | c461f6efb0e2ccb841fe0dec3cf5993edafd946e | |
parent | 773712419e7663f62a3c529b7743dd6964f0879a (diff) |
harness: fix test-peer-repair
-rw-r--r-- | packages/taler-harness/src/integrationtests/test-peer-repair.ts | 45 |
1 files changed, 35 insertions, 10 deletions
diff --git a/packages/taler-harness/src/integrationtests/test-peer-repair.ts b/packages/taler-harness/src/integrationtests/test-peer-repair.ts index cfa7ec877..b09bff2dc 100644 --- a/packages/taler-harness/src/integrationtests/test-peer-repair.ts +++ b/packages/taler-harness/src/integrationtests/test-peer-repair.ts @@ -61,7 +61,8 @@ export async function runPeerRepairTest(t: GlobalTestState) { const wallet2 = w2.walletClient; const withdrawalDoneCond = wallet1.waitForNotificationCond( - (x) => x.type === NotificationType.TransactionStateTransition && + (x) => + x.type === NotificationType.TransactionStateTransition && x.newTxState.major === TransactionMajorState.Done && x.transactionId.startsWith("txn:withdrawal:"), ); @@ -102,7 +103,7 @@ export async function runPeerRepairTest(t: GlobalTestState) { x.type === NotificationType.TransactionStateTransition && x.transactionId === resp1.transactionId && x.newTxState.major === TransactionMajorState.Pending && - x.newTxState.minor === TransactionMinorState.Ready + x.newTxState.minor === TransactionMinorState.Ready, ); await peerPushDebitReady1Cond; @@ -128,12 +129,9 @@ export async function runPeerRepairTest(t: GlobalTestState) { x.newTxState.major === TransactionMajorState.Done, ); - await wallet2.client.call( - WalletApiOperation.ConfirmPeerPushCredit, - { - peerPushPaymentIncomingId: resp2.peerPushPaymentIncomingId, - }, - ); + await wallet2.client.call(WalletApiOperation.ConfirmPeerPushCredit, { + peerPushPaymentIncomingId: resp2.peerPushPaymentIncomingId, + }); await peerPushCreditDone1Cond; await peerPushDebitDone1Cond; @@ -154,6 +152,8 @@ export async function runPeerRepairTest(t: GlobalTestState) { }); wallet1 = w1.walletClient; + console.log("attempting peer-push-debit, should fail."); + const initResp2 = await wallet1.client.call( WalletApiOperation.InitiatePeerPushDebit, { @@ -166,12 +166,37 @@ export async function runPeerRepairTest(t: GlobalTestState) { }, ); + const peerPushDebitFailingCond = wallet1.waitForNotificationCond( + (x) => + x.type === NotificationType.TransactionStateTransition && + x.transactionId === initResp2.transactionId && + x.newTxState.major === TransactionMajorState.Pending && + x.errorInfo != null, + ); + + console.log(`waiting for error on ${initResp2.transactionId}`); + + await peerPushDebitFailingCond; + + console.log("reached error"); + + // Now withdraw so we have enough coins to re-select + + const withdraw2Res = await withdrawViaBankV2(t, { + walletClient: wallet1, + bank, + exchange, + amount: "TESTKUDOS:5", + }); + + await withdraw2Res.withdrawalFinishedCond; + const peerPushDebitReady2Cond = wallet1.waitForNotificationCond( (x) => x.type === NotificationType.TransactionStateTransition && - x.transactionId === resp1.transactionId && + x.transactionId === initResp2.transactionId && x.newTxState.major === TransactionMajorState.Pending && - x.newTxState.minor === TransactionMinorState.Ready + x.newTxState.minor === TransactionMinorState.Ready, ); await peerPushDebitReady2Cond; |