exchange/src/testing/testing_api_cmd_signal.c

116 lines
2.5 KiB
C
Raw Normal View History

2018-01-23 10:28:24 +01:00
/*
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
<http://www.gnu.org/licenses/>
*/
/**
* @file testing/testing_api_cmd_signal.c
2018-01-23 10:28:24 +01:00
* @brief command(s) to send signals to processes.
* @author Marcello Stanisci
*/
#include "platform.h"
#include "taler_json_lib.h"
#include <gnunet/gnunet_curl_lib.h>
#include "taler_testing_lib.h"
2018-05-28 13:38:20 +02:00
/**
* State for a "signal" CMD.
*/
2018-01-23 10:28:24 +01:00
struct SignalState
{
/**
* The process to send the signal to.
*/
struct GNUNET_OS_Process *process;
/**
* The signal to send to the process.
*/
int signal;
};
/**
* Run the command.
*
2018-05-28 13:38:20 +02:00
* @param cls closure.
* @param cmd the command to execute.
2018-01-23 10:28:24 +01:00
* @param is the interpreter state.
*/
static void
2018-01-23 10:28:24 +01:00
signal_run (void *cls,
const struct TALER_TESTING_Command *cmd,
struct TALER_TESTING_Interpreter *is)
{
struct SignalState *ss = cls;
GNUNET_break (0 == GNUNET_OS_process_kill
2019-08-25 16:18:24 +02:00
(ss->process, ss->signal));
2018-01-23 10:28:24 +01:00
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
"Signaling '%d'..\n",
ss->signal);
sleep (6);
TALER_TESTING_interpreter_next (is);
}
/**
2018-05-28 13:38:20 +02:00
* Cleanup the state from a "signal" CMD.
2018-01-23 10:28:24 +01:00
*
2018-05-28 13:38:20 +02:00
* @param cls closure.
2018-01-23 10:28:24 +01:00
* @param cmd the command which is being cleaned up.
*/
static void
2018-01-23 10:28:24 +01:00
signal_cleanup (void *cls,
const struct TALER_TESTING_Command *cmd)
{
struct SignalState *ss = cls;
GNUNET_free (ss);
}
2018-01-23 10:28:24 +01:00
/**
2018-05-28 13:38:20 +02:00
* Create a "signal" CMD.
2018-01-23 10:28:24 +01:00
*
2018-05-28 13:38:20 +02:00
* @param label command label.
* @param process handle to the process to signal.
* @param signal signal to send.
2018-01-23 10:28:24 +01:00
*
* @return the command.
*/
struct TALER_TESTING_Command
TALER_TESTING_cmd_signal (const char *label,
struct GNUNET_OS_Process *process,
int signal)
{
struct SignalState *ss;
ss = GNUNET_new (struct SignalState);
ss->process = process;
ss->signal = signal;
2018-12-19 11:43:05 +01:00
struct TALER_TESTING_Command cmd = {
.cls = ss,
.label = label,
.run = &signal_run,
.cleanup = &signal_cleanup
};
2018-01-23 10:28:24 +01:00
return cmd;
}