diff options
Diffstat (limited to 'src/mint')
-rw-r--r-- | src/mint/taler-mint-httpd.c | 26 | ||||
-rw-r--r-- | src/mint/taler-mint-httpd.h | 5 | ||||
-rw-r--r-- | src/mint/taler-mint-httpd_db.c | 12 |
3 files changed, 37 insertions, 6 deletions
diff --git a/src/mint/taler-mint-httpd.c b/src/mint/taler-mint-httpd.c index 0d221444f..d74ecf022 100644 --- a/src/mint/taler-mint-httpd.c +++ b/src/mint/taler-mint-httpd.c @@ -69,6 +69,11 @@ char *TMH_expected_wire_format; struct TALER_MINTDB_Plugin *TMH_plugin; /** + * Are we running in test mode? + */ +int TMH_test_mode; + +/** * The HTTP Daemon. */ static struct MHD_Daemon *mydaemon; @@ -368,6 +373,17 @@ mint_serve_process_config (const char *mint_directory) "Failed to initialize DB subsystem\n"); return GNUNET_SYSERR; } + if (GNUNET_YES == + GNUNET_CONFIGURATION_get_value_yesno (cfg, + "mint", + "TESTRUN")) + { + GNUNET_log (GNUNET_ERROR_TYPE_INFO, + "Running in TEST mode! Database contents will not persist!\n"); + TMH_test_mode = GNUNET_YES; + TMH_plugin->create_tables (TMH_plugin->cls, + GNUNET_YES); + } if (GNUNET_OK != GNUNET_CONFIGURATION_get_value_number (cfg, @@ -452,6 +468,16 @@ main (int argc, char *const *argv) ret = TMH_KS_loop (); MHD_stop_daemon (mydaemon); + if (GNUNET_YES == TMH_test_mode) + { + struct TALER_MINTDB_Session *session; + + session = TMH_plugin->get_session (TMH_plugin->cls, + GNUNET_YES); + TMH_plugin->drop_temporary (TMH_plugin->cls, + session); + } + TALER_MINTDB_plugin_unload (TMH_plugin); return (GNUNET_OK == ret) ? 0 : 1; } diff --git a/src/mint/taler-mint-httpd.h b/src/mint/taler-mint-httpd.h index c674a9daa..a54e5aa2e 100644 --- a/src/mint/taler-mint-httpd.h +++ b/src/mint/taler-mint-httpd.h @@ -38,6 +38,11 @@ extern char *TMH_mint_currency_string; extern struct GNUNET_CONFIGURATION_Handle *cfg; /** + * Are we running in test mode? + */ +extern int TMH_test_mode; + +/** * Main directory with mint data. */ extern char *TMH_mint_directory; diff --git a/src/mint/taler-mint-httpd_db.c b/src/mint/taler-mint-httpd_db.c index 8a46a1839..c51f58205 100644 --- a/src/mint/taler-mint-httpd_db.c +++ b/src/mint/taler-mint-httpd_db.c @@ -107,7 +107,7 @@ TMH_DB_execute_deposit (struct MHD_Connection *connection, int ret; if (NULL == (session = TMH_plugin->get_session (TMH_plugin->cls, - GNUNET_NO))) + TMH_test_mode))) { GNUNET_break (0); return TMH_RESPONSE_reply_internal_db_error (connection); @@ -222,7 +222,7 @@ TMH_DB_execute_withdraw_status (struct MHD_Connection *connection, int res; if (NULL == (session = TMH_plugin->get_session (TMH_plugin->cls, - GNUNET_NO))) + TMH_test_mode))) { GNUNET_break (0); return TMH_RESPONSE_reply_internal_db_error (connection); @@ -288,7 +288,7 @@ TMH_DB_execute_withdraw_sign (struct MHD_Connection *connection, &h_blind); if (NULL == (session = TMH_plugin->get_session (TMH_plugin->cls, - GNUNET_NO))) + TMH_test_mode))) { GNUNET_break (0); return TMH_RESPONSE_reply_internal_db_error (connection); @@ -615,7 +615,7 @@ TMH_DB_execute_refresh_melt (struct MHD_Connection *connection, if (NULL == (session = TMH_plugin->get_session (TMH_plugin->cls, - GNUNET_NO))) + TMH_test_mode))) { GNUNET_break (0); return TMH_RESPONSE_reply_internal_db_error (connection); @@ -1071,7 +1071,7 @@ TMH_DB_execute_refresh_reveal (struct MHD_Connection *connection, unsigned int off; if (NULL == (session = TMH_plugin->get_session (TMH_plugin->cls, - GNUNET_NO))) + TMH_test_mode))) { GNUNET_break (0); return TMH_RESPONSE_reply_internal_db_error (connection); @@ -1335,7 +1335,7 @@ TMH_DB_execute_refresh_link (struct MHD_Connection *connection, unsigned int i; if (NULL == (ctx.session = TMH_plugin->get_session (TMH_plugin->cls, - GNUNET_NO))) + TMH_test_mode))) { GNUNET_break (0); return TMH_RESPONSE_reply_internal_db_error (connection); |