test logic for actually testing /refresh operations, keeping disabled for now as the test is known to fail (to be investigated)
This commit is contained in:
parent
f0d073410e
commit
e982139186
@ -19,6 +19,17 @@ lookahead_provide = 4 weeks 1 day
|
|||||||
# name begins with "coin_". The rest of the
|
# name begins with "coin_". The rest of the
|
||||||
# name is free, but of course following the convention
|
# name is free, but of course following the convention
|
||||||
# of "coin_$CURRENCY[_$SUBUNIT]_$VALUE" make sense.
|
# of "coin_$CURRENCY[_$SUBUNIT]_$VALUE" make sense.
|
||||||
|
[coin_eur_ct_1]
|
||||||
|
value = EUR:0.01
|
||||||
|
duration_overlap = 5 minutes
|
||||||
|
duration_withdraw = 7 days
|
||||||
|
duration_spend = 2 years
|
||||||
|
duration_legal = 3 years
|
||||||
|
fee_withdraw = EUR:0.00
|
||||||
|
fee_deposit = EUR:0.00
|
||||||
|
fee_refresh = EUR:0.01
|
||||||
|
rsa_keysize = 1024
|
||||||
|
|
||||||
[coin_eur_ct_10]
|
[coin_eur_ct_10]
|
||||||
value = EUR:0.10
|
value = EUR:0.10
|
||||||
duration_overlap = 5 minutes
|
duration_overlap = 5 minutes
|
||||||
@ -27,7 +38,18 @@ duration_spend = 2 years
|
|||||||
duration_legal = 3 years
|
duration_legal = 3 years
|
||||||
fee_withdraw = EUR:0.01
|
fee_withdraw = EUR:0.01
|
||||||
fee_deposit = EUR:0.01
|
fee_deposit = EUR:0.01
|
||||||
fee_refresh = EUR:0.01
|
fee_refresh = EUR:0.03
|
||||||
|
rsa_keysize = 1024
|
||||||
|
|
||||||
|
[coin_eur_1]
|
||||||
|
value = EUR:1
|
||||||
|
duration_overlap = 5 minutes
|
||||||
|
duration_withdraw = 7 days
|
||||||
|
duration_spend = 2 years
|
||||||
|
duration_legal = 3 years
|
||||||
|
fee_withdraw = EUR:0.01
|
||||||
|
fee_deposit = EUR:0.01
|
||||||
|
fee_refresh = EUR:0.03
|
||||||
rsa_keysize = 1024
|
rsa_keysize = 1024
|
||||||
|
|
||||||
[coin_eur_5]
|
[coin_eur_5]
|
||||||
@ -38,7 +60,7 @@ duration_spend = 2 years
|
|||||||
duration_legal = 3 years
|
duration_legal = 3 years
|
||||||
fee_withdraw = EUR:0.01
|
fee_withdraw = EUR:0.01
|
||||||
fee_deposit = EUR:0.01
|
fee_deposit = EUR:0.01
|
||||||
fee_refresh = EUR:0.01
|
fee_refresh = EUR:0.03
|
||||||
rsa_keysize = 1024
|
rsa_keysize = 1024
|
||||||
|
|
||||||
[coin_eur_10]
|
[coin_eur_10]
|
||||||
@ -49,7 +71,7 @@ duration_spend = 2 years
|
|||||||
duration_legal = 3 years
|
duration_legal = 3 years
|
||||||
fee_withdraw = EUR:0.01
|
fee_withdraw = EUR:0.01
|
||||||
fee_deposit = EUR:0.01
|
fee_deposit = EUR:0.01
|
||||||
fee_refresh = EUR:0.01
|
fee_refresh = EUR:0.03
|
||||||
rsa_keysize = 1024
|
rsa_keysize = 1024
|
||||||
|
|
||||||
[coin_eur_1000]
|
[coin_eur_1000]
|
||||||
@ -60,5 +82,5 @@ duration_spend = 2 years
|
|||||||
duration_legal = 3 years
|
duration_legal = 3 years
|
||||||
fee_withdraw = EUR:0.01
|
fee_withdraw = EUR:0.01
|
||||||
fee_deposit = EUR:0.01
|
fee_deposit = EUR:0.01
|
||||||
fee_refresh = EUR:0.01
|
fee_refresh = EUR:0.03
|
||||||
rsa_keysize = 2048
|
rsa_keysize = 2048
|
||||||
|
@ -18,9 +18,6 @@
|
|||||||
* @brief testcase to test mint's HTTP API interface
|
* @brief testcase to test mint's HTTP API interface
|
||||||
* @author Sree Harsha Totakura <sreeharsha@totakura.in>
|
* @author Sree Harsha Totakura <sreeharsha@totakura.in>
|
||||||
* @author Christian Grothoff
|
* @author Christian Grothoff
|
||||||
*
|
|
||||||
* TODO:
|
|
||||||
* - test /refresh/-operations
|
|
||||||
*/
|
*/
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "taler_util.h"
|
#include "taler_util.h"
|
||||||
@ -1822,26 +1819,25 @@ run (void *cls,
|
|||||||
const struct GNUNET_SCHEDULER_TaskContext *tc)
|
const struct GNUNET_SCHEDULER_TaskContext *tc)
|
||||||
{
|
{
|
||||||
struct InterpreterState *is;
|
struct InterpreterState *is;
|
||||||
#if FUTURE
|
|
||||||
static struct MeltDetails melt_coins_1[] = {
|
static struct MeltDetails melt_coins_1[] = {
|
||||||
{ "coin_ref1", "EUR:1.1" }, // FIXME: pick sensible values
|
{ .amount = "EUR:4",
|
||||||
{ "coin_ref2", "EUR:1.1" }, // FIXME: pick sensible values
|
.coin_ref = "refresh-withdraw-coin-1" },
|
||||||
{ "coin_ref3", "EUR:1.1" }, // FIXME: pick sensible values
|
|
||||||
{ NULL, NULL }
|
{ NULL, NULL }
|
||||||
};
|
};
|
||||||
static const char *melt_fresh_amounts_1[] = {
|
static const char *melt_fresh_amounts_1[] = {
|
||||||
"EUR:1", // FIXME: pick sensible values
|
"EUR:1",
|
||||||
"EUR:1", // FIXME: pick sensible values
|
"EUR:1",
|
||||||
"EUR:1", // FIXME: pick sensible values
|
"EUR:1",
|
||||||
|
"EUR:0.1",
|
||||||
|
"EUR:0.1",
|
||||||
|
"EUR:0.1",
|
||||||
|
"EUR:0.1",
|
||||||
|
"EUR:0.1",
|
||||||
|
"EUR:0.1",
|
||||||
|
"EUR:0.1",
|
||||||
|
/* with 0.03 refresh fees each, this totals up to exactly 4 EUR */
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
static const char *melt_fresh_amounts_2[] = {
|
|
||||||
"EUR:1", // FIXME: pick sensible values
|
|
||||||
"EUR:1", // FIXME: pick sensible values
|
|
||||||
"EUR:1", // FIXME: pick sensible values
|
|
||||||
NULL
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
static struct Command commands[] =
|
static struct Command commands[] =
|
||||||
{
|
{
|
||||||
/* Fill reserve with EUR:5.01, as withdraw fee is 1 ct per config */
|
/* Fill reserve with EUR:5.01, as withdraw fee is 1 ct per config */
|
||||||
@ -1909,44 +1905,82 @@ run (void *cls,
|
|||||||
.details.deposit.contract = "{ \"items\"={ \"name\":\"ice cream\", \"value\":2 } }",
|
.details.deposit.contract = "{ \"items\"={ \"name\":\"ice cream\", \"value\":2 } }",
|
||||||
.details.deposit.transaction_id = 1 },
|
.details.deposit.transaction_id = 1 },
|
||||||
|
|
||||||
#if FUTURE
|
#if TEST_REFRESH
|
||||||
/* Test running a successful melt operation */
|
/* ***************** /refresh testing ******************** */
|
||||||
|
|
||||||
|
/* Fill reserve with EUR:5.01, as withdraw fee is 1 ct */
|
||||||
|
{ .oc = OC_ADMIN_ADD_INCOMING,
|
||||||
|
.label = "refresh-create-reserve-1",
|
||||||
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
|
.details.admin_add_incoming.wire = "{ \"type\":\"TEST\", \"bank\":\"source bank\", \"account\":424 }",
|
||||||
|
.details.admin_add_incoming.amount = "EUR:5.01" },
|
||||||
|
/* Withdraw a 5 EUR coin, at fee of 1 ct */
|
||||||
|
{ .oc = OC_WITHDRAW_SIGN,
|
||||||
|
.label = "refresh-withdraw-coin-1",
|
||||||
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
|
.details.withdraw_sign.reserve_reference = "refresh-create-reserve-1",
|
||||||
|
.details.withdraw_sign.amount = "EUR:5" },
|
||||||
|
/* Try to partially spend (deposit) 1 EUR of the 5 EUR coin (in full)
|
||||||
|
(merchant would receive EUR:0.99 due to 1 ct deposit fee) */
|
||||||
|
{ .oc = OC_DEPOSIT,
|
||||||
|
.label = "refresh-deposit-partial",
|
||||||
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
|
.details.deposit.amount = "EUR:1",
|
||||||
|
.details.deposit.coin_ref = "refresh-withdraw-coin-1",
|
||||||
|
.details.deposit.wire_details = "{ \"type\":\"TEST\", \"bank\":\"dest bank\", \"account\":42 }",
|
||||||
|
.details.deposit.contract = "{ \"items\"={ \"name\":\"ice cream\", \"value\"EUR:1 } }",
|
||||||
|
.details.deposit.transaction_id = 42421 },
|
||||||
|
|
||||||
|
/* Melt the rest of the coin's value (EUR:4.00 = 3x EUR:1.03 + 7x EUR:0.13) */
|
||||||
{ .oc = OC_REFRESH_MELT,
|
{ .oc = OC_REFRESH_MELT,
|
||||||
.label = "melt-1",
|
.label = "refresh-melt-1",
|
||||||
.expected_response_code = MHD_HTTP_OK,
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
.details.refresh_melt.melted_coins = melt_coins_1,
|
.details.refresh_melt.melted_coins = melt_coins_1,
|
||||||
.details.refresh_melt.fresh_amounts = melt_fresh_amounts_1 },
|
.details.refresh_melt.fresh_amounts = melt_fresh_amounts_1 },
|
||||||
|
|
||||||
/* Complete (successful) melt operation, and withdraw the coins */
|
/* Complete (successful) melt operation, and withdraw the coins */
|
||||||
{ .oc = OC_REFRESH_REVEAL,
|
{ .oc = OC_REFRESH_REVEAL,
|
||||||
.label = "reveal-1",
|
.label = "refresh-reveal-1",
|
||||||
.melt_ref = "melt-1",
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
.expected_response_code = MHD_HTTP_OK },
|
.details.refresh_reveal.melt_ref = "refresh-melt-1" },
|
||||||
|
|
||||||
/* Test that /refresh/link works */
|
/* Test that /refresh/link works */
|
||||||
{ .oc = OC_REFRESH_LINK,
|
{ .oc = OC_REFRESH_LINK,
|
||||||
.label = "link-1",
|
.label = "refresh-link-1",
|
||||||
.reveal_ref = "reveal-1",
|
|
||||||
.expected_response_code = MHD_HTTP_OK },
|
|
||||||
|
|
||||||
/* Test successfully spending coins from the refresh operation */
|
|
||||||
{ .oc = OC_DEPOSIT,
|
|
||||||
.label = "deposit-refreshed-1",
|
|
||||||
.expected_response_code = MHD_HTTP_OK,
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
.details.deposit.amount = "EUR:5", // FIXME: pick sensible value
|
.details.refresh_link.reveal_ref = "refresh-reveal-1" },
|
||||||
.details.deposit.coin_ref = "reveal-1",
|
|
||||||
|
/* Test successfully spending coins from the refresh operation:
|
||||||
|
first EUR:1 */
|
||||||
|
{ .oc = OC_DEPOSIT,
|
||||||
|
.label = "refresh-deposit-refreshed-1",
|
||||||
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
|
.details.deposit.amount = "EUR:1",
|
||||||
|
.details.deposit.coin_ref = "refresh-reveal-1a",
|
||||||
.details.deposit.coin_idx = 0,
|
.details.deposit.coin_idx = 0,
|
||||||
.details.deposit.wire_details = "{ \"type\":\"TEST\", \"bank\":\"dest bank\", \"account\":42 }",
|
.details.deposit.wire_details = "{ \"type\":\"TEST\", \"bank\":\"dest bank\", \"account\":42 }",
|
||||||
.details.deposit.contract = "{ \"items\"={ \"name\":\"ice cream\", \"value\":3 } }",
|
.details.deposit.contract = "{ \"items\"={ \"name\":\"ice cream\", \"value\":3 } }",
|
||||||
.details.deposit.transaction_id = 2 },
|
.details.deposit.transaction_id = 2 },
|
||||||
|
/* Test successfully spending coins from the refresh operation:
|
||||||
|
finally EUR:0.1 */
|
||||||
|
{ .oc = OC_DEPOSIT,
|
||||||
|
.label = "refresh-deposit-refreshed-1b",
|
||||||
|
.expected_response_code = MHD_HTTP_OK,
|
||||||
|
.details.deposit.amount = "EUR:0.1",
|
||||||
|
.details.deposit.coin_ref = "refresh-reveal-1b",
|
||||||
|
.details.deposit.coin_idx = 4,
|
||||||
|
.details.deposit.wire_details = "{ \"type\":\"TEST\", \"bank\":\"dest bank\", \"account\":42 }",
|
||||||
|
.details.deposit.contract = "{ \"items\"={ \"name\":\"ice cream\", \"value\":3 } }",
|
||||||
|
.details.deposit.transaction_id = 2 },
|
||||||
|
|
||||||
/* Test running a failing melt operation */
|
/* Test running a failing melt operation (same operation again must fail) */
|
||||||
{ .oc = OC_REFRESH_MELT,
|
{ .oc = OC_REFRESH_MELT,
|
||||||
.label = "melt-2",
|
.label = "refresh-melt-failing",
|
||||||
.expected_response_code = MHD_HTTP_FORBIDDEN,
|
.expected_response_code = MHD_HTTP_FORBIDDEN,
|
||||||
.details.refresh_melt.melted_coins = melt_coins_1,
|
.details.refresh_melt.melted_coins = melt_coins_1,
|
||||||
.details.refresh_melt.fresh_amounts = melt_fresh_amounts_2 },
|
.details.refresh_melt.fresh_amounts = melt_fresh_amounts_1 },
|
||||||
|
|
||||||
|
/* *************** end of /refresh testing ************** */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
{ .oc = OC_END }
|
{ .oc = OC_END }
|
||||||
|
Loading…
Reference in New Issue
Block a user