diff options
| author | Christian Grothoff <christian@grothoff.org> | 2022-04-23 20:02:28 +0200 | 
|---|---|---|
| committer | Christian Grothoff <christian@grothoff.org> | 2022-04-23 20:02:28 +0200 | 
| commit | b7a4fd401e0a90e309b1be66714b2a0c932f2813 (patch) | |
| tree | 55240c4ddfe1693b3bdc03d0bbd2ff47a1ba1a25 | |
| parent | a1825d38b355eb5b36d956eb470a68f071d25a6a (diff) | |
add subcommand to sign global fees in tests
| -rw-r--r-- | src/include/taler_testing_lib.h | 31 | ||||
| -rw-r--r-- | src/testing/Makefile.am | 3 | ||||
| -rw-r--r-- | src/testing/test_exchange_p2p.c | 12 | ||||
| -rw-r--r-- | src/testing/testing_api_cmd_offline_sign_global_fees.c | 252 | ||||
| -rw-r--r-- | src/testing/testing_api_cmd_offline_sign_wire_fees.c (renamed from src/testing/testing_api_cmd_offline_sign_fees.c) | 2 | 
5 files changed, 296 insertions, 4 deletions
| diff --git a/src/include/taler_testing_lib.h b/src/include/taler_testing_lib.h index 3d7ba372..a1fa8c16 100644 --- a/src/include/taler_testing_lib.h +++ b/src/include/taler_testing_lib.h @@ -2245,7 +2245,7 @@ TALER_TESTING_cmd_exec_offline_sign_keys (const char *label,  /** - * Sign a wire fee. + * Sign a wire fee structure.   *   * @param label command label.   * @param config_filename configuration filename. @@ -2263,6 +2263,35 @@ TALER_TESTING_cmd_exec_offline_sign_fees (const char *label,  /** + * Sign global fee structure. + * + * @param label command label. + * @param config_filename configuration filename. + * @param history_fee the history fee to charge (for the current year) + * @param kyc_fee the KYC fee to charge (for the current year) + * @param account_fee the account fee to charge (for the current year) + * @param purse_fee the purse fee to charge (for the current year) + * @param purse_timeout when do purses time out + * @param kyc_timeout when does the KYC time out + * @param history_expiration when does an account history expire + * @param num_purses number of (free) active purses per account + * @return the command + */ +struct TALER_TESTING_Command +TALER_TESTING_cmd_exec_offline_sign_global_fees ( +  const char *label, +  const char *config_filename, +  const char *history_fee, +  const char *kyc_fee, +  const char *account_fee, +  const char *purse_fee, +  struct GNUNET_TIME_Relative purse_timeout, +  struct GNUNET_TIME_Relative kyc_timeout, +  struct GNUNET_TIME_Relative history_expiration, +  unsigned int num_purses); + + +/**   * Revoke an exchange denomination key.   *   * @param label command label. diff --git a/src/testing/Makefile.am b/src/testing/Makefile.am index f15577be..b985dd28 100644 --- a/src/testing/Makefile.am +++ b/src/testing/Makefile.am @@ -68,7 +68,8 @@ libtalertesting_la_SOURCES = \    testing_api_cmd_kyc_proof.c \    testing_api_cmd_kyc_wallet_get.c \    testing_api_cmd_oauth.c \ -  testing_api_cmd_offline_sign_fees.c \ +  testing_api_cmd_offline_sign_global_fees.c \ +  testing_api_cmd_offline_sign_wire_fees.c \    testing_api_cmd_offline_sign_keys.c \    testing_api_cmd_offline_sign_extensions.c \    testing_api_cmd_purse_create_deposit.c \ diff --git a/src/testing/test_exchange_p2p.c b/src/testing/test_exchange_p2p.c index 930ff2be..b16b2f0a 100644 --- a/src/testing/test_exchange_p2p.c +++ b/src/testing/test_exchange_p2p.c @@ -186,11 +186,21 @@ run (void *cls,                                  false),      TALER_TESTING_cmd_exec_offline_sign_keys ("offline-sign-future-keys",                                                config_file), -    TALER_TESTING_cmd_exec_offline_sign_fees ("offline-sign-fees", +    TALER_TESTING_cmd_exec_offline_sign_fees ("offline-sign-wire-fees",                                                config_file,                                                "EUR:0.01",                                                "EUR:0.01",                                                "EUR:0.01"), +    TALER_TESTING_cmd_exec_offline_sign_global_fees ("offline-sign-global-fees", +                                                     config_file, +                                                     "EUR:0.01", +                                                     "EUR:0.01", +                                                     "EUR:0.01", +                                                     "EUR:0.01", +                                                     GNUNET_TIME_UNIT_MINUTES, +                                                     GNUNET_TIME_UNIT_MINUTES, +                                                     GNUNET_TIME_UNIT_DAYS, +                                                     1),      TALER_TESTING_cmd_check_keys_pull_all_keys ("refetch /keys",                                                  1),      TALER_TESTING_cmd_batch ("withdraw", diff --git a/src/testing/testing_api_cmd_offline_sign_global_fees.c b/src/testing/testing_api_cmd_offline_sign_global_fees.c new file mode 100644 index 00000000..7c903225 --- /dev/null +++ b/src/testing/testing_api_cmd_offline_sign_global_fees.c @@ -0,0 +1,252 @@ +/* +  This file is part of TALER +  Copyright (C) 2022 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/> +*/ + +/** + * @file testing/testing_api_cmd_offline_sign_global_fees.c + * @brief run the taler-exchange-offline command to download, sign and upload global fees + * @author Marcello Stanisci + * @author Christian Grothoff + */ +#include "platform.h" +#include "taler_json_lib.h" +#include <gnunet/gnunet_curl_lib.h> +#include "taler_signatures.h" +#include "taler_testing_lib.h" + + +/** + * State for a "offlinesign" CMD. + */ +struct OfflineSignState +{ + +  /** +   * Process for the "offlinesign" command. +   */ +  struct GNUNET_OS_Process *offlinesign_proc; + +  /** +   * Configuration file used by the command. +   */ +  const char *config_filename; + +  /** +   * The history fee to sign. +   */ +  const char *history_fee_s; + +  /** +   * The KYC fee to sign. +   */ +  const char *kyc_fee_s; + +  /** +   * The account fee to sign. +   */ +  const char *account_fee_s; + +  /** +   * The purse fee to sign. +   */ +  const char *purse_fee_s; + +  /** +   * When MUST purses time out? +   */ +  struct GNUNET_TIME_Relative purse_timeout; + +  /** +   * How long does a user have to complete the KYC? +   */ +  struct GNUNET_TIME_Relative kyc_timeout; + +  /** +   * How long do we keep the history? +   */ +  struct GNUNET_TIME_Relative history_expiration; + +  /** +   * Number of (free) purses per account. +   */ +  unsigned int num_purses; +}; + + +/** + * Run the command; calls the `taler-exchange-offline' program. + * + * @param cls closure. + * @param cmd the commaind being run. + * @param is interpreter state. + */ +static void +offlinesign_run (void *cls, +                 const struct TALER_TESTING_Command *cmd, +                 struct TALER_TESTING_Interpreter *is) +{ +  struct OfflineSignState *ks = cls; +  char num_purses[12]; +  char history_expiration[32]; +  char purse_timeout[32]; +  char kyc_timeout[32]; + +  GNUNET_snprintf (num_purses, +                   sizeof (num_purses), +                   "%u", +                   ks->num_purses); +  GNUNET_snprintf (history_expiration, +                   sizeof (history_expiration), +                   "%s", +                   GNUNET_TIME_relative2s (ks->history_expiration, +                                           false)); +  GNUNET_snprintf (purse_timeout, +                   sizeof (purse_timeout), +                   "%s", +                   GNUNET_TIME_relative2s (ks->purse_timeout, +                                           false)); +  GNUNET_snprintf (kyc_timeout, +                   sizeof (kyc_timeout), +                   "%s", +                   GNUNET_TIME_relative2s (ks->kyc_timeout, +                                           false)); +  ks->offlinesign_proc +    = GNUNET_OS_start_process ( +        GNUNET_OS_INHERIT_STD_ALL, +        NULL, NULL, NULL, +        "taler-exchange-offline", +        "taler-exchange-offline", +        "-c", ks->config_filename, +        "-L", "INFO", +        "global-fee", +        "now", +        ks->history_fee_s, +        ks->kyc_fee_s, +        ks->account_fee_s, +        ks->purse_fee_s, +        purse_timeout, +        kyc_timeout, +        history_expiration, +        num_purses, +        "upload", +        NULL); +  if (NULL == ks->offlinesign_proc) +  { +    GNUNET_break (0); +    TALER_TESTING_interpreter_fail (is); +    return; +  } +  TALER_TESTING_wait_for_sigchld (is); +} + + +/** + * Free the state of a "offlinesign" CMD, and possibly kills its + * process if it did not terminate correctly. + * + * @param cls closure. + * @param cmd the command being freed. + */ +static void +offlinesign_cleanup (void *cls, +                     const struct TALER_TESTING_Command *cmd) +{ +  struct OfflineSignState *ks = cls; + +  (void) cmd; +  if (NULL != ks->offlinesign_proc) +  { +    GNUNET_break (0 == +                  GNUNET_OS_process_kill (ks->offlinesign_proc, +                                          SIGKILL)); +    GNUNET_OS_process_wait (ks->offlinesign_proc); +    GNUNET_OS_process_destroy (ks->offlinesign_proc); +    ks->offlinesign_proc = NULL; +  } +  GNUNET_free (ks); +} + + +/** + * Offer "offlinesign" CMD internal data to other commands. + * + * @param cls closure. + * @param[out] ret result + * @param trait name of the trait. + * @param index index number of the object to offer. + * @return #GNUNET_OK on success. + */ +static enum GNUNET_GenericReturnValue +offlinesign_traits (void *cls, +                    const void **ret, +                    const char *trait, +                    unsigned int index) +{ +  struct OfflineSignState *ks = cls; +  struct TALER_TESTING_Trait traits[] = { +    TALER_TESTING_make_trait_process (&ks->offlinesign_proc), +    TALER_TESTING_trait_end () +  }; + +  return TALER_TESTING_get_trait (traits, +                                  ret, +                                  trait, +                                  index); +} + + +struct TALER_TESTING_Command +TALER_TESTING_cmd_exec_offline_sign_global_fees ( +  const char *label, +  const char *config_filename, +  const char *history_fee, +  const char *kyc_fee, +  const char *account_fee, +  const char *purse_fee, +  struct GNUNET_TIME_Relative purse_timeout, +  struct GNUNET_TIME_Relative kyc_timeout, +  struct GNUNET_TIME_Relative history_expiration, +  unsigned int num_purses) +{ +  struct OfflineSignState *ks; + +  ks = GNUNET_new (struct OfflineSignState); +  ks->config_filename = config_filename; +  ks->history_fee_s = history_fee; +  ks->kyc_fee_s = kyc_fee; +  ks->account_fee_s = account_fee; +  ks->purse_fee_s = purse_fee; +  ks->purse_timeout = purse_timeout; +  ks->kyc_timeout = kyc_timeout; +  ks->history_expiration = history_expiration; +  ks->num_purses = num_purses; +  { +    struct TALER_TESTING_Command cmd = { +      .cls = ks, +      .label = label, +      .run = &offlinesign_run, +      .cleanup = &offlinesign_cleanup, +      .traits = &offlinesign_traits +    }; + +    return cmd; +  } +} + + +/* end of testing_api_cmd_exec_offline_sign_global_fees.c */ diff --git a/src/testing/testing_api_cmd_offline_sign_fees.c b/src/testing/testing_api_cmd_offline_sign_wire_fees.c index 8cf9fffe..55746ebc 100644 --- a/src/testing/testing_api_cmd_offline_sign_fees.c +++ b/src/testing/testing_api_cmd_offline_sign_wire_fees.c @@ -18,7 +18,7 @@  */  /** - * @file testing/testing_api_cmd_offline_sign_fees.c + * @file testing/testing_api_cmd_offline_sign_wire_fees.c   * @brief run the taler-exchange-offline command to download, sign and upload wire fees   * @author Marcello Stanisci   * @author Christian Grothoff | 
