2018-02-22 14:51:12 +01:00
|
|
|
/*
|
|
|
|
This file is part of TALER
|
2020-01-11 15:19:56 +01:00
|
|
|
Copyright (C) 2016-2020 Taler Systems SA
|
2018-02-22 14:51:12 +01:00
|
|
|
|
|
|
|
TALER is free software; you can redistribute it and/or modify
|
2019-09-11 00:32:07 +02:00
|
|
|
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.
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2019-09-11 00:32:07 +02:00
|
|
|
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.
|
2018-02-22 14:51:12 +01:00
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public
|
|
|
|
License along with TALER; see the file COPYING. If not,
|
2019-06-08 21:41:12 +02:00
|
|
|
see <http://www.gnu.org/licenses/>
|
2018-02-22 14:51:12 +01:00
|
|
|
*/
|
|
|
|
/**
|
2020-01-19 15:23:19 +01:00
|
|
|
* @file testing/test_bank_api.c
|
2018-02-22 14:51:12 +01:00
|
|
|
* @brief testcase to test bank's HTTP API
|
2019-09-11 00:32:07 +02:00
|
|
|
* interface against the fakebank
|
2018-02-22 14:51:12 +01:00
|
|
|
* @author Marcello Stanisci
|
2019-09-11 00:32:07 +02:00
|
|
|
* @author Christian Grothoff
|
2018-02-22 14:51:12 +01:00
|
|
|
*/
|
|
|
|
#include "platform.h"
|
|
|
|
#include "taler_util.h"
|
|
|
|
#include "taler_signatures.h"
|
|
|
|
#include "taler_bank_service.h"
|
2019-09-11 00:32:07 +02:00
|
|
|
#include "taler_exchange_service.h"
|
2018-02-22 14:51:12 +01:00
|
|
|
#include <gnunet/gnunet_util_lib.h>
|
|
|
|
#include <gnunet/gnunet_curl_lib.h>
|
|
|
|
#include <microhttpd.h>
|
|
|
|
#include "taler_testing_lib.h"
|
2019-09-11 00:32:07 +02:00
|
|
|
|
2020-01-17 12:15:57 +01:00
|
|
|
#define CONFIG_FILE_FAKEBANK "test_bank_api_fakebank.conf"
|
|
|
|
#define CONFIG_FILE_PYBANK "test_bank_api_pybank.conf"
|
2020-04-17 00:32:18 +02:00
|
|
|
#define CONFIG_FILE_NEXUS "test_bank_api_nexus.conf"
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2019-04-09 18:12:11 +02:00
|
|
|
/**
|
2020-01-13 00:27:48 +01:00
|
|
|
* Bank configuration data.
|
2020-01-11 23:06:10 +01:00
|
|
|
*/
|
2020-01-13 00:27:48 +01:00
|
|
|
static struct TALER_TESTING_BankConfiguration bc;
|
2020-01-11 23:06:10 +01:00
|
|
|
|
2018-02-22 14:51:12 +01:00
|
|
|
/**
|
2019-09-11 00:32:07 +02:00
|
|
|
* Handle to the Py-bank daemon.
|
2018-02-22 14:51:12 +01:00
|
|
|
*/
|
2019-09-11 00:32:07 +02:00
|
|
|
static struct GNUNET_OS_Process *bankd;
|
2018-02-22 14:51:12 +01:00
|
|
|
|
|
|
|
/**
|
2019-09-11 00:32:07 +02:00
|
|
|
* Flag indicating whether the test is running against the
|
|
|
|
* Fakebank. Set up at runtime.
|
2018-02-22 14:51:12 +01:00
|
|
|
*/
|
2020-01-12 17:43:20 +01:00
|
|
|
static int with_fakebank;
|
2019-06-08 21:41:12 +02:00
|
|
|
|
2020-06-02 11:36:51 +02:00
|
|
|
/**
|
|
|
|
* Handles to the libeufin services.
|
|
|
|
*/
|
|
|
|
static struct TALER_TESTING_LibeufinServices libeufin_services;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Needed to shutdown differently.
|
|
|
|
*/
|
|
|
|
static int with_libeufin;
|
2020-02-04 21:59:43 +01:00
|
|
|
|
2018-02-22 14:51:12 +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)
|
|
|
|
{
|
2020-01-12 17:43:20 +01:00
|
|
|
struct TALER_WireTransferIdentifierRawP wtid;
|
2020-01-15 22:09:39 +01:00
|
|
|
|
2020-01-13 23:51:01 +01:00
|
|
|
memset (&wtid, 42, sizeof (wtid));
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2020-01-15 22:09:39 +01:00
|
|
|
{
|
|
|
|
struct TALER_TESTING_Command commands[] = {
|
|
|
|
TALER_TESTING_cmd_bank_credits ("history-0",
|
|
|
|
&bc.exchange_auth,
|
|
|
|
NULL,
|
|
|
|
1),
|
2020-01-16 15:06:09 +01:00
|
|
|
TALER_TESTING_cmd_admin_add_incoming ("credit-1",
|
2020-01-15 22:09:39 +01:00
|
|
|
"KUDOS:5.01",
|
|
|
|
&bc.exchange_auth,
|
|
|
|
bc.user42_payto),
|
2020-06-08 20:29:46 +02:00
|
|
|
TALER_TESTING_cmd_sleep ("Waiting 4s for 'credit-1' to settle",
|
2020-07-16 00:42:42 +02:00
|
|
|
4),
|
2020-01-15 22:09:39 +01:00
|
|
|
TALER_TESTING_cmd_bank_credits ("history-1c",
|
|
|
|
&bc.exchange_auth,
|
|
|
|
NULL,
|
|
|
|
5),
|
|
|
|
TALER_TESTING_cmd_bank_debits ("history-1d",
|
|
|
|
&bc.exchange_auth,
|
|
|
|
NULL,
|
|
|
|
5),
|
2020-01-16 15:06:09 +01:00
|
|
|
TALER_TESTING_cmd_admin_add_incoming ("credit-2",
|
2020-01-15 22:09:39 +01:00
|
|
|
"KUDOS:3.21",
|
|
|
|
&bc.exchange_auth,
|
|
|
|
bc.user42_payto),
|
2020-01-16 15:06:09 +01:00
|
|
|
TALER_TESTING_cmd_transfer ("debit-1",
|
2020-01-15 22:09:39 +01:00
|
|
|
"KUDOS:3.22",
|
|
|
|
&bc.exchange_auth,
|
2020-01-17 15:03:19 +01:00
|
|
|
bc.exchange_payto,
|
2020-01-15 22:09:39 +01:00
|
|
|
bc.user42_payto,
|
|
|
|
&wtid,
|
|
|
|
"http://exchange.example.com/"),
|
2020-06-08 20:29:46 +02:00
|
|
|
|
|
|
|
TALER_TESTING_cmd_sleep ("Waiting 5s for 'debit-1' to settle",
|
2020-07-16 00:42:42 +02:00
|
|
|
5),
|
2020-01-15 22:09:39 +01:00
|
|
|
TALER_TESTING_cmd_bank_debits ("history-2b",
|
|
|
|
&bc.exchange_auth,
|
|
|
|
NULL,
|
|
|
|
5),
|
|
|
|
TALER_TESTING_cmd_end ()
|
|
|
|
};
|
|
|
|
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"Bank serves at `%s'\n",
|
2020-01-18 04:00:35 +01:00
|
|
|
bc.exchange_auth.wire_gateway_url);
|
2020-01-15 22:09:39 +01:00
|
|
|
if (GNUNET_YES == with_fakebank)
|
|
|
|
TALER_TESTING_run_with_fakebank (is,
|
|
|
|
commands,
|
2020-01-18 04:00:35 +01:00
|
|
|
bc.exchange_auth.wire_gateway_url);
|
2020-01-15 22:09:39 +01:00
|
|
|
else
|
|
|
|
TALER_TESTING_run (is,
|
|
|
|
commands);
|
|
|
|
}
|
2018-02-22 14:51:12 +01:00
|
|
|
}
|
|
|
|
|
2019-10-31 12:59:50 +01:00
|
|
|
|
2020-02-04 21:59:43 +01:00
|
|
|
/**
|
|
|
|
* Runs #TALER_TESTING_setup() using the configuration.
|
|
|
|
*
|
|
|
|
* @param cls unused
|
|
|
|
* @param cfg configuration to use
|
|
|
|
* @return status code
|
|
|
|
*/
|
|
|
|
static int
|
|
|
|
setup_with_cfg (void *cls,
|
|
|
|
const struct GNUNET_CONFIGURATION_Handle *cfg)
|
|
|
|
{
|
|
|
|
(void) cls;
|
|
|
|
return TALER_TESTING_setup (&run,
|
|
|
|
NULL,
|
|
|
|
cfg,
|
|
|
|
NULL,
|
|
|
|
GNUNET_NO);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-02-22 14:51:12 +01:00
|
|
|
int
|
2019-08-25 16:18:24 +02:00
|
|
|
main (int argc,
|
|
|
|
char *const *argv)
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
2020-02-04 21:59:43 +01:00
|
|
|
int rv;
|
2020-04-17 00:32:18 +02:00
|
|
|
const char *cfgfile;
|
2019-12-14 23:14:59 +01:00
|
|
|
|
2018-02-22 14:51:12 +01:00
|
|
|
/* These environment variables get in the way... */
|
|
|
|
unsetenv ("XDG_DATA_HOME");
|
|
|
|
unsetenv ("XDG_CONFIG_HOME");
|
2019-12-23 11:47:16 +01:00
|
|
|
GNUNET_log_setup ("test-bank-api",
|
2019-09-11 00:32:07 +02:00
|
|
|
"DEBUG",
|
|
|
|
NULL);
|
2020-04-17 13:45:03 +02:00
|
|
|
|
|
|
|
with_fakebank = TALER_TESTING_has_in_name (argv[0],
|
|
|
|
"_with_fakebank");
|
|
|
|
if (GNUNET_YES == with_fakebank)
|
2019-09-11 00:32:07 +02:00
|
|
|
{
|
|
|
|
TALER_LOG_DEBUG ("Running against the Fakebank.\n");
|
2020-04-17 00:32:18 +02:00
|
|
|
cfgfile = CONFIG_FILE_FAKEBANK;
|
2020-01-13 00:27:48 +01:00
|
|
|
if (GNUNET_OK !=
|
2020-01-17 12:15:57 +01:00
|
|
|
TALER_TESTING_prepare_fakebank (CONFIG_FILE_FAKEBANK,
|
2020-01-19 18:48:14 +01:00
|
|
|
"exchange-account-2",
|
2020-01-13 00:27:48 +01:00
|
|
|
&bc))
|
2019-09-11 00:32:07 +02:00
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 77;
|
|
|
|
}
|
|
|
|
}
|
2020-04-17 00:32:18 +02:00
|
|
|
else if (GNUNET_YES == TALER_TESTING_has_in_name (argv[0],
|
|
|
|
"_with_pybank"))
|
2019-09-11 00:32:07 +02:00
|
|
|
{
|
|
|
|
TALER_LOG_DEBUG ("Running against the Pybank.\n");
|
2020-07-24 15:18:17 +02:00
|
|
|
// FIXME: is the line below correct?
|
2020-04-17 00:32:18 +02:00
|
|
|
cfgfile = CONFIG_FILE_FAKEBANK;
|
2020-01-13 00:27:48 +01:00
|
|
|
if (GNUNET_OK !=
|
2020-01-17 12:15:57 +01:00
|
|
|
TALER_TESTING_prepare_bank (CONFIG_FILE_PYBANK,
|
2020-03-19 21:44:54 +01:00
|
|
|
GNUNET_YES,
|
2020-01-19 18:48:14 +01:00
|
|
|
"exchange-account-2",
|
2020-01-13 00:27:48 +01:00
|
|
|
&bc))
|
2019-09-11 00:32:07 +02:00
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 77;
|
|
|
|
}
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2020-01-17 12:15:57 +01:00
|
|
|
if (NULL == (bankd = TALER_TESTING_run_bank (CONFIG_FILE_PYBANK,
|
2020-01-18 04:00:35 +01:00
|
|
|
bc.exchange_auth.
|
|
|
|
wire_gateway_url)))
|
2019-09-11 00:32:07 +02:00
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 77;
|
|
|
|
}
|
2020-07-16 00:42:42 +02:00
|
|
|
}
|
|
|
|
else if (GNUNET_YES == TALER_TESTING_has_in_name (argv[0],
|
|
|
|
"_with_nexus"))
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
2020-06-01 16:03:03 +02:00
|
|
|
TALER_LOG_DEBUG ("Running with Nexus.\n");
|
2020-06-02 11:36:51 +02:00
|
|
|
with_libeufin = GNUNET_YES;
|
|
|
|
cfgfile = CONFIG_FILE_NEXUS;
|
2020-04-17 00:32:18 +02:00
|
|
|
if (GNUNET_OK != TALER_TESTING_prepare_nexus (CONFIG_FILE_NEXUS,
|
|
|
|
GNUNET_YES,
|
|
|
|
"exchange-account-2",
|
|
|
|
&bc))
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 77;
|
|
|
|
}
|
2020-06-02 11:36:51 +02:00
|
|
|
libeufin_services = TALER_TESTING_run_libeufin (&bc);
|
2020-07-16 00:42:42 +02:00
|
|
|
if ( (NULL == libeufin_services.nexus) || (NULL ==
|
|
|
|
libeufin_services.sandbox) )
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 77;
|
|
|
|
}
|
2019-09-11 00:32:07 +02:00
|
|
|
}
|
2020-04-17 00:32:18 +02:00
|
|
|
else
|
|
|
|
{
|
2020-06-01 16:03:03 +02:00
|
|
|
/* no bank service was ever invoked. */
|
2020-04-17 00:32:18 +02:00
|
|
|
GNUNET_break (0);
|
|
|
|
return 77;
|
|
|
|
}
|
|
|
|
|
2020-02-04 21:59:43 +01:00
|
|
|
if (GNUNET_OK !=
|
2020-04-17 00:32:18 +02:00
|
|
|
GNUNET_CONFIGURATION_parse_and_run (cfgfile,
|
2020-02-04 21:59:43 +01:00
|
|
|
&setup_with_cfg,
|
|
|
|
NULL))
|
|
|
|
rv = 1;
|
|
|
|
else
|
|
|
|
rv = 0;
|
2020-06-02 11:36:51 +02:00
|
|
|
|
2020-01-12 17:43:20 +01:00
|
|
|
if (GNUNET_NO == with_fakebank)
|
2019-09-11 00:32:07 +02:00
|
|
|
{
|
2020-06-02 11:36:51 +02:00
|
|
|
// -> pybank
|
2020-07-16 00:42:42 +02:00
|
|
|
if (GNUNET_NO == with_libeufin)
|
2020-06-02 11:36:51 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
GNUNET_OS_process_kill (bankd,
|
|
|
|
SIGKILL);
|
|
|
|
GNUNET_OS_process_wait (bankd);
|
|
|
|
GNUNET_OS_process_destroy (bankd);
|
|
|
|
}
|
|
|
|
else // -> libeufin
|
|
|
|
{
|
|
|
|
GNUNET_OS_process_kill (libeufin_services.nexus,
|
|
|
|
SIGKILL);
|
|
|
|
GNUNET_OS_process_wait (libeufin_services.nexus);
|
2020-07-16 00:42:42 +02:00
|
|
|
GNUNET_OS_process_destroy (libeufin_services.nexus);
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2020-06-02 11:36:51 +02:00
|
|
|
GNUNET_OS_process_kill (libeufin_services.sandbox,
|
|
|
|
SIGKILL);
|
|
|
|
GNUNET_OS_process_wait (libeufin_services.sandbox);
|
2020-07-16 00:42:42 +02:00
|
|
|
GNUNET_OS_process_destroy (libeufin_services.sandbox);
|
|
|
|
}
|
2019-09-11 00:32:07 +02:00
|
|
|
}
|
2020-06-02 11:36:51 +02:00
|
|
|
|
2019-09-11 00:32:07 +02:00
|
|
|
return rv;
|
2018-02-22 14:51:12 +01:00
|
|
|
}
|
|
|
|
|
2019-09-11 00:32:07 +02:00
|
|
|
|
2019-12-14 23:19:22 +01:00
|
|
|
/* end of test_bank_api.c */
|