diff --git a/src/exchange-lib/exchange_api_refund.c b/src/exchange-lib/exchange_api_refund.c index ef1d66b90..1ddf642d6 100644 --- a/src/exchange-lib/exchange_api_refund.c +++ b/src/exchange-lib/exchange_api_refund.c @@ -180,6 +180,10 @@ handle_refund_finished (void *cls, /* Kind of normal: the money was already sent to the merchant (it was too late for the refund). */ break; + case MHD_HTTP_PRECONDITION_FAILED: + /* Client request was inconsistent; might be a currency missmatch + problem. */ + break; case MHD_HTTP_INTERNAL_SERVER_ERROR: /* Server had an internal issue; we should retry, but this API leaves this to the application */ diff --git a/src/exchange-lib/test_exchange_api_twisted.c b/src/exchange-lib/test_exchange_api_twisted.c index 6b044a8e6..63358e755 100644 --- a/src/exchange-lib/test_exchange_api_twisted.c +++ b/src/exchange-lib/test_exchange_api_twisted.c @@ -201,7 +201,7 @@ run (void *cls, /* Next chunk, refund conflicts (contract hash missmatch [!], - original deposit does not exist, + original deposit does not exist V, currency missmatch) V; 'refund_transaction()' has many of the relevant cases; @@ -235,18 +235,11 @@ run (void *cls, "EUR:5", MHD_HTTP_OK), - TALER_TESTING_cmd_modify_object_ul - ("hack-currency", - CONFIG_FILE, - /* Will make currency missmatch */ - "refund_amount", - "USD:5"), - TALER_TESTING_cmd_refund ("refund-currency-missmatch", - MHD_HTTP_BAD_REQUEST, - "EUR:5", - "EUR:0.01", + MHD_HTTP_PRECONDITION_FAILED, + "USD:5", + "USD:0.01", "deposit-refund-1"), TALER_TESTING_cmd_refund @@ -291,7 +284,7 @@ run (void *cls, TALER_TESTING_cmd_refund ("refund-deposit-not-found", - MHD_HTTP_BAD_REQUEST, + MHD_HTTP_NOT_FOUND, "EUR:5", "EUR:0.01", "deposit-refund-to-fail"), diff --git a/src/exchange-lib/testing_api_cmd_refund.c b/src/exchange-lib/testing_api_cmd_refund.c index 35cb20d26..d0f48bb22 100644 --- a/src/exchange-lib/testing_api_cmd_refund.c +++ b/src/exchange-lib/testing_api_cmd_refund.c @@ -227,8 +227,12 @@ refund_run (void *cls, } rs->rh = TALER_EXCHANGE_refund - (rs->exchange, &refund_amount, &refund_fee, &h_contract_terms, - &coin, rs->refund_transaction_id, + (rs->exchange, + &refund_amount, + &refund_fee, + &h_contract_terms, + &coin, + rs->refund_transaction_id, (const struct TALER_MerchantPrivateKeyP *) merchant_priv, &refund_cb, rs);