aboutsummaryrefslogtreecommitdiff
path: root/packages
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
parent118975fee3568f773c75b26753086ecdde182db4 (diff)
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')
-rw-r--r--packages/taler-wallet-cli/src/integrationtests/libeufin.ts126
-rw-r--r--packages/taler-wallet-cli/src/integrationtests/test-libeufin-refund.ts49
-rw-r--r--packages/taler-wallet-cli/src/integrationtests/testrunner.ts2
3 files changed, 168 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,
+ };
+}
diff --git a/packages/taler-wallet-cli/src/integrationtests/test-libeufin-refund.ts b/packages/taler-wallet-cli/src/integrationtests/test-libeufin-refund.ts
new file mode 100644
index 000000000..2d5103dce
--- /dev/null
+++ b/packages/taler-wallet-cli/src/integrationtests/test-libeufin-refund.ts
@@ -0,0 +1,49 @@
+/*
+ This file is part of GNU Taler
+ (C) 2020 Taler Systems S.A.
+
+ GNU Taler is free software; you can redistribute it and/or modify it under the
+ terms of the GNU General Public License as published by the Free Software
+ Foundation; either version 3, or (at your option) any later version.
+
+ GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY
+ WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+ A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License along with
+ GNU Taler; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
+ */
+
+/**
+ * Imports.
+ */
+import { CoreApiResponse } from "@gnu-taler/taler-wallet-core";
+import { CoinConfig, defaultCoinConfig } from "./denomStructures";
+import { GlobalTestState } from "./harness";
+import {
+ SandboxUserBundle,
+ NexusUserBundle,
+ launchLibeufinServices,
+} from "./libeufin";
+
+/**
+ * Run basic test with LibEuFin.
+ */
+export async function runLibeufinRefundTest(t: GlobalTestState) {
+ const user01nexus = new NexusUserBundle(
+ "01",
+ "http://localhost:5010/ebicsweb",
+ );
+ const user01sandbox = new SandboxUserBundle("01");
+ const user02nexus = new NexusUserBundle(
+ "02",
+ "http://localhost:5010/ebicsweb",
+ );
+ const user02sandbox = new SandboxUserBundle("02");
+
+ await launchLibeufinServices(
+ t,
+ [user01nexus, user02nexus],
+ [user01sandbox, user02sandbox],
+ );
+}
diff --git a/packages/taler-wallet-cli/src/integrationtests/testrunner.ts b/packages/taler-wallet-cli/src/integrationtests/testrunner.ts
index e220e45e4..a11b45878 100644
--- a/packages/taler-wallet-cli/src/integrationtests/testrunner.ts
+++ b/packages/taler-wallet-cli/src/integrationtests/testrunner.ts
@@ -55,6 +55,7 @@ import { runWithdrawalBankIntegratedTest } from "./test-withdrawal-bank-integrat
import M from "minimatch";
import { runMerchantExchangeConfusionTest } from "./test-merchant-exchange-confusion";
import { runLibeufinBasicTest } from "./test-libeufin-basic";
+import { runLibeufinRefundTest } from "./test-libeufin-refund";
import { runLibeufinTutorialTest } from "./test-libeufin-tutorial";
import { runDepositTest } from "./test-deposit";
import CancellationToken from "cancellationtoken";
@@ -79,6 +80,7 @@ const allTests: TestMainFunction[] = [
runFeeRegressionTest,
runLibeufinBasicTest,
runLibeufinTutorialTest,
+ runLibeufinRefundTest,
runMerchantExchangeConfusionTest,
runMerchantLongpollingTest,
runMerchantRefundApiTest,