aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSree Harsha Totakura <sreeharsha@totakura.in>2015-08-17 23:07:32 +0200
committerSree Harsha Totakura <sreeharsha@totakura.in>2015-08-17 23:07:32 +0200
commit1a0eb0307a664c0dcc7bdb8bc08cf7aaba4e7f3e (patch)
treead2a2819da79db8415147814221478f5dde3dd16
parente0b587b4946339ad3ea4bc72b770837541c5d09e (diff)
mintdb postgres: parameterize denomination creation.
-rw-r--r--src/mintdb/test_mintdb.c183
1 files changed, 97 insertions, 86 deletions
diff --git a/src/mintdb/test_mintdb.c b/src/mintdb/test_mintdb.c
index d195cfc38..69147b0b7 100644
--- a/src/mintdb/test_mintdb.c
+++ b/src/mintdb/test_mintdb.c
@@ -87,24 +87,49 @@ struct DenomKeyPair
/**
- * Register a denomination in the DB.
+ * Destroy a denomination key pair. The key is not necessarily removed from the DB.
*
- * @param dkp the denomination key pair
+ * @param dkp the keypair to destroy
+ */
+static void
+destroy_denom_key_pair (struct DenomKeyPair *dkp)
+{
+ GNUNET_CRYPTO_rsa_public_key_free (dkp->pub.rsa_public_key);
+ GNUNET_CRYPTO_rsa_private_key_free (dkp->priv.rsa_private_key);
+ GNUNET_free (dkp);
+}
+
+
+/**
+ * Create a denominaiton key pair by registering the denomination in the DB.
+ *
+ * @param size the size of the denomination key
* @param session the DB session
- * @return #GNUNET_OK upon success; #GNUNET_SYSERR upon failure
+ * @return the denominaiton key pair; NULL upon error
*/
-static int
-register_denomination(struct TALER_DenominationPublicKey denom_pub,
- struct TALER_MINTDB_Session *session)
+static struct DenomKeyPair *
+create_denom_key_pair (unsigned int size,
+ struct TALER_MINTDB_Session *session,
+ const struct TALER_Amount *value,
+ const struct TALER_Amount *fee_withdraw,
+ const struct TALER_Amount *fee_deposit,
+ const struct TALER_Amount *fee_refresh)
{
+ struct DenomKeyPair *dkp;
struct TALER_MINTDB_DenominationKeyIssueInformation dki;
+ dkp = GNUNET_new (struct DenomKeyPair);
+ dkp->priv.rsa_private_key = GNUNET_CRYPTO_rsa_private_key_create (size);
+ GNUNET_assert (NULL != dkp->priv.rsa_private_key);
+ dkp->pub.rsa_public_key
+ = GNUNET_CRYPTO_rsa_private_key_get_public (dkp->priv.rsa_private_key);
+
/* Using memset() as fields like master key and signature
are not properly initialized for this test. */
memset (&dki,
0,
sizeof (struct TALER_MINTDB_DenominationKeyIssueInformation));
- dki.denom_pub = denom_pub;
+ dki.denom_pub = dkp->pub;
dki.issue.properties.start = GNUNET_TIME_absolute_hton (GNUNET_TIME_absolute_get ());
dki.issue.properties.expire_withdraw = GNUNET_TIME_absolute_hton
(GNUNET_TIME_absolute_add (GNUNET_TIME_absolute_get (),
@@ -117,61 +142,30 @@ register_denomination(struct TALER_DenominationPublicKey denom_pub,
(GNUNET_TIME_absolute_add
(GNUNET_TIME_absolute_get (),
GNUNET_TIME_relative_multiply (GNUNET_TIME_UNIT_HOURS, 3)));
- dki.issue.properties.value.value = GNUNET_htonll (1);
- dki.issue.properties.value.fraction = htonl (100);
- (void) strcpy (dki.issue.properties.value.currency, CURRENCY);
- dki.issue.properties.fee_withdraw.value = 0;
- dki.issue.properties.fee_withdraw.fraction = htonl (100);
- (void) strcpy (dki.issue.properties.fee_withdraw.currency, CURRENCY);
- dki.issue.properties.fee_deposit = dki.issue.properties.fee_withdraw;
- dki.issue.properties.fee_refresh = dki.issue.properties.fee_withdraw;
+ TALER_amount_hton (&dki.issue.properties.value, value);
+ TALER_amount_hton (&dki.issue.properties.fee_withdraw, fee_withdraw);
+ TALER_amount_hton (&dki.issue.properties.fee_deposit, fee_deposit);
+ TALER_amount_hton (&dki.issue.properties.fee_refresh, fee_refresh);
+ GNUNET_CRYPTO_rsa_public_key_hash (dkp->pub.rsa_public_key,
+ &dki.issue.properties.denom_hash);
if (GNUNET_OK !=
plugin->insert_denomination_info (plugin->cls,
session,
- &denom_pub,
+ &dki.denom_pub,
&dki.issue))
{
GNUNET_break(0);
- return GNUNET_SYSERR;
+ destroy_denom_key_pair (dkp);
+ return NULL;
}
- return GNUNET_OK;
-}
-
-
-/**
- * Create a denominaiton key pair
- *
- * @param size the size of the denomination key
- * @param session the DB session
- * @return the denominaiton key pair; NULL upon error
- */
-static struct DenomKeyPair *
-create_denom_key_pair (unsigned int size, struct TALER_MINTDB_Session *session)
-{
- struct DenomKeyPair *dkp;
-
- dkp = GNUNET_new (struct DenomKeyPair);
- dkp->priv.rsa_private_key = GNUNET_CRYPTO_rsa_private_key_create (size);
- GNUNET_assert (NULL != dkp->priv.rsa_private_key);
- dkp->pub.rsa_public_key
- = GNUNET_CRYPTO_rsa_private_key_get_public (dkp->priv.rsa_private_key);
- (void) register_denomination (dkp->pub, session);
return dkp;
}
-
-/**
- * Destroy a denomination key pair. The key is not necessarily removed from the DB.
- *
- * @param dkp the keypair to destroy
- */
-static void
-destroy_denom_key_pair (struct DenomKeyPair *dkp)
-{
- GNUNET_CRYPTO_rsa_public_key_free (dkp->pub.rsa_public_key);
- GNUNET_CRYPTO_rsa_private_key_free (dkp->priv.rsa_private_key);
- GNUNET_free (dkp);
-}
+static struct TALER_Amount value;
+static struct TALER_Amount fee_withdraw;
+static struct TALER_Amount fee_deposit;
+static struct TALER_Amount fee_refresh;
+static struct TALER_Amount amount_with_fee;
/**
@@ -184,15 +178,16 @@ destroy_denom_key_pair (struct DenomKeyPair *dkp)
static int
test_melting (struct TALER_MINTDB_Session *session)
{
-#define MELT_COINS 10
+#define MELT_OLD_COINS 10
+#define MELT_NEW_COINS 5
+
struct TALER_MINTDB_RefreshSession refresh_session;
struct TALER_MINTDB_RefreshSession ret_refresh_session;
struct GNUNET_HashCode session_hash;
struct DenomKeyPair *dkp;
+ struct DenomKeyPair *new_dkp;
/* struct TALER_CoinPublicInfo *coins; */
struct TALER_MINTDB_RefreshMelt *melts;
- struct TALER_Amount amount_with_fee;
- struct TALER_Amount melt_fee;
unsigned int cnt;
int ret;
@@ -201,7 +196,7 @@ test_melting (struct TALER_MINTDB_Session *session)
RND_BLK (&session_hash);
melts = NULL;
/* create and test a refresh session */
- refresh_session.num_oldcoins = MELT_COINS;
+ refresh_session.num_oldcoins = MELT_OLD_COINS;
refresh_session.num_newcoins = 1;
refresh_session.noreveal_index = 1;
FAILIF (GNUNET_OK != plugin->create_refresh_session (plugin->cls,
@@ -217,16 +212,14 @@ test_melting (struct TALER_MINTDB_Session *session)
sizeof (refresh_session)));
/* create a denomination (value: 1; fraction: 100) */
- dkp = create_denom_key_pair(512, session);
- /* create MELT_COINS number of refresh melts */
- melts = GNUNET_new_array (MELT_COINS, struct TALER_MINTDB_RefreshMelt);
- GNUNET_assert (GNUNET_OK ==
- TALER_string_to_amount (CURRENCY ":1.000010",
- &amount_with_fee));
- GNUNET_assert (GNUNET_OK ==
- TALER_string_to_amount (CURRENCY ":0.000010",
- &melt_fee));
- for (cnt=0; cnt < MELT_COINS; cnt++)
+ dkp = create_denom_key_pair(512, session,
+ &value,
+ &fee_withdraw,
+ &fee_deposit,
+ &fee_refresh);
+ /* create MELT_OLD_COINS number of refresh melts */
+ melts = GNUNET_new_array (MELT_OLD_COINS, struct TALER_MINTDB_RefreshMelt);
+ for (cnt=0; cnt < MELT_OLD_COINS; cnt++)
{
RND_BLK (&melts[cnt].coin.coin_pub);
melts[cnt].coin.denom_sig.rsa_signature =
@@ -237,13 +230,13 @@ test_melting (struct TALER_MINTDB_Session *session)
RND_BLK (&melts[cnt].coin_sig);
melts[cnt].session_hash = session_hash;
melts[cnt].amount_with_fee = amount_with_fee;
- melts[cnt].melt_fee = melt_fee;
+ melts[cnt].melt_fee = fee_refresh;
FAILIF (GNUNET_OK != plugin->insert_refresh_melt (plugin->cls,
session,
cnt,
&melts[cnt]));
}
- for (cnt = 0; cnt < MELT_COINS; cnt++)
+ for (cnt = 0; cnt < MELT_OLD_COINS; cnt++)
{
struct TALER_MINTDB_RefreshMelt ret_melt;
FAILIF (GNUNET_OK != plugin->get_refresh_melt (plugin->cls,
@@ -279,7 +272,7 @@ test_melting (struct TALER_MINTDB_Session *session)
destroy_denom_key_pair (dkp);
if (NULL != melts)
{
- for (cnt = 0; cnt < MELT_COINS; cnt++)
+ for (cnt = 0; cnt < MELT_OLD_COINS; cnt++)
GNUNET_CRYPTO_rsa_signature_free (melts[cnt].coin.denom_sig.rsa_signature);
GNUNET_free (melts);
}
@@ -353,40 +346,57 @@ run (void *cls,
}
RND_BLK (&reserve_pub);
GNUNET_assert (GNUNET_OK ==
- TALER_string_to_amount (CURRENCY ":1.000001",
- &amount));
+ TALER_string_to_amount (CURRENCY ":1.000010",
+ &value));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_string_to_amount (CURRENCY ":0.000010",
+ &fee_withdraw));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_string_to_amount (CURRENCY ":0.000010",
+ &fee_deposit));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_string_to_amount (CURRENCY ":0.000010",
+ &fee_refresh));
+ GNUNET_assert (GNUNET_OK ==
+ TALER_string_to_amount (CURRENCY ":1.000010",
+ &amount_with_fee));
+
result = 4;
just = json_loads ("{ \"justification\":\"1\" }", 0, NULL);
FAILIF (GNUNET_OK !=
plugin->reserves_in_insert (plugin->cls,
session,
&reserve_pub,
- &amount,
+ &value,
GNUNET_TIME_absolute_get (),
just));
json_decref (just);
FAILIF (GNUNET_OK !=
check_reserve (session,
&reserve_pub,
- amount.value,
- amount.fraction,
- amount.currency));
+ value.value,
+ value.fraction,
+ value.currency));
just = json_loads ("{ \"justification\":\"2\" }", 0, NULL);
FAILIF (GNUNET_OK !=
plugin->reserves_in_insert (plugin->cls,
session,
&reserve_pub,
- &amount,
+ &value,
GNUNET_TIME_absolute_get (),
just));
json_decref (just);
FAILIF (GNUNET_OK !=
check_reserve (session,
&reserve_pub,
- ++amount.value,
- ++amount.fraction,
- amount.currency));
- dkp = create_denom_key_pair (1024, session);
+ value.value * 2,
+ value.fraction * 2,
+ value.currency));
+ dkp = create_denom_key_pair (1024, session,
+ &value,
+ &fee_withdraw,
+ &fee_deposit,
+ &fee_refresh);
RND_BLK(&cbc.h_coin_envelope);
RND_BLK(&cbc.reserve_sig);
cbc.denom_pub = dkp->pub;
@@ -399,7 +409,7 @@ run (void *cls,
sizeof (reserve_pub));
amount.value--;
amount.fraction--;
- cbc.amount_with_fee = amount;
+ cbc.amount_with_fee = value;
GNUNET_assert (GNUNET_OK ==
TALER_amount_get_zero (CURRENCY, &cbc.withdraw_fee));
FAILIF (GNUNET_OK !=
@@ -409,9 +419,9 @@ run (void *cls,
FAILIF (GNUNET_OK !=
check_reserve (session,
&reserve_pub,
- amount.value,
- amount.fraction,
- amount.currency));
+ value.value,
+ value.fraction,
+ value.currency));
FAILIF (GNUNET_YES !=
plugin->get_withdraw_info (plugin->cls,
session,
@@ -442,8 +452,9 @@ run (void *cls,
FAILIF (0 != memcmp (&bt->reserve_pub,
&reserve_pub,
sizeof (reserve_pub)));
+ /* this is the amount we trasferred twice*/
FAILIF (1 != bt->amount.value);
- FAILIF (1 != bt->amount.fraction);
+ FAILIF (10 != bt->amount.fraction);
FAILIF (0 != strcmp (CURRENCY, bt->amount.currency));
FAILIF (NULL == bt->wire);
break;
@@ -472,7 +483,7 @@ run (void *cls,
deposit.wire = wire;
deposit.transaction_id =
GNUNET_CRYPTO_random_u64 (GNUNET_CRYPTO_QUALITY_WEAK, UINT64_MAX);
- deposit.amount_with_fee = amount;
+ deposit.amount_with_fee = value;
GNUNET_assert (GNUNET_OK ==
TALER_amount_get_zero (CURRENCY, &deposit.deposit_fee));
FAILIF (GNUNET_OK !=