-missing file, internal benchmark
This commit is contained in:
parent
c54476c40e
commit
68811cc5f5
101
packages/taler-wallet-cli/src/env-full.ts
Normal file
101
packages/taler-wallet-cli/src/env-full.ts
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
/*
|
||||||
|
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 { Duration, j2s, URL } from "@gnu-taler/taler-util";
|
||||||
|
import { CoinConfig, defaultCoinConfig } from "./harness/denomStructures.js";
|
||||||
|
import {
|
||||||
|
GlobalTestState,
|
||||||
|
setupDb,
|
||||||
|
ExchangeService,
|
||||||
|
FakebankService,
|
||||||
|
MerchantService,
|
||||||
|
getPayto,
|
||||||
|
} from "./harness/harness.js";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Entry point for the full Taler test environment.
|
||||||
|
*/
|
||||||
|
export async function runEnvFull(t: GlobalTestState): Promise<void> {
|
||||||
|
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 merchant = await MerchantService.create(t, {
|
||||||
|
name: "testmerchant-1",
|
||||||
|
currency: "TESTKUDOS",
|
||||||
|
httpPort: 8083,
|
||||||
|
database: db.connStr,
|
||||||
|
});
|
||||||
|
|
||||||
|
const exchangeBankAccount = await bank.createExchangeAccount(
|
||||||
|
"myexchange",
|
||||||
|
"x",
|
||||||
|
);
|
||||||
|
console.log("exchange bank account", j2s(exchangeBankAccount));
|
||||||
|
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();
|
||||||
|
|
||||||
|
merchant.addExchange(exchange);
|
||||||
|
|
||||||
|
await merchant.start();
|
||||||
|
await merchant.pingUntilAvailable();
|
||||||
|
|
||||||
|
await merchant.addInstance({
|
||||||
|
id: "default",
|
||||||
|
name: "Default Instance",
|
||||||
|
paytoUris: [getPayto("merchant-default")],
|
||||||
|
defaultWireTransferDelay: Duration.toTalerProtocolDuration(
|
||||||
|
Duration.fromSpec({ minutes: 1 }),
|
||||||
|
),
|
||||||
|
});
|
||||||
|
|
||||||
|
await merchant.addInstance({
|
||||||
|
id: "minst1",
|
||||||
|
name: "minst1",
|
||||||
|
paytoUris: [getPayto("minst1")],
|
||||||
|
defaultWireTransferDelay: Duration.toTalerProtocolDuration(
|
||||||
|
Duration.fromSpec({ minutes: 1 }),
|
||||||
|
),
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log("setup done!");
|
||||||
|
}
|
@ -48,6 +48,7 @@ import {
|
|||||||
import {
|
import {
|
||||||
CryptoDispatcher,
|
CryptoDispatcher,
|
||||||
getDefaultNodeWallet,
|
getDefaultNodeWallet,
|
||||||
|
getDefaultNodeWallet2,
|
||||||
getErrorDetailFromException,
|
getErrorDetailFromException,
|
||||||
nativeCrypto,
|
nativeCrypto,
|
||||||
NodeHttpLib,
|
NodeHttpLib,
|
||||||
@ -865,6 +866,34 @@ advancedCli
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
advancedCli
|
||||||
|
.subcommand("benchInternal", "bench-internal", {
|
||||||
|
help: "Run the 'bench-internal' benchmark",
|
||||||
|
})
|
||||||
|
.action(async (args) => {
|
||||||
|
const myHttpLib = new NodeHttpLib();
|
||||||
|
myHttpLib.setThrottling(false);
|
||||||
|
const res = await getDefaultNodeWallet2({
|
||||||
|
// No persistent DB storage.
|
||||||
|
persistentStoragePath: undefined,
|
||||||
|
httpLib: myHttpLib,
|
||||||
|
});
|
||||||
|
const wallet = res.wallet;
|
||||||
|
await wallet.client.call(WalletApiOperation.InitWallet, {});
|
||||||
|
await wallet.client.call(WalletApiOperation.RunIntegrationTest, {
|
||||||
|
amountToSpend: "TESTKUDOS:1",
|
||||||
|
amountToWithdraw: "TESTKUDOS:3",
|
||||||
|
bankBaseUrl: "http://localhost:8082/",
|
||||||
|
bankAccessApiBaseUrl: "http://localhost:8082/taler-bank-access/",
|
||||||
|
exchangeBaseUrl: "http://localhost:8081/",
|
||||||
|
merchantBaseUrl: "http://localhost:8083/",
|
||||||
|
});
|
||||||
|
await wallet.runTaskLoop({
|
||||||
|
stopWhenDone: true,
|
||||||
|
});
|
||||||
|
wallet.stop();
|
||||||
|
});
|
||||||
|
|
||||||
advancedCli
|
advancedCli
|
||||||
.subcommand("bench1", "bench1", {
|
.subcommand("bench1", "bench1", {
|
||||||
help: "Run the 'bench1' benchmark",
|
help: "Run the 'bench1' benchmark",
|
||||||
|
@ -356,7 +356,7 @@ export class CryptoDispatcher {
|
|||||||
// it to make sure it doesn't keep us alive if there is no work.)
|
// it to make sure it doesn't keep us alive if there is no work.)
|
||||||
return new Promise<T>((resolve, reject) => {
|
return new Promise<T>((resolve, reject) => {
|
||||||
let timedOut = false;
|
let timedOut = false;
|
||||||
const timeout = timer.after(5000, () => {
|
const timeout = timer.after(10000, () => {
|
||||||
logger.warn(`crypto RPC call ('${operation}') timed out`);
|
logger.warn(`crypto RPC call ('${operation}') timed out`);
|
||||||
timedOut = true;
|
timedOut = true;
|
||||||
reject(new Error(`crypto RPC call ('${operation}') timed out`));
|
reject(new Error(`crypto RPC call ('${operation}') timed out`));
|
||||||
|
@ -431,11 +431,12 @@ export async function testWithLocal() {
|
|||||||
bankBaseUrl: "http://localhost:8082/",
|
bankBaseUrl: "http://localhost:8082/",
|
||||||
bankAccessApiBaseUrl: "http://localhost:8082/taler-bank-access/",
|
bankAccessApiBaseUrl: "http://localhost:8082/taler-bank-access/",
|
||||||
exchangeBaseUrl: "http://localhost:8081/",
|
exchangeBaseUrl: "http://localhost:8081/",
|
||||||
merchantBaseUrl: "http://backend.demo.taler.net:8083/",
|
merchantBaseUrl: "http://localhost:8083/",
|
||||||
});
|
});
|
||||||
await w.wallet.runTaskLoop({
|
await w.wallet.runTaskLoop({
|
||||||
stopWhenDone: true,
|
stopWhenDone: true,
|
||||||
});
|
});
|
||||||
|
w.wallet.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
Loading…
Reference in New Issue
Block a user