2018-01-23 10:28:24 +01:00
|
|
|
/*
|
|
|
|
This file is part of TALER
|
|
|
|
Copyright (C) 2018 Taler Systems SA
|
|
|
|
|
|
|
|
TALER is free software; you can redistribute it and/or modify it
|
2020-03-10 18:51:08 +01:00
|
|
|
under the terms of the GNU General Public License as pub
|
|
|
|
lished
|
2018-01-23 10:28:24 +01:00
|
|
|
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_exchange_api_keys_cherry_picking.c
|
2018-01-23 10:28:24 +01:00
|
|
|
* @brief testcase to test exchange's /keys cherry picking ability
|
|
|
|
* @author Marcello Stanisci
|
|
|
|
* @author Christian Grothoff
|
|
|
|
*/
|
|
|
|
#include "platform.h"
|
|
|
|
#include "taler_util.h"
|
|
|
|
#include "taler_signatures.h"
|
|
|
|
#include "taler_exchange_service.h"
|
|
|
|
#include "taler_json_lib.h"
|
|
|
|
#include <gnunet/gnunet_util_lib.h>
|
|
|
|
#include <microhttpd.h>
|
|
|
|
#include "taler_bank_service.h"
|
|
|
|
#include "taler_fakebank_lib.h"
|
|
|
|
#include "taler_testing_lib.h"
|
|
|
|
|
2019-04-03 16:07:04 +02:00
|
|
|
|
2018-01-23 10:28:24 +01:00
|
|
|
/**
|
|
|
|
* Configuration file we use. One (big) configuration is used
|
|
|
|
* for the various components for this test.
|
|
|
|
*/
|
|
|
|
#define CONFIG_FILE "test_exchange_api_keys_cherry_picking.conf"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to increase the number of denomination keys.
|
|
|
|
*/
|
|
|
|
#define CONFIG_FILE_EXTENDED \
|
|
|
|
"test_exchange_api_keys_cherry_picking_extended.conf"
|
|
|
|
|
2019-01-09 13:45:47 +01:00
|
|
|
/**
|
|
|
|
* Used to increase the number of denomination keys.
|
|
|
|
*/
|
|
|
|
#define CONFIG_FILE_EXTENDED_2 \
|
|
|
|
"test_exchange_api_keys_cherry_picking_extended_2.conf"
|
|
|
|
|
2019-04-11 17:42:58 +02:00
|
|
|
|
2020-03-10 18:51:08 +01:00
|
|
|
#define NDKS_RIGHT_BEFORE_SERIALIZATION 40
|
2019-04-11 17:42:58 +02:00
|
|
|
|
2019-04-03 16:07:04 +02:00
|
|
|
/**
|
2019-04-10 19:01:26 +02:00
|
|
|
* Add seconds.
|
|
|
|
*
|
|
|
|
* @param base absolute time to add seconds to.
|
|
|
|
* @param relative number of seconds to add.
|
|
|
|
* @return a new absolute time, modified according to @e relative.
|
2019-04-03 16:07:04 +02:00
|
|
|
*/
|
2019-04-10 19:01:26 +02:00
|
|
|
#define ADDSECS(base, secs) \
|
|
|
|
GNUNET_TIME_absolute_add \
|
|
|
|
(base, \
|
2019-08-25 16:18:24 +02:00
|
|
|
GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, \
|
|
|
|
secs))
|
2019-04-03 16:07:04 +02:00
|
|
|
|
|
|
|
/**
|
2019-04-10 19:01:26 +02:00
|
|
|
* Subtract seconds.
|
2019-04-03 16:07:04 +02:00
|
|
|
*
|
2019-04-10 19:01:26 +02:00
|
|
|
* @param base absolute time to subtract seconds to.
|
|
|
|
* @param secs relative number of _seconds_ to subtract.
|
2019-04-03 16:07:04 +02:00
|
|
|
* @return a new absolute time, modified according to @e relative.
|
|
|
|
*/
|
2019-04-10 19:01:26 +02:00
|
|
|
#define SUBSECS(base, secs) \
|
2019-04-11 00:10:00 +02:00
|
|
|
GNUNET_TIME_absolute_subtract \
|
2019-04-10 19:01:26 +02:00
|
|
|
(base, \
|
2019-08-25 16:18:24 +02:00
|
|
|
GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, \
|
|
|
|
secs))
|
2019-04-06 12:55:13 +02:00
|
|
|
#define JAN1971 "1971-01-01"
|
|
|
|
#define JAN2030 "2030-01-01"
|
|
|
|
|
2018-02-28 16:15:18 +01:00
|
|
|
/**
|
2020-01-13 00:27:48 +01:00
|
|
|
* Exchange configuration data.
|
2018-02-28 16:15:18 +01:00
|
|
|
*/
|
2020-01-13 00:27:48 +01:00
|
|
|
static struct TALER_TESTING_ExchangeConfiguration ec;
|
2018-11-10 19:28:28 +01:00
|
|
|
|
2019-08-01 00:24:11 +02:00
|
|
|
|
2019-04-06 12:55:13 +02:00
|
|
|
/**
|
|
|
|
* Wrapper around the time parser.
|
|
|
|
*
|
|
|
|
* @param str human-readable time string.
|
|
|
|
* @return the parsed time from @a str.
|
|
|
|
*/
|
|
|
|
static struct GNUNET_TIME_Absolute
|
|
|
|
TTH_parse_time (const char *str)
|
|
|
|
{
|
|
|
|
struct GNUNET_TIME_Absolute ret;
|
|
|
|
|
|
|
|
GNUNET_assert
|
|
|
|
(GNUNET_OK == GNUNET_STRINGS_fancy_time_to_absolute (str,
|
|
|
|
&ret));
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-01-23 10:28:24 +01:00
|
|
|
/**
|
|
|
|
* Main function that will tell the interpreter what commands to
|
|
|
|
* run.
|
|
|
|
*
|
|
|
|
* @param cls closure
|
2019-08-01 00:24:11 +02:00
|
|
|
* @param is[in,out] interpreter state
|
2018-01-23 10:28:24 +01:00
|
|
|
*/
|
|
|
|
static void
|
|
|
|
run (void *cls,
|
|
|
|
struct TALER_TESTING_Interpreter *is)
|
|
|
|
{
|
2018-12-21 22:05:42 +01:00
|
|
|
struct TALER_TESTING_Command keys_serialization[] = {
|
2019-04-06 20:17:41 +02:00
|
|
|
TALER_TESTING_cmd_serialize_keys
|
|
|
|
("serialize-keys"),
|
|
|
|
TALER_TESTING_cmd_connect_with_state
|
|
|
|
("reconnect-with-state",
|
2019-08-25 16:18:24 +02:00
|
|
|
"serialize-keys"),
|
2019-04-11 17:42:58 +02:00
|
|
|
/**
|
|
|
|
* Make sure we have the same keys situation as
|
|
|
|
* it was before the serialization.
|
|
|
|
*/
|
|
|
|
TALER_TESTING_cmd_check_keys_with_now
|
|
|
|
("check-keys-after-deserialization",
|
2019-08-25 16:18:24 +02:00
|
|
|
4,
|
|
|
|
NDKS_RIGHT_BEFORE_SERIALIZATION,
|
|
|
|
/**
|
|
|
|
* Pretend 5 seconds passed.
|
|
|
|
*/
|
|
|
|
ADDSECS (TTH_parse_time (JAN2030),
|
|
|
|
5)),
|
2019-04-11 17:42:58 +02:00
|
|
|
/**
|
|
|
|
* Use one of the deserialized keys.
|
|
|
|
*/
|
2019-04-06 20:17:41 +02:00
|
|
|
TALER_TESTING_cmd_wire
|
|
|
|
("verify-/wire-with-serialized-keys",
|
2019-08-25 16:18:24 +02:00
|
|
|
"x-taler-bank",
|
|
|
|
NULL,
|
|
|
|
MHD_HTTP_OK),
|
2019-01-21 20:07:26 +01:00
|
|
|
TALER_TESTING_cmd_end (),
|
2018-12-21 22:05:42 +01:00
|
|
|
};
|
|
|
|
|
2019-01-21 20:07:26 +01:00
|
|
|
struct TALER_TESTING_Command ordinary_cherry_pick[] = {
|
2019-02-19 15:48:52 +01:00
|
|
|
/**
|
2019-04-06 12:55:13 +02:00
|
|
|
* 1 DK with 80s withdraw duration, lookahead_sign is 60s
|
|
|
|
* => expect 1 DK.
|
2019-02-19 15:48:52 +01:00
|
|
|
*/
|
2018-01-23 10:28:24 +01:00
|
|
|
TALER_TESTING_cmd_check_keys ("check-keys-1",
|
2019-02-15 12:41:26 +01:00
|
|
|
1, /* generation */
|
2019-02-19 15:48:52 +01:00
|
|
|
1),
|
|
|
|
/**
|
2019-04-06 20:17:41 +02:00
|
|
|
* The far-future now will cause "keyup" to start a fresh
|
|
|
|
* key set. The new KS will have only one key, because the
|
|
|
|
* current lookahead_sign == 60 seconds and the key's withdraw
|
|
|
|
* duration is 80 seconds.
|
2020-03-10 17:11:12 +01:00
|
|
|
*///
|
2020-03-29 01:58:38 +01:00
|
|
|
TALER_TESTING_cmd_exec_keyup_with_now ("keyup-1",
|
|
|
|
CONFIG_FILE,
|
|
|
|
TTH_parse_time (JAN2030)),
|
2019-08-25 16:18:24 +02:00
|
|
|
/**
|
2020-03-29 01:58:38 +01:00
|
|
|
* Should return 1 new key, + the original one. NOTE: the
|
|
|
|
* original DK will never be 'cancelled' as for the current
|
|
|
|
* libtalerexchange logic, so it must always be counted.
|
|
|
|
*///
|
|
|
|
TALER_TESTING_cmd_check_keys_with_now ("check-keys-2",
|
|
|
|
2, /* generation */
|
|
|
|
2,
|
|
|
|
TTH_parse_time (JAN2030)),
|
2019-04-06 20:17:41 +02:00
|
|
|
TALER_TESTING_cmd_exec_keyup_with_now
|
|
|
|
("keyup-3",
|
2019-08-25 16:18:24 +02:00
|
|
|
CONFIG_FILE_EXTENDED_2,
|
|
|
|
/* Taking care of not using a 'now' that equals the
|
|
|
|
* last DK timestamp, otherwise it would get silently
|
|
|
|
* overridden. */
|
|
|
|
ADDSECS (TTH_parse_time (JAN2030),
|
|
|
|
10)),
|
2019-04-06 20:17:41 +02:00
|
|
|
/**
|
2019-04-10 19:01:26 +02:00
|
|
|
* Expected number of DK:
|
2019-04-06 20:17:41 +02:00
|
|
|
*
|
2020-03-10 18:51:08 +01:00
|
|
|
* 3000 (the lookahead_sign time frame, in seconds)
|
|
|
|
* - 69 (how many seconds are covered by the latest DK, 79s - 10s already past)
|
2019-04-10 19:01:26 +02:00
|
|
|
* ----
|
2020-03-10 18:51:08 +01:00
|
|
|
* 2931
|
|
|
|
* / 79 (how many seconds each DK will cover, 80-1)
|
2019-04-10 19:01:26 +02:00
|
|
|
* ----
|
2020-03-10 18:51:08 +01:00
|
|
|
* 38 (rounded up)
|
2019-04-10 19:01:26 +02:00
|
|
|
* + 2 (old DKs already stored locally: 1 from the
|
|
|
|
* very initial setup, and 1 from the 'keyup-1' CMD)
|
|
|
|
* ----
|
2020-03-10 18:51:08 +01:00
|
|
|
* 40
|
|
|
|
*///
|
|
|
|
TALER_TESTING_cmd_check_keys_with_now
|
2019-04-06 20:17:41 +02:00
|
|
|
("check-keys-3",
|
2020-03-10 18:51:08 +01:00
|
|
|
3 /* generation */,
|
2019-08-25 16:18:24 +02:00
|
|
|
NDKS_RIGHT_BEFORE_SERIALIZATION,
|
|
|
|
TTH_parse_time (JAN2030)),
|
2019-01-21 20:07:26 +01:00
|
|
|
TALER_TESTING_cmd_end ()
|
|
|
|
};
|
|
|
|
struct TALER_TESTING_Command commands[] = {
|
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_FILE),
|
|
|
|
TALER_TESTING_cmd_check_keys_pull_all_keys ("refetch /keys",
|
|
|
|
1,
|
|
|
|
1 /* FIXME: wrong number... */),
|
2019-01-21 20:07:26 +01:00
|
|
|
TALER_TESTING_cmd_batch ("ordinary-cherry-pick",
|
|
|
|
ordinary_cherry_pick),
|
2019-04-06 20:17:41 +02:00
|
|
|
TALER_TESTING_cmd_batch ("keys-serialization",
|
|
|
|
keys_serialization),
|
2018-01-23 10:28:24 +01:00
|
|
|
TALER_TESTING_cmd_end ()
|
|
|
|
};
|
|
|
|
|
2018-10-13 19:13:39 +02:00
|
|
|
TALER_TESTING_run (is,
|
2019-08-01 00:24:11 +02:00
|
|
|
commands);
|
2018-01-23 10:28:24 +01:00
|
|
|
}
|
|
|
|
|
2018-08-19 12:22:42 +02:00
|
|
|
|
2018-01-23 10:28:24 +01:00
|
|
|
int
|
|
|
|
main (int argc,
|
2019-08-25 16:18:24 +02:00
|
|
|
char *const *argv)
|
2018-01-23 10:28:24 +01:00
|
|
|
{
|
|
|
|
/* These environment variables get in the way... */
|
|
|
|
unsetenv ("XDG_DATA_HOME");
|
|
|
|
unsetenv ("XDG_CONFIG_HOME");
|
2019-08-01 00:24:11 +02:00
|
|
|
GNUNET_log_setup ("test-exchange-api-cherry-picking",
|
2019-01-21 20:07:26 +01:00
|
|
|
"DEBUG",
|
|
|
|
NULL);
|
2018-01-23 10:28:24 +01:00
|
|
|
TALER_TESTING_cleanup_files (CONFIG_FILE);
|
|
|
|
/* @helpers. Run keyup, create tables, ... Note: it
|
|
|
|
* fetches the port number from config in order to see
|
|
|
|
* if it's available. */
|
2018-02-28 16:15:18 +01:00
|
|
|
switch (TALER_TESTING_prepare_exchange (CONFIG_FILE,
|
2020-03-19 17:56:23 +01:00
|
|
|
GNUNET_YES,
|
2020-01-13 00:27:48 +01:00
|
|
|
&ec))
|
2018-01-23 10:28:24 +01:00
|
|
|
{
|
|
|
|
case GNUNET_SYSERR:
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 1;
|
|
|
|
case GNUNET_NO:
|
|
|
|
return 77;
|
|
|
|
case GNUNET_OK:
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
/* Set up event loop and reschedule context, plus
|
|
|
|
* start/stop the exchange. It calls TALER_TESTING_setup
|
|
|
|
* which creates the 'is' object.
|
|
|
|
*/
|
|
|
|
TALER_TESTING_setup_with_exchange (&run,
|
|
|
|
NULL,
|
|
|
|
CONFIG_FILE))
|
|
|
|
return 1;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
GNUNET_break (0);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-10-31 12:59:50 +01:00
|
|
|
|
2019-08-01 00:24:11 +02:00
|
|
|
/* end of test_exchange_api_keys_cherry_picking.c */
|