GNUnet  0.11.x
Data Structures | Macros | Functions
testing_api_cmd_netjail_start_v2.c File Reference
#include "platform.h"
#include "gnunet_util_lib.h"
#include "gnunet_testing_ng_lib.h"
Include dependency graph for testing_api_cmd_netjail_start_v2.c:

Go to the source code of this file.

Data Structures

struct  NetJailState
 Struct to hold information for callbacks. More...
 

Macros

#define NETJAIL_START_SCRIPT   "./../testing/netjail_start_v2.sh"
 

Functions

static void netjail_start_cleanup (void *cls, const struct GNUNET_TESTING_Command *cmd)
 The cleanup function of this cmd frees resources the cmd allocated. More...
 
static int netjail_start_traits (void *cls, const void **ret, const char *trait, unsigned int index)
 Trait function of this cmd does nothing. More...
 
static void child_completed_callback (void *cls, enum GNUNET_OS_ProcessStatusType type, long unsigned int exit_code)
 Callback which will be called if the setup script finished. More...
 
static void netjail_start_run (void *cls, const struct GNUNET_TESTING_Command *cmd, struct GNUNET_TESTING_Interpreter *is)
 The run method starts the script which setup the network namespaces. More...
 
static int netjail_start_finish (void *cls, GNUNET_SCHEDULER_TaskCallback cont, void *cont_cls)
 This function checks the flag NetJailState::finished, if this cmd finished. More...
 
struct GNUNET_TESTING_Command GNUNET_TESTING_cmd_netjail_start_v2 (const char *label, char *topology_config)
 Create command. More...
 

Macro Definition Documentation

◆ NETJAIL_START_SCRIPT

#define NETJAIL_START_SCRIPT   "./../testing/netjail_start_v2.sh"

Definition at line 30 of file testing_api_cmd_netjail_start_v2.c.

Function Documentation

◆ netjail_start_cleanup()

static void netjail_start_cleanup ( void *  cls,
const struct GNUNET_TESTING_Command cmd 
)
static

The cleanup function of this cmd frees resources the cmd allocated.

Definition at line 61 of file testing_api_cmd_netjail_start_v2.c.

63 {
64  struct NetJailState *ns = cls;
65 
67  "netjail_start_cleanup!\n");
68 
69  if (NULL != ns->cwh)
70  {
72  ns->cwh = NULL;
73  }
74  if (NULL != ns->start_proc)
75  {
76  GNUNET_assert (0 ==
77  GNUNET_OS_process_kill (ns->start_proc,
78  SIGKILL));
80  GNUNET_OS_process_wait (ns->start_proc));
81  GNUNET_OS_process_destroy (ns->start_proc);
82  ns->start_proc = NULL;
83  }
84  GNUNET_free (ns);
85 }
static struct GNUNET_NAMESTORE_Handle * ns
Handle to the namestore.
Definition: gnunet-abd.c:41
void GNUNET_wait_child_cancel(struct GNUNET_ChildWaitHandle *cwh)
Stop waiting on this child.
#define GNUNET_log(kind,...)
@ GNUNET_OK
Definition: gnunet_common.h:95
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
@ GNUNET_ERROR_TYPE_DEBUG
#define GNUNET_free(ptr)
Wrapper around free.
int GNUNET_OS_process_wait(struct GNUNET_OS_Process *proc)
Wait for a process to terminate.
Definition: os_priority.c:983
void GNUNET_OS_process_destroy(struct GNUNET_OS_Process *proc)
Cleans up process structure contents (OS-dependent) and deallocates it.
Definition: os_priority.c:286
int GNUNET_OS_process_kill(struct GNUNET_OS_Process *proc, int sig)
Sends a signal to the process.
Definition: os_priority.c:224
Struct to hold information for callbacks.

References GNUNET_assert, GNUNET_ERROR_TYPE_DEBUG, GNUNET_free, GNUNET_log, GNUNET_OK, GNUNET_OS_process_destroy(), GNUNET_OS_process_kill(), GNUNET_OS_process_wait(), GNUNET_wait_child_cancel(), and ns.

Here is the call graph for this function:

◆ netjail_start_traits()

static int netjail_start_traits ( void *  cls,
const void **  ret,
const char *  trait,
unsigned int  index 
)
static

Trait function of this cmd does nothing.

Definition at line 93 of file testing_api_cmd_netjail_start_v2.c.

97 {
98  return GNUNET_OK;
99 }

References GNUNET_OK.

◆ child_completed_callback()

static void child_completed_callback ( void *  cls,
enum GNUNET_OS_ProcessStatusType  type,
long unsigned int  exit_code 
)
static

Callback which will be called if the setup script finished.

Definition at line 107 of file testing_api_cmd_netjail_start_v2.c.

110 {
111  struct NetJailState *ns = cls;
112 
113  if (0 == exit_code)
114  {
115  ns->finished = GNUNET_YES;
116  }
117  else
118  {
120  "Child completed with an error!\n");
121  ns->finished = GNUNET_SYSERR;
122  }
123  GNUNET_OS_process_destroy (ns->start_proc);
124  ns->start_proc = NULL;
125 }
static long unsigned int exit_code
Handler exit code.
Definition: gnunet-qr.c:54
@ GNUNET_YES
Definition: gnunet_common.h:97
@ GNUNET_SYSERR
Definition: gnunet_common.h:93
@ GNUNET_ERROR_TYPE_ERROR

References exit_code, GNUNET_ERROR_TYPE_ERROR, GNUNET_log, GNUNET_OS_process_destroy(), GNUNET_SYSERR, GNUNET_YES, and ns.

Referenced by netjail_start_run().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ netjail_start_run()

