add integration test for p2p age restrictions
This commit is contained in:
parent
4aaece0eff
commit
b1f77f4662
@ -28,7 +28,7 @@ import {
|
|||||||
/**
|
/**
|
||||||
* Run test for basic, bank-integrated withdrawal and payment.
|
* Run test for basic, bank-integrated withdrawal and payment.
|
||||||
*/
|
*/
|
||||||
export async function runAgeRestrictionsTest(t: GlobalTestState) {
|
export async function runAgeRestrictionsMerchantTest(t: GlobalTestState) {
|
||||||
// Set up test environment
|
// Set up test environment
|
||||||
|
|
||||||
const { wallet: walletOne, bank, exchange, merchant } =
|
const { wallet: walletOne, bank, exchange, merchant } =
|
||||||
@ -109,4 +109,4 @@ export async function runAgeRestrictionsTest(t: GlobalTestState) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
runAgeRestrictionsTest.suites = ["wallet"];
|
runAgeRestrictionsMerchantTest.suites = ["wallet"];
|
@ -0,0 +1,80 @@
|
|||||||
|
/*
|
||||||
|
This file is part of GNU Taler
|
||||||
|
(C) 2022 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 { defaultCoinConfig } from "../harness/denomStructures.js";
|
||||||
|
import { GlobalTestState, WalletCli } from "../harness/harness.js";
|
||||||
|
import {
|
||||||
|
createSimpleTestkudosEnvironment,
|
||||||
|
withdrawViaBank,
|
||||||
|
makeTestPayment,
|
||||||
|
} from "../harness/helpers.js";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run test for basic, bank-integrated withdrawal and payment.
|
||||||
|
*/
|
||||||
|
export async function runAgeRestrictionsPeerTest(t: GlobalTestState) {
|
||||||
|
// Set up test environment
|
||||||
|
|
||||||
|
const {
|
||||||
|
wallet: walletOne,
|
||||||
|
bank,
|
||||||
|
exchange,
|
||||||
|
merchant,
|
||||||
|
} = await createSimpleTestkudosEnvironment(
|
||||||
|
t,
|
||||||
|
defaultCoinConfig.map((x) => x("TESTKUDOS")),
|
||||||
|
{
|
||||||
|
ageMaskSpec: "8:10:12:14:16:18:21",
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
const walletTwo = new WalletCli(t, "walletTwo");
|
||||||
|
const walletThree = new WalletCli(t, "walletThree");
|
||||||
|
|
||||||
|
{
|
||||||
|
const wallet = walletOne;
|
||||||
|
|
||||||
|
await withdrawViaBank(t, {
|
||||||
|
wallet,
|
||||||
|
bank,
|
||||||
|
exchange,
|
||||||
|
amount: "TESTKUDOS:20",
|
||||||
|
restrictAge: 13,
|
||||||
|
});
|
||||||
|
|
||||||
|
const order = {
|
||||||
|
summary: "Buy me!",
|
||||||
|
amount: "TESTKUDOS:5",
|
||||||
|
fulfillment_url: "taler://fulfillment-success/thx",
|
||||||
|
minimum_age: 9,
|
||||||
|
};
|
||||||
|
|
||||||
|
await wallet.client.call(WalletApiOperation.InitiatePeerPushPayment, {
|
||||||
|
amount: "TESTKUDOS:1",
|
||||||
|
partialContractTerms: {
|
||||||
|
summary: "Hello, World",
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
await wallet.runUntilDone();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
runAgeRestrictionsPeerTest.suites = ["wallet"];
|
@ -25,7 +25,7 @@ import {
|
|||||||
shouldLingerInTest,
|
shouldLingerInTest,
|
||||||
TestRunResult,
|
TestRunResult,
|
||||||
} from "../harness/harness.js";
|
} from "../harness/harness.js";
|
||||||
import { runAgeRestrictionsTest } from "./test-age-restrictions.js";
|
import { runAgeRestrictionsMerchantTest } from "./test-age-restrictions-merchant.js";
|
||||||
import { runBankApiTest } from "./test-bank-api.js";
|
import { runBankApiTest } from "./test-bank-api.js";
|
||||||
import { runClaimLoopTest } from "./test-claim-loop.js";
|
import { runClaimLoopTest } from "./test-claim-loop.js";
|
||||||
import { runClauseSchnorrTest } from "./test-clause-schnorr.js";
|
import { runClauseSchnorrTest } from "./test-clause-schnorr.js";
|
||||||
@ -90,6 +90,7 @@ import { runWithdrawalAbortBankTest } from "./test-withdrawal-abort-bank.js";
|
|||||||
import { runWithdrawalBankIntegratedTest } from "./test-withdrawal-bank-integrated.js";
|
import { runWithdrawalBankIntegratedTest } from "./test-withdrawal-bank-integrated.js";
|
||||||
import { runWithdrawalFakebankTest } from "./test-withdrawal-fakebank.js";
|
import { runWithdrawalFakebankTest } from "./test-withdrawal-fakebank.js";
|
||||||
import { runTestWithdrawalManualTest } from "./test-withdrawal-manual.js";
|
import { runTestWithdrawalManualTest } from "./test-withdrawal-manual.js";
|
||||||
|
import { runAgeRestrictionsPeerTest } from "./test-age-restrictions-peer.js";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test runner.
|
* Test runner.
|
||||||
@ -106,7 +107,8 @@ interface TestMainFunction {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const allTests: TestMainFunction[] = [
|
const allTests: TestMainFunction[] = [
|
||||||
runAgeRestrictionsTest,
|
runAgeRestrictionsMerchantTest,
|
||||||
|
runAgeRestrictionsPeerTest,
|
||||||
runBankApiTest,
|
runBankApiTest,
|
||||||
runClaimLoopTest,
|
runClaimLoopTest,
|
||||||
runClauseSchnorrTest,
|
runClauseSchnorrTest,
|
||||||
|
Loading…
Reference in New Issue
Block a user