From 42a21ffc8ef36a141db2a7c57a20e70747028524 Mon Sep 17 00:00:00 2001 From: Christian Grothoff Date: Sat, 10 Nov 2018 13:58:02 +0100 Subject: add skeleton for auditor httpd tests --- src/include/taler_testing_auditor_lib.h | 98 +++++++++++++++++++++++++++++++++ 1 file changed, 98 insertions(+) create mode 100644 src/include/taler_testing_auditor_lib.h (limited to 'src/include') diff --git a/src/include/taler_testing_auditor_lib.h b/src/include/taler_testing_auditor_lib.h new file mode 100644 index 000000000..49b55581d --- /dev/null +++ b/src/include/taler_testing_auditor_lib.h @@ -0,0 +1,98 @@ +/* + This file is part of TALER + (C) 2018 Taler Systems SA + + 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, see + +*/ + +/** + * @file include/taler_testing_auditor_lib.h + * @brief API for writing an interpreter to test Taler components + * @author Christian Grothoff + * @author Marcello Stanisci + */ +#ifndef TALER_TESTING_AUDITOR_LIB_H +#define TALER_TESTING_AUDITOR_LIB_H + +#include "taler_util.h" +#include "taler_exchange_service.h" +#include +#include "taler_json_lib.h" +#include + + +/* ********************* Helper functions ********************* */ + +/** + * Prepare launching an auditor and exchange. Checks that the configured + * port is available, runs taler-exchange-keyup, taler-auditor-exchange, + * taler-auditor-sign and taler-exchange-dbinit. Does not + * launch the exchange process itself. + * + * @param config_filename configuration file to use + * @param auditor_base_url[out] will be set to the auditor base url, + * if the config has any; otherwise it will be set to + * NULL. + * @param exchange_base_url[out] will be set to the exchange base url, + * if the config has any; otherwise it will be set to + * NULL. + * @return #GNUNET_OK on success, #GNUNET_NO if test should be + * skipped, #GNUNET_SYSERR on test failure + */ +int +TALER_TESTING_AUDITOR_prepare_auditor (const char *config_filename, + char **auditor_base_url, + char **exchange_base_url); + + +/** + * Wait for the auditor to have started. Waits for at + * most 10s, after that returns 77 to indicate an error. + * + * @param base_url what URL should we expect the exchange + * to be running at + * @return 0 on success + */ +int +TALER_TESTING_AUDITOR_wait_auditor_ready (const char *base_url); + + +/** + * Remove files from previous runs + */ +void +TALER_TESTING_AUDITOR_cleanup_files (const char *config_name); + + +/** + * Initialize scheduler loop and curl context for the testcase + * including starting and stopping the auditor and exchange using the + * given configuration file. + * + * @param main_cb routine containing all the commands to run. + * @param main_cb_cls closure for @a main_cb, typically NULL. + * @param config_file configuration file for the test-suite. + * + * @return #GNUNET_OK if all is okay, != #GNUNET_OK otherwise. + * non-#GNUNET_OK codes are #GNUNET_SYSERR most of the + * time. + */ +int +TALER_TESTING_AUDITOR_setup_with_auditor (TALER_TESTING_Main main_cb, + void *main_cb_cls, + const char *config_filename); + + +#endif -- cgit v1.2.3