summaryrefslogtreecommitdiff
path: root/packages/taler-wallet-cli/src/integrationtests/libeufin.ts
diff options
context:
space:
mode:
authorMS <ms@taler.net>2021-02-15 10:43:05 +0100
committerMS <ms@taler.net>2021-02-15 10:43:05 +0100
commit7a2ab04da8548d9b409df1ab183c785c7bde7e48 (patch)
tree509a735d420d0020b15c59f757d4a79b5d992045 /packages/taler-wallet-cli/src/integrationtests/libeufin.ts
parent118975fee3568f773c75b26753086ecdde182db4 (diff)
downloadwallet-core-7a2ab04da8548d9b409df1ab183c785c7bde7e48.tar.gz
wallet-core-7a2ab04da8548d9b409df1ab183c785c7bde7e48.tar.bz2
wallet-core-7a2ab04da8548d9b409df1ab183c785c7bde7e48.zip
TWG refund tests.
Arriving to the point where Libeufin services get launched and configured with multiple users. The configuration provides: bank accounts, bank connections and facades; all being created via the abstraction "bundling" layer of one Libeufin 'user'.
Diffstat (limited to 'packages/taler-wallet-cli/src/integrationtests/libeufin.ts')
-rw-r--r--packages/taler-wallet-cli/src/integrationtests/libeufin.ts126
1 files changed, 117 insertions, 9 deletions
diff --git a/packages/taler-wallet-cli/src/integrationtests/libeufin.ts b/packages/taler-wallet-cli/src/integrationtests/libeufin.ts
index c96125d7c..1bced0bec 100644
--- a/packages/taler-wallet-cli/src/integrationtests/libeufin.ts
+++ b/packages/taler-wallet-cli/src/integrationtests/libeufin.ts
@@ -21,9 +21,11 @@ import axios from "axios";
import { URL } from "@gnu-taler/taler-wallet-core";
import {
GlobalTestState,
+ DbInfo,
pingProc,
ProcessWrapper,
runCommand,
+ setupDb,
sh,
} from "./harness";
@@ -35,6 +37,12 @@ export interface LibeufinNexusServiceInterface {
baseUrl: string;
}
+export interface LibeufinServices {
+ libeufinSandbox: LibeufinSandboxServiceInterface;
+ libeufinNexus: LibeufinNexusServiceInterface;
+ commonDb: DbInfo;
+}
+
export interface LibeufinSandboxConfig {
httpPort: number;
databaseJdbcUri: string;
@@ -255,11 +263,13 @@ export interface SimulateIncomingTransactionRequest {
export class NexusUserBundle {
userReq: CreateNexusUserRequest;
connReq: CreateEbicsBankConnectionRequest;
- twg: CreateTalerWireGatewayFacadeRequest;
+ twgReq: CreateTalerWireGatewayFacadeRequest;
+ twgTransferPermission: PostNexusPermissionRequest;
+ twgHistoryPermission: PostNexusPermissionRequest;
localAccountName: string;
remoteAccountName: string;
- constructor(ebicsURL: string, salt: string) {
+ constructor(salt: string, ebicsURL: string) {
this.userReq = {
username: `username-${salt}`,
password: `password-${salt}`,
@@ -268,12 +278,12 @@ export class NexusUserBundle {
this.connReq = {
name: `connection-${salt}`,
ebicsURL: ebicsURL,
- hostID: `ebicshost-${salt}`,
- partnerID: `ebicspartner-${salt}`,
- userID: `ebicsuser-${salt}`,
+ hostID: `ebicshost,${salt}`,
+ partnerID: `ebicspartner,${salt}`,
+ userID: `ebicsuser,${salt}`,
};
- this.twg = {
+ this.twgReq = {
currency: "EUR",
name: `twg-${salt}`,
reserveTransferLevel: "report",
@@ -282,6 +292,26 @@ export class NexusUserBundle {
};
this.remoteAccountName = `remote-account-${salt}`;
this.localAccountName = `local-account-${salt}`;
+ this.twgTransferPermission = {
+ action: "grant",
+ permission: {
+ subjectType: `username-${salt}`,
+ subjectId: "twguser",
+ resourceType: "facade",
+ resourceId: `twg-${salt}`,
+ permissionName: "facade.talerWireGateway.transfer",
+ },
+ };
+ this.twgHistoryPermission = {
+ action: "grant",
+ permission: {
+ subjectType: `username-${salt}`,
+ subjectId: "twguser",
+ resourceType: "facade",
+ resourceId: `twg-${salt}`,
+ permissionName: "facade.talerWireGateway.history",
+ },
+ };
}
}
@@ -303,9 +333,9 @@ export class SandboxUserBundle {
label: `remote-account-${salt}`,
name: `Taler Exchange: ${salt}`,
subscriber: {
- hostID: `ebicshost-${salt}`,
- partnerID: `ebicspartner-${salt}`,
- userID: `ebicsuser-${salt}`,
+ hostID: `ebicshost,${salt}`,
+ partnerID: `ebicspartner,${salt}`,
+ userID: `ebicsuser,${salt}`,
},
};
}
@@ -873,3 +903,81 @@ export namespace LibeufinNexusApi {
);
}
}
+
+/**
+ * Launch Nexus and Sandbox.
+ */
+export async function launchLibeufinServices(
+ t: GlobalTestState,
+ nexusUserBundle: NexusUserBundle[],
+ sandboxUserBundle: SandboxUserBundle[],
+): Promise<LibeufinServices> {
+ const db = await setupDb(t);
+
+ const libeufinSandbox = await LibeufinSandboxService.create(t, {
+ httpPort: 5010,
+ databaseJdbcUri: `jdbc:sqlite:${t.testDir}/libeufin-sandbox.sqlite3`,
+ });
+
+ await libeufinSandbox.start();
+ await libeufinSandbox.pingUntilAvailable();
+
+ const libeufinNexus = await LibeufinNexusService.create(t, {
+ httpPort: 5011,
+ databaseJdbcUri: `jdbc:sqlite:${t.testDir}/libeufin-nexus.sqlite3`,
+ });
+
+ await libeufinNexus.start();
+ await libeufinNexus.pingUntilAvailable();
+ console.log("Libeufin services launched!");
+
+ for (let sb of sandboxUserBundle) {
+ await LibeufinSandboxApi.createEbicsHost(
+ libeufinSandbox,
+ sb.ebicsBankAccount.subscriber.hostID,
+ );
+ await LibeufinSandboxApi.createEbicsSubscriber(
+ libeufinSandbox,
+ sb.ebicsBankAccount.subscriber,
+ );
+ await LibeufinSandboxApi.createEbicsBankAccount(
+ libeufinSandbox,
+ sb.ebicsBankAccount,
+ );
+ }
+ console.log("Sandbox user(s) / account(s) / subscriber(s): created");
+
+ for (let nb of nexusUserBundle) {
+ await LibeufinNexusApi.createEbicsBankConnection(libeufinNexus, nb.connReq);
+ await LibeufinNexusApi.connectBankConnection(
+ libeufinNexus,
+ nb.connReq.name,
+ );
+ await LibeufinNexusApi.fetchAccounts(libeufinNexus, nb.connReq.name);
+ await LibeufinNexusApi.importConnectionAccount(
+ libeufinNexus,
+ nb.connReq.name,
+ nb.remoteAccountName,
+ nb.localAccountName,
+ );
+ await LibeufinNexusApi.createTwgFacade(libeufinNexus, nb.twgReq);
+ await LibeufinNexusApi.createUser(libeufinNexus, nb.userReq);
+ await LibeufinNexusApi.postPermission(
+ libeufinNexus,
+ nb.twgTransferPermission,
+ );
+ await LibeufinNexusApi.postPermission(
+ libeufinNexus,
+ nb.twgHistoryPermission,
+ );
+ }
+ console.log(
+ "Nexus user(s) / connection(s) / facade(s) / permission(s): created",
+ );
+
+ return {
+ commonDb: db,
+ libeufinNexus: libeufinNexus,
+ libeufinSandbox: libeufinSandbox,
+ };
+}