exchange/src/lib/test_exchange_api_keys_cherry_picking.c

273 lines
7.5 KiB
C
Raw Normal View History

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
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/>
*/
/**
2019-06-08 21:41:12 +02:00
* @file exchange-lib/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"
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"
/**
* 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
#define NDKS_RIGHT_BEFORE_SERIALIZATION 46
/**
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-10 19:01:26 +02:00
#define ADDSECS(base, secs) \
GNUNET_TIME_absolute_add \
(base, \
GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, \
secs))
/**
2019-04-10 19:01:26 +02:00
* Subtract seconds.
*
2019-04-10 19:01:26 +02:00
* @param base absolute time to subtract seconds to.
* @param secs relative number of _seconds_ to subtract.
* @return a new absolute time, modified according to @e relative.
*/
2019-04-10 19:01:26 +02:00
#define SUBSECS(base, secs) \
GNUNET_TIME_absolute_subtract \
2019-04-10 19:01:26 +02:00
(base, \
GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_SECONDS, \
secs))
#define JAN1971 "1971-01-01"
#define JAN2030 "2030-01-01"
/**
* Exchange base URL; mainly purpose is to make the compiler happy.
*/
2018-02-28 16:25:00 +01:00
static char *exchange_url;
2018-01-23 10:28:24 +01:00
/**
* Auditor base URL; mainly purpose is to make the compiler happy.
*/
static char *auditor_url;
2019-08-01 00:24:11 +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[] = {
TALER_TESTING_cmd_serialize_keys
("serialize-keys"),
TALER_TESTING_cmd_connect_with_state
("reconnect-with-state",
"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",
4,
NDKS_RIGHT_BEFORE_SERIALIZATION,
/**
* Pretend 5 seconds passed.
*/
ADDSECS (TTH_parse_time (JAN2030),
5)),
/**
* Use one of the deserialized keys.
*/
TALER_TESTING_cmd_wire
("verify-/wire-with-serialized-keys",
"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[] = {
/**
* 1 DK with 80s withdraw duration, lookahead_sign is 60s
* => expect 1 DK.
*/
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 */
1),
/**
* 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.
*/
TALER_TESTING_cmd_exec_keyup_with_now
("keyup-1",
CONFIG_FILE,
TTH_parse_time (JAN2030)),
/**
* 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)),
TALER_TESTING_cmd_exec_keyup_with_now
("keyup-3",
CONFIG_FILE_EXTENDED_2,
2019-04-10 19:01:26 +02:00
/* 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-10 19:01:26 +02:00
* Expected number of DK:
*
2019-08-01 00:24:11 +02:00
* 3500 (the lookahead_sign time frame, in seconds)
2019-04-10 19:01:26 +02:00
* - 69 (how many seconds are covered by the latest DK)
* ----
* 3431
* / 79 (how many seconds each DK will cover)
* ----
* 44 (rounded up)
* + 2 (old DKs already stored locally: 1 from the
* very initial setup, and 1 from the 'keyup-1' CMD)
* ----
* 46
*/
2019-04-11 17:42:58 +02:00
TALER_TESTING_cmd_check_keys_with_now
("check-keys-3",
2019-06-08 21:41:12 +02:00
3,
2019-04-11 17:42:58 +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[] = {
2019-01-21 20:07:26 +01:00
TALER_TESTING_cmd_batch ("ordinary-cherry-pick",
ordinary_cherry_pick),
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-01-23 10:28:24 +01:00
int
main (int argc,
char * const *argv)
{
/* 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. */
switch (TALER_TESTING_prepare_exchange (CONFIG_FILE,
&auditor_url,
2019-08-01 00:24:11 +02:00
&exchange_url))
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-08-01 00:24:11 +02:00
/* end of test_exchange_api_keys_cherry_picking.c */