From 41b65e90b9eb1a0a4a999bce75df29a0ea3aedcc Mon Sep 17 00:00:00 2001 From: MS Date: Wed, 12 May 2021 09:58:17 +0200 Subject: Libeufin API testing. Testing CRUD operations of the 'bankaccount' resource. --- .../src/integrationtests/libeufin.ts | 90 +++++++++++++++++++++- 1 file changed, 86 insertions(+), 4 deletions(-) (limited to 'packages/taler-wallet-cli/src/integrationtests/libeufin.ts') diff --git a/packages/taler-wallet-cli/src/integrationtests/libeufin.ts b/packages/taler-wallet-cli/src/integrationtests/libeufin.ts index 638926a43..eb9d63f12 100644 --- a/packages/taler-wallet-cli/src/integrationtests/libeufin.ts +++ b/packages/taler-wallet-cli/src/integrationtests/libeufin.ts @@ -54,6 +54,52 @@ export interface LibeufinNexusConfig { databaseJdbcUri: string; } +interface LibeufinNexusMoneyMovement { + amount: string; + creditDebitIndicator: string; + details: { + debtor: { + name: string; + }; + debtorAccount: { + iban: string; + }; + debtorAgent: { + bic: string; + }; + creditor: { + name: string; + }; + creditorAccount: { + iban: string; + }; + creditorAgent: { + bic: string; + }; + endToEndId: string; + unstructuredRemittanceInformation: string; + } +} + +interface LibeufinNexusBatches { + batchTransactions: Array; +} + +interface LibeufinNexusTransaction { + amount: string; + creditDebitIndicator: string; + status: string; + bankTransactionCode: string; + valueDate: string; + bookingDate: string; + accountServicerRef: string; + batches: Array; +} + +interface LibeufinNexusTransactions { + transactions: Array; +} + export interface LibeufinCliDetails { nexusUrl: string; sandboxUrl: string; @@ -667,6 +713,15 @@ export namespace LibeufinSandboxApi { await axios.post(url.href, req); } + export async function bookPayment2( + libeufinSandboxService: LibeufinSandboxService, + req: LibeufinSandboxAddIncomingRequest, + ) { + const baseUrl = libeufinSandboxService.baseUrl; + let url = new URL("admin/payments", baseUrl); + await axios.post(url.href, req); + } + export async function bookPayment( libeufinSandboxService: LibeufinSandboxService, creditorBundle: SandboxUserBundle, @@ -688,9 +743,7 @@ export namespace LibeufinSandboxApi { uid: getRandomString(), direction: "CRDT", }; - const baseUrl = libeufinSandboxService.baseUrl; - let url = new URL("admin/payments", baseUrl); - await axios.post(url.href, req); + await bookPayment2(libeufinSandboxService, req); } export async function simulateIncomingTransaction( @@ -783,6 +836,7 @@ export interface PostNexusPermissionRequest { } export namespace LibeufinNexusApi { + export async function createEbicsBankConnection( libeufinNexusService: LibeufinNexusServiceInterface, req: CreateEbicsBankConnectionRequest, @@ -943,7 +997,7 @@ export namespace LibeufinNexusApi { accountName: string, username: string = "admin", password: string = "test", - ): Promise { + ): Promise { const baseUrl = libeufinNexusService.baseUrl; let url = new URL( `/bank-accounts/${accountName}/transactions`, @@ -958,6 +1012,7 @@ export namespace LibeufinNexusApi { }, }, ); + return response; } export async function fetchAllTransactions( @@ -1173,3 +1228,30 @@ export async function launchLibeufinServices( libeufinSandbox: libeufinSandbox, }; } + +/** + * Helper function that searches a payment among + * a list, as returned by Nexus. The key is just + * the payment subject. + */ +export function findNexusPayment( + key: string, + payments: LibeufinNexusTransactions, +): LibeufinNexusMoneyMovement | void { + + let transactions = payments["transactions"]; + for (let i = 0; i < transactions.length; i++) { + + let batches = transactions[i]["batches"]; + for (let y = 0; y < batches.length; y++) { + + let movements = batches[y]["batchTransactions"]; + for (let z = 0; z < movements.length; z++) { + + let movement = movements[z]; + if (movement["details"]["unstructuredRemittanceInformation"] == key) + return movement; + } + } + } +} -- cgit v1.2.3