diff options
| author | Christian Grothoff <christian@grothoff.org> | 2016-03-01 15:35:04 +0100 | 
|---|---|---|
| committer | Christian Grothoff <christian@grothoff.org> | 2016-03-01 15:35:04 +0100 | 
| commit | b5cba3251053c22bf1df46282f1dd0a4c46f6a38 (patch) | |
| tree | b7495c3e47c40c57ff81045a4e43aa07a3b6c7b1 /src/exchangedb/test_exchangedb_keyio.c | |
| parent | e406833eab7ca0835f9779abebada94592a85a7e (diff) | |
renaming mint->exchange
Diffstat (limited to 'src/exchangedb/test_exchangedb_keyio.c')
| -rw-r--r-- | src/exchangedb/test_exchangedb_keyio.c | 85 | 
1 files changed, 85 insertions, 0 deletions
| diff --git a/src/exchangedb/test_exchangedb_keyio.c b/src/exchangedb/test_exchangedb_keyio.c new file mode 100644 index 00000000..2485da8a --- /dev/null +++ b/src/exchangedb/test_exchangedb_keyio.c @@ -0,0 +1,85 @@ +/* +  This file is part of TALER +  Copyright (C) 2014 GNUnet e. V. (and other contributing authors) + +  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, If not, see <http://www.gnu.org/licenses/> +*/ +/** + * @file exchange/test_exchange_common.c + * @brief test cases for some functions in exchange/exchange_common.c + * @author Sree Harsha Totakura <sreeharsha@totakura.in> + */ +#include "platform.h" +#include "gnunet/gnunet_util_lib.h" +#include "taler_signatures.h" +#include "taler_exchangedb_lib.h" + +#define RSA_KEY_SIZE 1024 + + +#define EXITIF(cond)                                              \ +  do {                                                            \ +    if (cond) { GNUNET_break (0); goto EXITIF_exit; }             \ +  } while (0) + + +int +main (int argc, +      const char *const argv[]) +{ +  struct TALER_EXCHANGEDB_DenominationKeyIssueInformation dki; +  char *enc; +  size_t enc_size; +  struct TALER_EXCHANGEDB_DenominationKeyIssueInformation dki_read; +  char *enc_read; +  size_t enc_read_size; +  char *tmpfile; +  int ret; + +  ret = 1; +  enc = NULL; +  enc_read = NULL; +  tmpfile = NULL; +  dki.denom_priv.rsa_private_key = NULL; +  dki_read.denom_priv.rsa_private_key = NULL; +  GNUNET_CRYPTO_random_block (GNUNET_CRYPTO_QUALITY_WEAK, +                              &dki.issue.signature, +                              sizeof (struct TALER_MasterSignatureP)); +  dki.denom_priv.rsa_private_key +    = GNUNET_CRYPTO_rsa_private_key_create (RSA_KEY_SIZE); +  enc_size = GNUNET_CRYPTO_rsa_private_key_encode (dki.denom_priv.rsa_private_key, +                                                   &enc); +  EXITIF (NULL == (tmpfile = GNUNET_DISK_mktemp ("test_exchange_common"))); +  EXITIF (GNUNET_OK != TALER_EXCHANGEDB_denomination_key_write (tmpfile, &dki)); +  EXITIF (GNUNET_OK != TALER_EXCHANGEDB_denomination_key_read (tmpfile, &dki_read)); +  enc_read_size = GNUNET_CRYPTO_rsa_private_key_encode (dki_read.denom_priv.rsa_private_key, +                                                        &enc_read); +  EXITIF (enc_size != enc_read_size); +  EXITIF (0 != memcmp (enc, +                       enc_read, +                       enc_size)); +  ret = 0; + +  EXITIF_exit: +  GNUNET_free_non_null (enc); +  if (NULL != tmpfile) +  { +    (void) unlink (tmpfile); +    GNUNET_free (tmpfile); +  } +  GNUNET_free_non_null (enc_read); +  if (NULL != dki.denom_priv.rsa_private_key) +    GNUNET_CRYPTO_rsa_private_key_free (dki.denom_priv.rsa_private_key); +  if (NULL != dki_read.denom_priv.rsa_private_key) +    GNUNET_CRYPTO_rsa_private_key_free (dki_read.denom_priv.rsa_private_key); +  return ret; +} | 