static void netjail_start_run ( void *  cls,
const struct GNUNET_TESTING_Command cmd,
struct GNUNET_TESTING_Interpreter is 
)
static

The run method starts the script which setup the network namespaces.

Parameters
clsclosure.
cmdCMD being run.
isinterpreter state.

Definition at line 137 of file testing_api_cmd_netjail_start_v2.c.

140 {
141  struct NetJailState *ns = cls;
142  char *pid;
144  "%u",
145  getpid ());
146  char *const script_argv[] = {NETJAIL_START_SCRIPT,
147  ns->topology_config,
148  pid,
149  NULL};
150  unsigned int helper_check = GNUNET_OS_check_helper_binary (
152  GNUNET_YES,
153  NULL);
154 
155  if (GNUNET_NO == helper_check)
156  {
158  "No SUID for %s!\n",
161  }
162  else if (GNUNET_NO == helper_check)
163  {
165  "%s not found!\n",
168  }
169 
171  NULL,
172  NULL,
173  NULL,
175  script_argv);
176 
177  ns->cwh = GNUNET_wait_child (ns->start_proc,
179  ns);
180  GNUNET_break (NULL != ns->cwh);
181 }
static struct GNUNET_PeerIdentity pid
Identity of the peer we transmit to / connect to.
struct GNUNET_ChildWaitHandle * GNUNET_wait_child(struct GNUNET_OS_Process *proc, GNUNET_ChildCompletedCallback cb, void *cb_cls)
Starts the handling of the child processes.
@ GNUNET_NO
Definition: gnunet_common.h:94
void GNUNET_TESTING_interpreter_fail()
Current command failed, clean up and fail the test case.
#define GNUNET_break(cond)
Use this for internal assertion violations that are not fatal (can be handled) but should not occur.
int int GNUNET_asprintf(char **buf, const char *format,...) __attribute__((format(printf
Like asprintf, just portable.
int GNUNET_OS_check_helper_binary(const char *binary, int check_suid, const char *params)
Check whether an executable exists and possibly if the suid bit is set on the file.
struct GNUNET_OS_Process * GNUNET_OS_start_process_vap(enum GNUNET_OS_InheritStdioFlags std_inheritance, struct GNUNET_DISK_PipeHandle *pipe_stdin, struct GNUNET_DISK_PipeHandle *pipe_stdout, struct GNUNET_DISK_PipeHandle *pipe_stderr, const char *filename, char *const argv[])
Start a process.
Definition: os_priority.c:604
@ GNUNET_OS_INHERIT_STD_ERR
When this flag is set, the child process will inherit stderr of the parent.
Definition: gnunet_os_lib.h:91
static void child_completed_callback(void *cls, enum GNUNET_OS_ProcessStatusType type, long unsigned int exit_code)
Callback which will be called if the setup script finished.
#define NETJAIL_START_SCRIPT

References child_completed_callback(), GNUNET_asprintf(), GNUNET_break, GNUNET_ERROR_TYPE_ERROR, GNUNET_log, GNUNET_NO, GNUNET_OS_check_helper_binary(), GNUNET_OS_INHERIT_STD_ERR, GNUNET_OS_start_process_vap(), GNUNET_TESTING_interpreter_fail(), GNUNET_wait_child(), GNUNET_YES, NETJAIL_START_SCRIPT, ns, and pid.

Here is the call graph for this function:

◆ netjail_start_finish()

static int netjail_start_finish ( void *  cls,
GNUNET_SCHEDULER_TaskCallback  cont,
void *  cont_cls 
)
static

This function checks the flag NetJailState::finished, if this cmd finished.

Definition at line 189 of file testing_api_cmd_netjail_start_v2.c.

192 {
193  struct NetJailState *ns = cls;
194 
195  if (ns->finished)
196  {
197  cont (cont_cls);
198  }
199  return ns->finished;
200 }

References ns.

◆ GNUNET_TESTING_cmd_netjail_start_v2()

struct GNUNET_TESTING_Command GNUNET_TESTING_cmd_netjail_start_v2 ( const char *  label,
char *  topology_config 
)

Create command.

Parameters
labelname for command.
topology_configConfiguration file for the test topology.
Returns
command.

Definition at line 189 of file testing_api_cmd_netjail_start_v2.c.

212 {
213  struct NetJailState *ns;
214 
215  ns = GNUNET_new (struct NetJailState);
216  ns->finished = GNUNET_NO;
217  ns->topology_config = topology_config;
218 
219  struct GNUNET_TESTING_Command cmd = {
220  .cls = ns,
221  .label = label,
222  .run = &netjail_start_run,
223  .finish = &netjail_start_finish,
224  .cleanup = &netjail_start_cleanup,
225  .traits = &netjail_start_traits
226  };
227 
228  return cmd;
229 }
#define GNUNET_new(type)
Allocate a struct or union of the given type.
A command to be run by the interpreter.
const char * label
Label for the command.
void * cls
Closure for all commands with command-specific context information.
char * topology_config
Configuration file for the test topology.
static int netjail_start_traits(void *cls, const void **ret, const char *trait, unsigned int index)
Trait function of this cmd does nothing.
static void netjail_start_cleanup(void *cls, const struct GNUNET_TESTING_Command *cmd)
The cleanup function of this cmd frees resources the cmd allocated.
static int netjail_start_finish(void *cls, GNUNET_SCHEDULER_TaskCallback cont, void *cont_cls)
This function checks the flag NetJailState::finished, if this cmd finished.
static void netjail_start_run(void *cls, const struct GNUNET_TESTING_Command *cmd, struct GNUNET_TESTING_Interpreter *is)
The run method starts the script which setup the network namespaces.