wallet-core: fix type error in purse_expiration

This commit is contained in:
Florian Dold 2023-09-15 12:51:57 +02:00
parent 1d9d63b341
commit 5de329e653
No known key found for this signature in database
GPG Key ID: D2E4F00F29D02A4B
5 changed files with 116 additions and 7 deletions

View File

@ -73,7 +73,7 @@ export async function runPeerToPeerPullTest(t: GlobalTestState) {
await withdrawRes.withdrawalFinishedCond; await withdrawRes.withdrawalFinishedCond;
const purse_expiration = AbsoluteTime.toProtocolTimestamp( const purseExpiration = AbsoluteTime.toProtocolTimestamp(
AbsoluteTime.addDuration( AbsoluteTime.addDuration(
AbsoluteTime.now(), AbsoluteTime.now(),
Duration.fromSpec({ days: 2 }), Duration.fromSpec({ days: 2 }),
@ -87,7 +87,7 @@ export async function runPeerToPeerPullTest(t: GlobalTestState) {
partialContractTerms: { partialContractTerms: {
summary: "Hello World", summary: "Hello World",
amount: "TESTKUDOS:5", amount: "TESTKUDOS:5",
purse_expiration, purse_expiration: purseExpiration,
}, },
}, },
); );

View File

@ -0,0 +1,110 @@
/*
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 { WalletApiOperation } from "@gnu-taler/taler-wallet-core";
import { GlobalTestState } from "../harness/harness.js";
import {
createSimpleTestkudosEnvironmentV2,
withdrawViaBankV2,
makeTestPaymentV2,
} from "../harness/helpers.js";
import {
AbsoluteTime,
Duration,
NotificationType,
TransactionMajorState,
TransactionMinorState,
j2s,
} from "@gnu-taler/taler-util";
/**
* Test that creates various transactions and exports the resulting
* database. Used to generate a database export file for DB compatibility
* testing.
*/
export async function runWalletGenDbTest(t: GlobalTestState) {
// Set up test environment
const { walletClient, bank, exchange, merchant } =
await createSimpleTestkudosEnvironmentV2(t);
// Withdraw digital cash into the wallet.
await withdrawViaBankV2(t, {
walletClient,
bank,
exchange,
amount: "TESTKUDOS:50",
});
await walletClient.call(WalletApiOperation.TestingWaitTransactionsFinal, {});
const order = {
summary: "Buy me!",
amount: "TESTKUDOS:10",
fulfillment_url: "taler://fulfillment-success/thx",
};
await makeTestPaymentV2(t, { walletClient, merchant, order });
await walletClient.call(WalletApiOperation.TestingWaitTransactionsFinal, {});
const purseExpiration = AbsoluteTime.toProtocolTimestamp(
AbsoluteTime.addDuration(
AbsoluteTime.now(),
Duration.fromSpec({ days: 2 }),
),
);
const peerPullIniResp = await walletClient.call(
WalletApiOperation.InitiatePeerPullCredit,
{
exchangeBaseUrl: exchange.baseUrl,
partialContractTerms: {
summary: "Hello World",
amount: "TESTKUDOS:5",
purse_expiration: purseExpiration,
},
},
);
const peerPullCreditReadyCond = walletClient.waitForNotificationCond(
(x) =>
x.type === NotificationType.TransactionStateTransition &&
x.transactionId === peerPullIniResp.transactionId &&
x.newTxState.major === TransactionMajorState.Pending &&
x.newTxState.minor === TransactionMinorState.Ready,
);
await peerPullCreditReadyCond;
const checkResp = await walletClient.call(
WalletApiOperation.PreparePeerPullDebit,
{
talerUri: peerPullIniResp.talerUri,
},
);
await walletClient.call(WalletApiOperation.ConfirmPeerPullDebit, {
transactionId: checkResp.transactionId,
});
await walletClient.call(WalletApiOperation.TestingWaitTransactionsFinal, {});
}
runWalletGenDbTest.suites = ["wallet"];

View File

@ -110,6 +110,7 @@ import { runWithdrawalFakebankTest } from "./test-withdrawal-fakebank.js";
import { runWithdrawalFeesTest } from "./test-withdrawal-fees.js"; import { runWithdrawalFeesTest } from "./test-withdrawal-fees.js";
import { runWithdrawalHugeTest } from "./test-withdrawal-huge.js"; import { runWithdrawalHugeTest } from "./test-withdrawal-huge.js";
import { runWithdrawalManualTest } from "./test-withdrawal-manual.js"; import { runWithdrawalManualTest } from "./test-withdrawal-manual.js";
import { runWalletGenDbTest } from "./test-wallet-gendb.js";
/** /**
* Test runner. * Test runner.
@ -209,6 +210,7 @@ const allTests: TestMainFunction[] = [
runTermOfServiceFormatTest, runTermOfServiceFormatTest,
runStoredBackupsTest, runStoredBackupsTest,
runPaymentExpiredTest, runPaymentExpiredTest,
runWalletGenDbTest,
]; ];
export interface TestRunSpec { export interface TestRunSpec {

View File

@ -392,7 +392,7 @@ async function handlePeerPullCreditCreatePurse(
const econtractResp = await ws.cryptoApi.encryptContractForDeposit({ const econtractResp = await ws.cryptoApi.encryptContractForDeposit({
contractPriv: pullIni.contractPriv, contractPriv: pullIni.contractPriv,
contractPub: pullIni.contractPub, contractPub: pullIni.contractPub,
contractTerms: contractTermsRecord, contractTerms: contractTermsRecord.contractTermsRaw,
pursePriv: pullIni.pursePriv, pursePriv: pullIni.pursePriv,
pursePub: pullIni.pursePub, pursePub: pullIni.pursePub,
nonce: pullIni.contractEncNonce, nonce: pullIni.contractEncNonce,

View File

@ -245,8 +245,6 @@ async function processPeerPushDebitCreateReserve(
hash(decodeCrock(econtractResp.econtract.econtract)), hash(decodeCrock(econtractResp.econtract.econtract)),
); );
logger.info(`econtract hash: ${econtractHash}`);
const createPurseUrl = new URL( const createPurseUrl = new URL(
`purses/${peerPushInitiation.pursePub}/create`, `purses/${peerPushInitiation.pursePub}/create`,
peerPushInitiation.exchangeBaseUrl, peerPushInitiation.exchangeBaseUrl,
@ -257,7 +255,7 @@ async function processPeerPushDebitCreateReserve(
merge_pub: peerPushInitiation.mergePub, merge_pub: peerPushInitiation.mergePub,
purse_sig: purseSigResp.sig, purse_sig: purseSigResp.sig,
h_contract_terms: hContractTerms, h_contract_terms: hContractTerms,
purse_expiration: purseExpiration, purse_expiration: timestampProtocolFromDb(purseExpiration),
deposits: depositSigsResp.deposits, deposits: depositSigsResp.deposits,
min_age: 0, min_age: 0,
econtract: econtractResp.econtract, econtract: econtractResp.econtract,
@ -649,7 +647,6 @@ export async function initiatePeerPushDebit(
// we might want to mark the coins as used and spend them // we might want to mark the coins as used and spend them
// after we've been able to create the purse. // after we've been able to create the purse.
await spendCoins(ws, tx, { await spendCoins(ws, tx, {
// allocationId: `txn:peer-push-debit:${pursePair.pub}`,
allocationId: constructTransactionIdentifier({ allocationId: constructTransactionIdentifier({
tag: TransactionType.PeerPushDebit, tag: TransactionType.PeerPushDebit,
pursePub: pursePair.pub, pursePub: pursePair.pub,