aboutsummaryrefslogtreecommitdiff
path: root/packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts
diff options
context:
space:
mode:
authorFlorian Dold <florian@dold.me>2022-12-23 12:59:29 +0100
committerFlorian Dold <florian@dold.me>2022-12-23 13:19:41 +0100
commit083c4cf5d96314c44dd716cf3cc931e95b651bbd (patch)
tree7f15a46224d5dfe495e26dc6ec66996c889498ff /packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts
parentd98711cb51d13bb2da3682014c7c6e75d7fbb4f0 (diff)
spill extra functionality from wallet-cli into taler-harness
We want to keep taler-wallet-cli smaller and have fewer dependencies.
Diffstat (limited to 'packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts')
-rw-r--r--packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts74
1 files changed, 74 insertions, 0 deletions
diff --git a/packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts b/packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts
new file mode 100644
index 000000000..53aacca84
--- /dev/null
+++ b/packages/taler-harness/src/integrationtests/test-libeufin-bad-gateway.ts
@@ -0,0 +1,74 @@
+/*
+ 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, delayMs } from "../harness/harness.js";
+import {
+ NexusUserBundle,
+ LibeufinNexusApi,
+ LibeufinNexusService,
+ LibeufinSandboxService,
+} from "../harness/libeufin.js";
+
+/**
+ * Testing how Nexus reacts when the Sandbox is unreachable.
+ * Typically, because the user specified a wrong EBICS endpoint.
+ */
+export async function runLibeufinBadGatewayTest(t: GlobalTestState) {
+ /**
+ * User saltetd "01"
+ */
+ const user01nexus = new NexusUserBundle(
+ "01", "http://localhost:5010/not-found", // the EBICS endpoint at Sandbox
+ );
+
+ // Start Nexus
+ const libeufinNexus = await LibeufinNexusService.create(t, {
+ httpPort: 5011,
+ databaseJdbcUri: `jdbc:sqlite:${t.testDir}/libeufin-nexus.sqlite3`,
+ });
+ await libeufinNexus.start();
+ await libeufinNexus.pingUntilAvailable();
+
+ // Start Sandbox
+ const libeufinSandbox = await LibeufinSandboxService.create(t, {
+ httpPort: 5010,
+ databaseJdbcUri: `jdbc:sqlite:${t.testDir}/libeufin-sandbox.sqlite3`,
+ });
+ await libeufinSandbox.start();
+ await libeufinSandbox.pingUntilAvailable();
+
+ // Connecting to a non-existent Sandbox endpoint.
+ await LibeufinNexusApi.createEbicsBankConnection(
+ libeufinNexus,
+ user01nexus.connReq
+ );
+
+ // 502 Bad Gateway expected.
+ try {
+ await LibeufinNexusApi.connectBankConnection(
+ libeufinNexus,
+ user01nexus.connReq.name,
+ );
+ } catch(e: any) {
+ t.assertTrue(e.response.status == 502);
+ return;
+ }
+ t.assertTrue(false);
+}
+runLibeufinBadGatewayTest.suites = ["libeufin"];