2017-06-11 11:48:06 +02:00
|
|
|
/*
|
|
|
|
This file is part of TALER
|
2020-03-28 20:45:53 +01:00
|
|
|
(C) 2016-2020 Taler Systems SA
|
2017-06-11 11:48:06 +02:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
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
|
|
|
|
TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2020-01-19 15:23:19 +01:00
|
|
|
* @file testing/test_taler_exchange_wirewatch.c
|
2017-06-11 11:48:06 +02:00
|
|
|
* @brief Tests for taler-exchange-wirewatch and taler-exchange-aggregator logic;
|
|
|
|
* Performs an invalid wire transfer to the exchange, and then checks that
|
|
|
|
* wirewatch immediately sends the money back.
|
|
|
|
* Then performs a valid wire transfer, waits for the reserve to expire,
|
|
|
|
* and then checks that the aggregator sends the money back.
|
|
|
|
* @author Christian Grothoff <christian@grothoff.org>
|
|
|
|
*/
|
|
|
|
#include "platform.h"
|
|
|
|
#include "taler_util.h"
|
|
|
|
#include <gnunet/gnunet_json_lib.h>
|
2019-12-24 22:37:31 +01:00
|
|
|
#include <gnunet/gnunet_pq_lib.h>
|
2017-06-11 11:48:06 +02:00
|
|
|
#include "taler_json_lib.h"
|
|
|
|
#include <microhttpd.h>
|
|
|
|
#include "taler_fakebank_lib.h"
|
2020-01-15 17:04:58 +01:00
|
|
|
#include "taler_testing_lib.h"
|
2017-06-11 11:48:06 +02:00
|
|
|
|
|
|
|
|
2020-01-15 17:04:58 +01:00
|
|
|
/**
|
|
|
|
* Bank configuration data.
|
|
|
|
*/
|
|
|
|
static struct TALER_TESTING_BankConfiguration bc;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper structure to keep exchange configuration values.
|
|
|
|
*/
|
2020-01-16 00:11:51 +01:00
|
|
|
static struct TALER_TESTING_ExchangeConfiguration ec;
|
2017-06-11 11:48:06 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Name of the configuration file to use.
|
|
|
|
*/
|
|
|
|
static char *config_filename;
|
|
|
|
|
2020-03-12 10:53:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the taler-exchange-aggregator, closer and transfer commands with
|
|
|
|
* our configuration file.
|
|
|
|
*
|
|
|
|
* @param label label to use for the command.
|
|
|
|
*/
|
|
|
|
#define CMD_EXEC_AGGREGATOR(label) \
|
|
|
|
TALER_TESTING_cmd_exec_aggregator (label "-aggregator", config_filename), \
|
|
|
|
TALER_TESTING_cmd_exec_transfer (label "-transfer", config_filename)
|
|
|
|
|
|
|
|
|
2020-01-16 00:11:51 +01:00
|
|
|
static struct TALER_TESTING_Command
|
|
|
|
transfer_to_exchange (const char *label,
|
2020-01-16 21:57:40 +01:00
|
|
|
const char *amount)
|
2017-06-11 11:48:06 +02:00
|
|
|
{
|
2020-01-16 00:11:51 +01:00
|
|
|
return TALER_TESTING_cmd_admin_add_incoming (label,
|
|
|
|
amount,
|
|
|
|
&bc.exchange_auth,
|
|
|
|
bc.user42_payto);
|
2020-01-15 17:04:58 +01:00
|
|
|
}
|
|
|
|
|
2020-01-16 21:57:40 +01:00
|
|
|
|
2020-01-15 17:04:58 +01:00
|
|
|
/**
|
|
|
|
* Main function that will tell the interpreter what commands to
|
|
|
|
* run.
|
|
|
|
*
|
|
|
|
* @param cls closure
|
|
|
|
*/
|
|
|
|
static void
|
|
|
|
run (void *cls,
|
|
|
|
struct TALER_TESTING_Interpreter *is)
|
|
|
|
{
|
|
|
|
struct TALER_TESTING_Command all[] = {
|
2020-12-11 23:44:01 +01:00
|
|
|
TALER_TESTING_cmd_auditor_add ("add-auditor-OK",
|
|
|
|
MHD_HTTP_NO_CONTENT,
|
|
|
|
false),
|
|
|
|
TALER_TESTING_cmd_wire_add ("add-wire-account",
|
|
|
|
"payto://x-taler-bank/localhost/2",
|
|
|
|
MHD_HTTP_NO_CONTENT,
|
|
|
|
false),
|
|
|
|
TALER_TESTING_cmd_exec_offline_sign_keys ("offline-sign-future-keys",
|
|
|
|
config_filename),
|
|
|
|
TALER_TESTING_cmd_check_keys_pull_all_keys ("refetch /keys",
|
|
|
|
1,
|
2020-12-14 15:42:32 +01:00
|
|
|
58 /* FIXME: wrong number... */),
|
2020-01-16 00:11:51 +01:00
|
|
|
TALER_TESTING_cmd_check_bank_empty ("expect-empty-transactions-on-start"),
|
2020-03-12 10:53:49 +01:00
|
|
|
CMD_EXEC_AGGREGATOR ("run-aggregator-on-empty"),
|
2020-01-16 00:11:51 +01:00
|
|
|
TALER_TESTING_cmd_exec_wirewatch ("run-wirewatch-on-empty",
|
2020-01-16 21:57:40 +01:00
|
|
|
config_filename),
|
2020-01-16 00:11:51 +01:00
|
|
|
TALER_TESTING_cmd_check_bank_empty ("expect-transfers-empty-after-dry-run"),
|
|
|
|
|
|
|
|
transfer_to_exchange ("run-transfer-good-to-exchange",
|
2020-01-16 21:57:40 +01:00
|
|
|
"EUR:5"),
|
2020-01-16 00:11:51 +01:00
|
|
|
TALER_TESTING_cmd_exec_wirewatch ("run-wirewatch-on-good-transfer",
|
2020-01-16 21:57:40 +01:00
|
|
|
config_filename),
|
2020-01-16 00:11:51 +01:00
|
|
|
|
2020-01-16 21:57:40 +01:00
|
|
|
TALER_TESTING_cmd_check_bank_admin_transfer (
|
|
|
|
"clear-good-transfer-to-the-exchange",
|
|
|
|
"EUR:5",
|
|
|
|
bc.user42_payto, // debit
|
|
|
|
bc.exchange_payto, // credit
|
|
|
|
"run-transfer-good-to-exchange"),
|
2020-01-16 00:11:51 +01:00
|
|
|
|
2020-03-28 20:45:53 +01:00
|
|
|
TALER_TESTING_cmd_exec_closer ("run-closer-non-expired-reserve",
|
|
|
|
config_filename,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL),
|
|
|
|
TALER_TESTING_cmd_exec_transfer ("do-idle-transfer", config_filename),
|
2020-01-16 00:11:51 +01:00
|
|
|
|
|
|
|
TALER_TESTING_cmd_check_bank_empty ("expect-empty-transactions-1"),
|
|
|
|
TALER_TESTING_cmd_sleep ("wait (5s)",
|
2020-01-16 21:57:40 +01:00
|
|
|
5),
|
2020-03-28 20:45:53 +01:00
|
|
|
TALER_TESTING_cmd_exec_closer ("run-closer-expired-reserve",
|
|
|
|
config_filename,
|
|
|
|
"EUR:4.99",
|
|
|
|
"EUR:0.01",
|
|
|
|
"run-transfer-good-to-exchange"),
|
|
|
|
TALER_TESTING_cmd_exec_transfer ("do-closing-transfer",
|
|
|
|
config_filename),
|
|
|
|
|
|
|
|
CMD_EXEC_AGGREGATOR ("run-closer-on-expired-reserve"),
|
2020-01-16 18:50:31 +01:00
|
|
|
TALER_TESTING_cmd_check_bank_transfer ("expect-deposit-1",
|
2020-01-16 21:57:40 +01:00
|
|
|
ec.exchange_url,
|
|
|
|
"EUR:4.99",
|
|
|
|
bc.exchange_payto,
|
|
|
|
bc.user42_payto),
|
2020-01-16 00:11:51 +01:00
|
|
|
TALER_TESTING_cmd_check_bank_empty ("expect-empty-transactions-2"),
|
2020-01-16 21:57:40 +01:00
|
|
|
TALER_TESTING_cmd_end ()
|
2020-01-15 17:04:58 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
TALER_TESTING_run_with_fakebank (is,
|
|
|
|
all,
|
2020-01-18 04:00:35 +01:00
|
|
|
bc.exchange_auth.wire_gateway_url);
|
2017-06-11 11:48:06 +02:00
|
|
|
}
|
|
|
|
|
2020-01-16 21:57:40 +01:00
|
|
|
|
2017-06-11 11:48:06 +02:00
|
|
|
int
|
|
|
|
main (int argc,
|
|
|
|
char *const argv[])
|
|
|
|
{
|
|
|
|
const char *plugin_name;
|
|
|
|
|
2020-01-15 17:04:58 +01:00
|
|
|
/* these might get in the way */
|
|
|
|
unsetenv ("XDG_DATA_HOME");
|
|
|
|
unsetenv ("XDG_CONFIG_HOME");
|
|
|
|
GNUNET_log_setup ("test_taler_exchange_wirewatch",
|
2020-01-16 00:11:51 +01:00
|
|
|
"DEBUG",
|
2020-01-15 17:04:58 +01:00
|
|
|
NULL);
|
|
|
|
|
2017-06-11 11:48:06 +02:00
|
|
|
if (NULL == (plugin_name = strrchr (argv[0], (int) '-')))
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
plugin_name++;
|
2020-01-18 18:22:10 +01:00
|
|
|
{
|
|
|
|
char *testname;
|
|
|
|
|
|
|
|
GNUNET_asprintf (&testname,
|
|
|
|
"test-taler-exchange-wirewatch-%s",
|
|
|
|
plugin_name);
|
|
|
|
GNUNET_asprintf (&config_filename,
|
|
|
|
"%s.conf",
|
|
|
|
testname);
|
|
|
|
GNUNET_free (testname);
|
|
|
|
}
|
2019-12-24 22:37:31 +01:00
|
|
|
/* check database is working */
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_Context *conn;
|
|
|
|
struct GNUNET_PQ_ExecuteStatement es[] = {
|
|
|
|
GNUNET_PQ_EXECUTE_STATEMENT_END
|
|
|
|
};
|
|
|
|
|
|
|
|
conn = GNUNET_PQ_connect ("postgres:///talercheck",
|
2020-01-17 03:31:39 +01:00
|
|
|
NULL,
|
2019-12-24 22:37:31 +01:00
|
|
|
es,
|
|
|
|
NULL);
|
|
|
|
if (NULL == conn)
|
|
|
|
return 77;
|
|
|
|
GNUNET_PQ_disconnect (conn);
|
|
|
|
}
|
2020-01-15 17:04:58 +01:00
|
|
|
|
|
|
|
TALER_TESTING_cleanup_files (config_filename);
|
|
|
|
if (GNUNET_OK != TALER_TESTING_prepare_exchange (config_filename,
|
2020-03-19 17:56:23 +01:00
|
|
|
GNUNET_YES,
|
2020-01-16 21:57:40 +01:00
|
|
|
&ec))
|
2017-06-11 17:04:54 +02:00
|
|
|
{
|
2020-01-15 17:04:58 +01:00
|
|
|
TALER_LOG_INFO ("Could not prepare the exchange\n");
|
2017-06-11 17:04:54 +02:00
|
|
|
return 77;
|
|
|
|
}
|
2020-01-15 17:04:58 +01:00
|
|
|
|
2017-06-11 11:48:06 +02:00
|
|
|
if (GNUNET_OK !=
|
2020-01-15 17:04:58 +01:00
|
|
|
TALER_TESTING_prepare_fakebank (config_filename,
|
2020-01-19 18:48:14 +01:00
|
|
|
"exchange-account-1",
|
2020-01-15 17:04:58 +01:00
|
|
|
&bc))
|
2017-06-11 11:48:06 +02:00
|
|
|
return 77;
|
|
|
|
|
2020-01-16 00:11:51 +01:00
|
|
|
return
|
|
|
|
(GNUNET_OK == TALER_TESTING_setup_with_exchange (&run,
|
|
|
|
NULL,
|
|
|
|
config_filename)) ? 0 : 1;
|
2020-01-15 17:04:58 +01:00
|
|
|
}
|
2019-10-31 12:59:50 +01:00
|
|
|
|
2020-01-16 21:57:40 +01:00
|
|
|
|
2017-06-11 11:48:06 +02:00
|
|
|
/* end of test_taler_exchange_wirewatch.c */
|