diff options
author | Florian Dold <florian@dold.me> | 2021-08-23 22:28:36 +0200 |
---|---|---|
committer | Florian Dold <florian@dold.me> | 2021-08-23 22:28:46 +0200 |
commit | 828e65b0eba66b7c999d9867396797a239449a6d (patch) | |
tree | 2dcb55dfb5c9854c196fc21d0d5282928de12ff6 /packages/taler-wallet-cli | |
parent | 67e511d719cbc3e7f2b391a8d6914406caa2fb24 (diff) |
fix un-offered denom situation, test case almost works
Diffstat (limited to 'packages/taler-wallet-cli')
3 files changed, 157 insertions, 8 deletions
diff --git a/packages/taler-wallet-cli/src/integrationtests/harness.ts b/packages/taler-wallet-cli/src/integrationtests/harness.ts index 10b93b330..d47dfe098 100644 --- a/packages/taler-wallet-cli/src/integrationtests/harness.ts +++ b/packages/taler-wallet-cli/src/integrationtests/harness.ts @@ -838,12 +838,6 @@ export class ExchangeService implements ExchangeServiceInterface { e.roundUnit ?? `${e.currency}:0.01`, ); setTalerPaths(config, gc.testDir + "/talerhome"); - - config.setString( - "exchange", - "keydir", - "${TALER_DATA_HOME}/exchange/live-keys/", - ); config.setString( "exchange", "revocation_dir", @@ -1078,6 +1072,23 @@ export class ExchangeService implements ExchangeServiceInterface { ); } + async purgeSecmodKeys(): Promise<void> { + const cfg = Configuration.load(this.configFilename); + const rsaKeydir = cfg.getPath("taler-exchange-secmod-rsa", "KEY_DIR").required(); + const eddsaKeydir = cfg.getPath("taler-exchange-secmod-eddsa", "KEY_DIR").required(); + // Be *VERY* careful when changing this, or you will accidentally delete user data. + await sh(this.globalState, "rm-secmod-keys", `rm -rf ${rsaKeydir}/COIN_*`); + await sh(this.globalState, "rm-secmod-keys", `rm ${eddsaKeydir}/*`); + } + + async purgeDatabase(): Promise<void> { + await sh( + this.globalState, + "exchange-dbinit", + `taler-exchange-dbinit -r -c "${this.configFilename}"`, + ); + } + async start(): Promise<void> { if (this.isRunning()) { throw Error("exchange is already running"); @@ -1111,8 +1122,6 @@ export class ExchangeService implements ExchangeServiceInterface { [ "-c", this.configFilename, - "--num-threads", - "1", ...this.timetravelArgArr, ], `exchange-httpd-${this.name}`, diff --git a/packages/taler-wallet-cli/src/integrationtests/test-denom-unoffered.ts b/packages/taler-wallet-cli/src/integrationtests/test-denom-unoffered.ts new file mode 100644 index 000000000..7a1ff669a --- /dev/null +++ b/packages/taler-wallet-cli/src/integrationtests/test-denom-unoffered.ts @@ -0,0 +1,138 @@ +/* + This file is part of GNU Taler + (C) 2021 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 { + PreparePayResultType, + TalerErrorCode, + TalerErrorDetails, + TransactionType, +} from "@gnu-taler/taler-util"; +import { + WalletApiOperation, +} from "@gnu-taler/taler-wallet-core"; +import { makeEventId } from "@gnu-taler/taler-wallet-core"; +import { GlobalTestState, MerchantPrivateApi } from "./harness"; +import { createSimpleTestkudosEnvironment, withdrawViaBank } from "./helpers"; + +export async function runDenomUnofferedTest(t: GlobalTestState) { + // Set up test environment + + const { + wallet, + bank, + exchange, + merchant, + } = await createSimpleTestkudosEnvironment(t); + + // Withdraw digital cash into the wallet. + + await withdrawViaBank(t, { wallet, bank, exchange, amount: "TESTKUDOS:20" }); + + // Make the exchange forget the denomination. + // Effectively we completely reset the exchange, + // but keep the exchange master public key. + + await exchange.stop(); + await exchange.purgeDatabase(); + await exchange.purgeSecmodKeys(); + await exchange.start(); + await exchange.pingUntilAvailable(); + + await merchant.stop(); + await merchant.start(); + await merchant.pingUntilAvailable(); + + const order = { + summary: "Buy me!", + amount: "TESTKUDOS:5", + fulfillment_url: "taler://fulfillment-success/thx", + }; + + { + const orderResp = await MerchantPrivateApi.createOrder( + merchant, + "default", + { + order: order, + }, + ); + + let orderStatus = await MerchantPrivateApi.queryPrivateOrderStatus( + merchant, + { + orderId: orderResp.order_id, + }, + ); + + t.assertTrue(orderStatus.order_status === "unpaid"); + + // Make wallet pay for the order + + const preparePayResult = await wallet.client.call( + WalletApiOperation.PreparePayForUri, + { + talerPayUri: orderStatus.taler_pay_uri, + }, + ); + + t.assertTrue( + preparePayResult.status === PreparePayResultType.PaymentPossible, + ); + + const exc = await t.assertThrowsAsync(async () => { + await wallet.client.call(WalletApiOperation.ConfirmPay, { + proposalId: preparePayResult.proposalId, + }); + }); + + const errorDetails: TalerErrorDetails = exc.operationError; + // FIXME: We might want a more specific error code here! + t.assertDeepEqual( + errorDetails.code, + TalerErrorCode.WALLET_UNEXPECTED_REQUEST_ERROR, + ); + const merchantErrorCode = (errorDetails.details as any).errorResponse.code; + t.assertDeepEqual( + merchantErrorCode, + TalerErrorCode.MERCHANT_POST_ORDERS_ID_PAY_DENOMINATION_KEY_NOT_FOUND, + ); + + const purchId = makeEventId(TransactionType.Payment, preparePayResult.proposalId); + await wallet.client.call(WalletApiOperation.DeleteTransaction, { + transactionId: purchId, + }); + + // Now, delete the purchase and refresh operation. + } + + await wallet.client.call(WalletApiOperation.AddExchange, { + exchangeBaseUrl: exchange.baseUrl, + forceUpdate: true, + }); + + // Now withdrawal should work again. + await withdrawViaBank(t, { wallet, bank, exchange, amount: "TESTKUDOS:20" }); + + await wallet.runUntilDone(); + + const txs = await wallet.client.call(WalletApiOperation.GetTransactions, {}); + console.log(JSON.stringify(txs, undefined, 2)); +} + +runDenomUnofferedTest.suites = ["wallet"]; diff --git a/packages/taler-wallet-cli/src/integrationtests/testrunner.ts b/packages/taler-wallet-cli/src/integrationtests/testrunner.ts index ab699e8b5..25067fbbd 100644 --- a/packages/taler-wallet-cli/src/integrationtests/testrunner.ts +++ b/packages/taler-wallet-cli/src/integrationtests/testrunner.ts @@ -82,6 +82,7 @@ import { runPaymentForgettableTest } from "./test-payment-forgettable.js"; import { runPaymentZeroTest } from "./test-payment-zero.js"; import { runMerchantSpecPublicOrdersTest } from "./test-merchant-spec-public-orders.js"; import { runExchangeTimetravelTest } from "./test-exchange-timetravel.js"; +import { runDenomUnofferedTest } from "./test-denom-unoffered.js"; /** * Test runner. @@ -101,6 +102,7 @@ const allTests: TestMainFunction[] = [ runBankApiTest, runClaimLoopTest, runDepositTest, + runDenomUnofferedTest, runExchangeManagementTest, runExchangeTimetravelTest, runFeeRegressionTest, |