diff options
author | Florian Dold <florian@dold.me> | 2024-02-29 23:29:57 +0100 |
---|---|---|
committer | Florian Dold <florian@dold.me> | 2024-02-29 23:29:57 +0100 |
commit | 1fcfba5c1d385da79795d2d1a507ed6ce658af3c (patch) | |
tree | b5a090aae0b8cd5ad8169100b3b91d0ad402a2d2 /packages/taler-harness/src/integrationtests | |
parent | 277a5c641df336d8b5b2d9bd6559e45f0b02aa79 (diff) | |
download | wallet-core-1fcfba5c1d385da79795d2d1a507ed6ce658af3c.tar.xz |
taler-harness: test for observability events
Diffstat (limited to 'packages/taler-harness/src/integrationtests')
-rw-r--r-- | packages/taler-harness/src/integrationtests/test-wallet-observability.ts | 119 | ||||
-rw-r--r-- | packages/taler-harness/src/integrationtests/testrunner.ts | 2 |
2 files changed, 121 insertions, 0 deletions
diff --git a/packages/taler-harness/src/integrationtests/test-wallet-observability.ts b/packages/taler-harness/src/integrationtests/test-wallet-observability.ts new file mode 100644 index 000000000..5dff8670e --- /dev/null +++ b/packages/taler-harness/src/integrationtests/test-wallet-observability.ts @@ -0,0 +1,119 @@ +/* + 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 { NotificationType, WalletNotification } from "@gnu-taler/taler-util"; +import { WalletApiOperation } from "@gnu-taler/taler-wallet-core"; +import { CoinConfig, defaultCoinConfig } from "../harness/denomStructures.js"; +import { + ExchangeService, + FakebankService, + GlobalTestState, + WalletClient, + WalletService, + setupDb, +} from "../harness/harness.js"; +import { withdrawViaBankV2 } from "../harness/helpers.js"; + +export async function runWalletObservabilityTest(t: GlobalTestState) { + // Set up test environment + + const db = await setupDb(t); + + const bank = await FakebankService.create(t, { + allowRegistrations: true, + currency: "TESTKUDOS", + database: db.connStr, + httpPort: 8082, + }); + + const exchange = ExchangeService.create(t, { + name: "testexchange-1", + currency: "TESTKUDOS", + httpPort: 8081, + database: db.connStr, + }); + + const exchangeBankAccount = await bank.createExchangeAccount( + "myexchange", + "x", + ); + exchange.addBankAccount("1", exchangeBankAccount); + + bank.setSuggestedExchange(exchange, exchangeBankAccount.accountPaytoUri); + + await bank.start(); + + await bank.pingUntilAvailable(); + + const coinConfig: CoinConfig[] = defaultCoinConfig.map((x) => x("TESTKUDOS")); + exchange.addCoinConfigList(coinConfig); + + await exchange.start(); + await exchange.pingUntilAvailable(); + + const walletService = new WalletService(t, { + name: "wallet", + useInMemoryDb: true, + }); + await walletService.start(); + await walletService.pingUntilAvailable(); + + const allNotifications: WalletNotification[] = []; + + const walletClient = new WalletClient({ + name: "wallet", + unixPath: walletService.socketPath, + onNotification(n) { + console.log("got notification", n); + allNotifications.push(n); + }, + }); + await walletClient.connect(); + await walletClient.client.call(WalletApiOperation.InitWallet, { + config: { + testing: { + skipDefaults: true, + emitObservabilityEvents: true, + }, + }, + }); + + const wres = await withdrawViaBankV2(t, { + amount: "TESTKUDOS:10", + bank, + exchange, + walletClient, + }); + await wres.withdrawalFinishedCond; + + const requestObsEvents = allNotifications.filter( + (x) => x.type === NotificationType.RequestObservabilityEvent, + ); + const taskObsEvents = allNotifications.filter( + (x) => x.type === NotificationType.TaskObservabilityEvent, + ); + + console.log(`req events: ${requestObsEvents.length}`); + console.log(`task events: ${taskObsEvents.length}`); + + t.assertTrue(requestObsEvents.length > 30); + t.assertTrue(taskObsEvents.length > 30); +} + +runWalletObservabilityTest.suites = ["wallet"]; diff --git a/packages/taler-harness/src/integrationtests/testrunner.ts b/packages/taler-harness/src/integrationtests/testrunner.ts index 73619a047..e6b409f59 100644 --- a/packages/taler-harness/src/integrationtests/testrunner.ts +++ b/packages/taler-harness/src/integrationtests/testrunner.ts @@ -104,6 +104,7 @@ import { runWithdrawalFakebankTest } from "./test-withdrawal-fakebank.js"; import { runWithdrawalFeesTest } from "./test-withdrawal-fees.js"; import { runWithdrawalHugeTest } from "./test-withdrawal-huge.js"; import { runWithdrawalManualTest } from "./test-withdrawal-manual.js"; +import { runWalletObservabilityTest } from "./test-wallet-observability.js"; /** * Test runner. @@ -198,6 +199,7 @@ const allTests: TestMainFunction[] = [ runWalletBalanceNotificationsTest, runExchangeManagementTest, runWalletConfigTest, + runWalletObservabilityTest ]; export interface TestRunSpec { |