From 083c4cf5d96314c44dd716cf3cc931e95b651bbd Mon Sep 17 00:00:00 2001 From: Florian Dold Date: Fri, 23 Dec 2022 12:59:29 +0100 Subject: spill extra functionality from wallet-cli into taler-harness We want to keep taler-wallet-cli smaller and have fewer dependencies. --- .../test-libeufin-api-scheduling.ts | 106 +++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 packages/taler-harness/src/integrationtests/test-libeufin-api-scheduling.ts (limited to 'packages/taler-harness/src/integrationtests/test-libeufin-api-scheduling.ts') diff --git a/packages/taler-harness/src/integrationtests/test-libeufin-api-scheduling.ts b/packages/taler-harness/src/integrationtests/test-libeufin-api-scheduling.ts new file mode 100644 index 000000000..95f4bfaa0 --- /dev/null +++ b/packages/taler-harness/src/integrationtests/test-libeufin-api-scheduling.ts @@ -0,0 +1,106 @@ +/* + 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 + */ + +/** + * Imports. + */ +import { GlobalTestState } from "../harness/harness.js"; +import { + launchLibeufinServices, + LibeufinNexusApi, + LibeufinNexusService, + NexusUserBundle, + SandboxUserBundle, +} from "../harness/libeufin.js"; + +/** + * Test Nexus scheduling API. It creates a task, check whether it shows + * up, then deletes it, and check if it's gone. Ideally, a check over the + * _liveliness_ of a scheduled task should happen. + */ +export async function runLibeufinApiSchedulingTest(t: GlobalTestState) { + const nexus = await LibeufinNexusService.create(t, { + httpPort: 5011, + databaseJdbcUri: `jdbc:sqlite:${t.testDir}/libeufin-nexus.sqlite3`, + }); + await nexus.start(); + await nexus.pingUntilAvailable(); + + const user01nexus = new NexusUserBundle( + "01", + "http://localhost:5010/ebicsweb", + ); + const user01sandbox = new SandboxUserBundle("01"); + await launchLibeufinServices(t, [user01nexus], [user01sandbox]); + await LibeufinNexusApi.postTask(nexus, user01nexus.localAccountName, { + name: "test-task", + cronspec: "* * *", + type: "fetch", + params: { + level: "all", + rangeType: "all", + }, + }); + let resp = await LibeufinNexusApi.getTasks( + nexus, + user01nexus.localAccountName, + "test-task", + ); + t.assertTrue(resp.data["taskName"] == "test-task"); + await LibeufinNexusApi.deleteTask( + nexus, + user01nexus.localAccountName, + "test-task", + ); + try { + await LibeufinNexusApi.getTasks( + nexus, + user01nexus.localAccountName, + "test-task", + ); + } catch (err: any) { + t.assertTrue(err.response.status == 404); + } + + // Same with submit task. + await LibeufinNexusApi.postTask(nexus, user01nexus.localAccountName, { + name: "test-task", + cronspec: "* * *", + type: "submit", + params: {}, + }); + resp = await LibeufinNexusApi.getTasks( + nexus, + user01nexus.localAccountName, + "test-task", + ); + t.assertTrue(resp.data["taskName"] == "test-task"); + await LibeufinNexusApi.deleteTask( + nexus, + user01nexus.localAccountName, + "test-task", + ); + try { + await LibeufinNexusApi.getTasks( + nexus, + user01nexus.localAccountName, + "test-task", + ); + } catch (err: any) { + t.assertTrue(err.response.status == 404); + } +} +runLibeufinApiSchedulingTest.suites = ["libeufin"]; -- cgit v1.2.3