Extend test tooling to create Anastasis facades.
This commit is contained in:
parent
daf9dc507e
commit
1f255b7f4e
@ -350,6 +350,7 @@ export interface SimulateIncomingTransactionRequest {
|
|||||||
export class NexusUserBundle {
|
export class NexusUserBundle {
|
||||||
userReq: CreateNexusUserRequest;
|
userReq: CreateNexusUserRequest;
|
||||||
connReq: CreateEbicsBankConnectionRequest;
|
connReq: CreateEbicsBankConnectionRequest;
|
||||||
|
anastasisReq: CreateAnastasisFacadeRequest;
|
||||||
twgReq: CreateTalerWireGatewayFacadeRequest;
|
twgReq: CreateTalerWireGatewayFacadeRequest;
|
||||||
twgTransferPermission: PostNexusPermissionRequest;
|
twgTransferPermission: PostNexusPermissionRequest;
|
||||||
twgHistoryPermission: PostNexusPermissionRequest;
|
twgHistoryPermission: PostNexusPermissionRequest;
|
||||||
@ -378,6 +379,13 @@ export class NexusUserBundle {
|
|||||||
accountName: `local-account-${salt}`,
|
accountName: `local-account-${salt}`,
|
||||||
connectionName: `connection-${salt}`,
|
connectionName: `connection-${salt}`,
|
||||||
};
|
};
|
||||||
|
this.anastasisReq = {
|
||||||
|
currency: "EUR",
|
||||||
|
name: `anastasis-${salt}`,
|
||||||
|
reserveTransferLevel: "report",
|
||||||
|
accountName: `local-account-${salt}`,
|
||||||
|
connectionName: `connection-${salt}`,
|
||||||
|
};
|
||||||
this.remoteAccountName = `remote-account-${salt}`;
|
this.remoteAccountName = `remote-account-${salt}`;
|
||||||
this.localAccountName = `local-account-${salt}`;
|
this.localAccountName = `local-account-${salt}`;
|
||||||
this.twgTransferPermission = {
|
this.twgTransferPermission = {
|
||||||
@ -1420,6 +1428,7 @@ export async function launchLibeufinServices(
|
|||||||
t: GlobalTestState,
|
t: GlobalTestState,
|
||||||
nexusUserBundle: NexusUserBundle[],
|
nexusUserBundle: NexusUserBundle[],
|
||||||
sandboxUserBundle: SandboxUserBundle[],
|
sandboxUserBundle: SandboxUserBundle[],
|
||||||
|
withFacades: string[] = [], // takes only "twg" and/or "anastasis"
|
||||||
): Promise<LibeufinServices> {
|
): Promise<LibeufinServices> {
|
||||||
const db = await setupDb(t);
|
const db = await setupDb(t);
|
||||||
|
|
||||||
@ -1469,16 +1478,24 @@ export async function launchLibeufinServices(
|
|||||||
nb.remoteAccountName,
|
nb.remoteAccountName,
|
||||||
nb.localAccountName,
|
nb.localAccountName,
|
||||||
);
|
);
|
||||||
await LibeufinNexusApi.createTwgFacade(libeufinNexus, nb.twgReq);
|
|
||||||
await LibeufinNexusApi.createUser(libeufinNexus, nb.userReq);
|
await LibeufinNexusApi.createUser(libeufinNexus, nb.userReq);
|
||||||
await LibeufinNexusApi.postPermission(
|
for (let facade of withFacades) {
|
||||||
libeufinNexus,
|
switch (facade) {
|
||||||
nb.twgTransferPermission,
|
case "twg":
|
||||||
);
|
await LibeufinNexusApi.createTwgFacade(libeufinNexus, nb.twgReq);
|
||||||
await LibeufinNexusApi.postPermission(
|
await LibeufinNexusApi.postPermission(
|
||||||
libeufinNexus,
|
libeufinNexus,
|
||||||
nb.twgHistoryPermission,
|
nb.twgTransferPermission,
|
||||||
);
|
);
|
||||||
|
await LibeufinNexusApi.postPermission(
|
||||||
|
libeufinNexus,
|
||||||
|
nb.twgHistoryPermission,
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
case "anastasis":
|
||||||
|
await LibeufinNexusApi.createAnastasisFacade(libeufinNexus, nb.anastasisReq);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
console.log(
|
console.log(
|
||||||
"Nexus user(s) / connection(s) / facade(s) / permission(s): created",
|
"Nexus user(s) / connection(s) / facade(s) / permission(s): created",
|
||||||
|
@ -45,6 +45,7 @@ export async function runLibeufinApiFacadeBadRequestTest(t: GlobalTestState) {
|
|||||||
t,
|
t,
|
||||||
[user01nexus],
|
[user01nexus],
|
||||||
[user01sandbox],
|
[user01sandbox],
|
||||||
|
["twg"],
|
||||||
);
|
);
|
||||||
console.log("malformed facade");
|
console.log("malformed facade");
|
||||||
const baseUrl = libeufinServices.libeufinNexus.baseUrl;
|
const baseUrl = libeufinServices.libeufinNexus.baseUrl;
|
||||||
|
@ -45,6 +45,7 @@ export async function runLibeufinApiFacadeTest(t: GlobalTestState) {
|
|||||||
t,
|
t,
|
||||||
[user01nexus],
|
[user01nexus],
|
||||||
[user01sandbox],
|
[user01sandbox],
|
||||||
|
["twg"],
|
||||||
);
|
);
|
||||||
let resp = await LibeufinNexusApi.getAllFacades(
|
let resp = await LibeufinNexusApi.getAllFacades(
|
||||||
libeufinServices.libeufinNexus,
|
libeufinServices.libeufinNexus,
|
||||||
|
@ -0,0 +1,75 @@
|
|||||||
|
/*
|
||||||
|
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 { GlobalTestState } from "./harness";
|
||||||
|
import {
|
||||||
|
SandboxUserBundle,
|
||||||
|
NexusUserBundle,
|
||||||
|
launchLibeufinServices,
|
||||||
|
LibeufinNexusApi,
|
||||||
|
} from "./libeufin";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run basic test with LibEuFin.
|
||||||
|
*/
|
||||||
|
export async function runLibeufinApiFacadeTest(t: GlobalTestState) {
|
||||||
|
/**
|
||||||
|
* User saltetd "01"
|
||||||
|
*/
|
||||||
|
const user01nexus = new NexusUserBundle(
|
||||||
|
"01",
|
||||||
|
"http://localhost:5010/ebicsweb",
|
||||||
|
);
|
||||||
|
const user01sandbox = new SandboxUserBundle("01");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launch Sandbox and Nexus.
|
||||||
|
*/
|
||||||
|
const libeufinServices = await launchLibeufinServices(
|
||||||
|
t,
|
||||||
|
[user01nexus],
|
||||||
|
[user01sandbox],
|
||||||
|
["anastasis"],
|
||||||
|
);
|
||||||
|
let resp = await LibeufinNexusApi.getAllFacades(
|
||||||
|
libeufinServices.libeufinNexus,
|
||||||
|
);
|
||||||
|
// check that original facade shows up.
|
||||||
|
t.assertTrue(resp.data["facades"][0]["name"] == user01nexus.twgReq["name"]);
|
||||||
|
|
||||||
|
const anastasisBaseUrl: string = resp.data["facades"][0]["twgBaseUrl"];
|
||||||
|
t.assertTrue(typeof anastasisBaseUrl === "string");
|
||||||
|
t.assertTrue(anastasisBaseUrl.startsWith("http://"));
|
||||||
|
t.assertTrue(anastasisBaseUrl.endsWith("/"));
|
||||||
|
|
||||||
|
//***************************************//
|
||||||
|
// Here payments need to be generated //
|
||||||
|
// and checked via the Anastasis facade. //
|
||||||
|
//***************************************//
|
||||||
|
|
||||||
|
// delete it.
|
||||||
|
resp = await LibeufinNexusApi.deleteFacade(
|
||||||
|
libeufinServices.libeufinNexus,
|
||||||
|
user01nexus.anastasisReq["name"],
|
||||||
|
);
|
||||||
|
// check that no facades show up.
|
||||||
|
t.assertTrue(!resp.data.hasOwnProperty("facades"));
|
||||||
|
}
|
||||||
|
|
||||||
|
runLibeufinApiFacadeTest.suites = ["libeufin"];
|
@ -65,6 +65,7 @@ export async function runLibeufinRefundMultipleUsersTest(t: GlobalTestState) {
|
|||||||
t,
|
t,
|
||||||
[user01nexus, user02nexus],
|
[user01nexus, user02nexus],
|
||||||
[user01sandbox, user02sandbox],
|
[user01sandbox, user02sandbox],
|
||||||
|
["twg"],
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -55,6 +55,7 @@ export async function runLibeufinRefundTest(t: GlobalTestState) {
|
|||||||
t,
|
t,
|
||||||
[user01nexus, user02nexus],
|
[user01nexus, user02nexus],
|
||||||
[user01sandbox, user02sandbox],
|
[user01sandbox, user02sandbox],
|
||||||
|
["twg"],
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user