LCOV - code coverage report
Current view: top level - testing - testing_api_cmd_auditor_exec_auditor.c (source / functions) Coverage Total Hit
Test: coverage.info Lines: 0.0 % 27 0
Test Date: 2025-12-26 23:00:34 Functions: 0.0 % 4 0

            Line data    Source code
       1              : /*
       2              :   This file is part of TALER
       3              :   Copyright (C) 2018 Taler Systems SA
       4              : 
       5              :   TALER is free software; you can redistribute it and/or modify it
       6              :   under the terms of the GNU General Public License as published
       7              :   by the Free Software Foundation; either version 3, or (at your
       8              :   option) any later version.
       9              : 
      10              :   TALER is distributed in the hope that it will be useful, but
      11              :   WITHOUT ANY WARRANTY; without even the implied warranty of
      12              :   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      13              :   GNU General Public License for more details.
      14              : 
      15              :   You should have received a copy of the GNU General Public
      16              :   License along with TALER; see the file COPYING.  If not,
      17              :   see <http://www.gnu.org/licenses/>
      18              : */
      19              : /**
      20              :  * @file testing/testing_api_cmd_auditor_exec_auditor.c
      21              :  * @brief run the taler-auditor command
      22              :  * @author Marcello Stanisci
      23              :  * @author Christian Grothoff
      24              :  */
      25              : #include "taler/platform.h"
      26              : #include "taler/taler_json_lib.h"
      27              : #include <gnunet/gnunet_curl_lib.h>
      28              : #include "taler/taler_signatures.h"
      29              : #include "taler/taler_testing_lib.h"
      30              : 
      31              : 
      32              : /**
      33              :  * State for a "auditor" CMD.
      34              :  */
      35              : struct AuditorState
      36              : {
      37              : 
      38              :   /**
      39              :    * Process for the "auditor" command.
      40              :    */
      41              :   struct GNUNET_OS_Process *auditor_proc;
      42              : 
      43              :   /**
      44              :    * Configuration file used by the command.
      45              :    */
      46              :   const char *config_filename;
      47              : };
      48              : 
      49              : 
      50              : /**
      51              :  * Run the command; calls the `taler-auditor` program.
      52              :  *
      53              :  * @param cls closure.
      54              :  * @param cmd the commaind being run.
      55              :  * @param is interpreter state.
      56              :  */
      57              : static void
      58            0 : auditor_run (void *cls,
      59              :              const struct TALER_TESTING_Command *cmd,
      60              :              struct TALER_TESTING_Interpreter *is)
      61              : {
      62            0 :   struct AuditorState *ks = cls;
      63              : 
      64              :   (void) cmd;
      65              :   // FIXME: taler-auditor is no more, run the individual
      66              :   // helpers here instead, or re-introduce the taler-auditor
      67              :   // command to run all helpers!
      68              :   ks->auditor_proc
      69            0 :     = GNUNET_OS_start_process (GNUNET_OS_INHERIT_STD_ALL,
      70              :                                NULL, NULL, NULL,
      71              :                                "taler-auditor",
      72              :                                "taler-auditor",
      73              :                                "-c", ks->config_filename,
      74              :                                "-I",
      75              :                                NULL);
      76            0 :   if (NULL == ks->auditor_proc)
      77              :   {
      78            0 :     GNUNET_break (0);
      79            0 :     TALER_TESTING_interpreter_fail (is);
      80            0 :     return;
      81              :   }
      82            0 :   TALER_TESTING_wait_for_sigchld (is);
      83              : }
      84              : 
      85              : 
      86              : /**
      87              :  * Free the state of a "auditor" CMD, and possibly kills its
      88              :  * process if it did not terminate correctly.
      89              :  *
      90              :  * @param cls closure.
      91              :  * @param cmd the command being freed.
      92              :  */
      93              : static void
      94            0 : auditor_cleanup (void *cls,
      95              :                  const struct TALER_TESTING_Command *cmd)
      96              : {
      97            0 :   struct AuditorState *ks = cls;
      98              : 
      99              :   (void) cmd;
     100            0 :   if (NULL != ks->auditor_proc)
     101              :   {
     102            0 :     GNUNET_break (0 ==
     103              :                   GNUNET_OS_process_kill (ks->auditor_proc,
     104              :                                           SIGKILL));
     105            0 :     GNUNET_OS_process_wait (ks->auditor_proc);
     106            0 :     GNUNET_OS_process_destroy (ks->auditor_proc);
     107            0 :     ks->auditor_proc = NULL;
     108              :   }
     109            0 :   GNUNET_free (ks);
     110            0 : }
     111              : 
     112              : 
     113              : /**
     114              :  * Offer "auditor" CMD internal data to other commands.
     115              :  *
     116              :  * @param cls closure.
     117              :  * @param[out] ret result
     118              :  * @param trait name of the trait.
     119              :  * @param index index number of the object to offer.
     120              :  * @return #GNUNET_OK on success.
     121              :  */
     122              : static enum GNUNET_GenericReturnValue
     123            0 : auditor_traits (void *cls,
     124              :                 const void **ret,
     125              :                 const char *trait,
     126              :                 unsigned int index)
     127              : {
     128            0 :   struct AuditorState *ks = cls;
     129              :   struct TALER_TESTING_Trait traits[] = {
     130            0 :     TALER_TESTING_make_trait_process (&ks->auditor_proc),
     131            0 :     TALER_TESTING_trait_end ()
     132              :   };
     133              : 
     134            0 :   return TALER_TESTING_get_trait (traits,
     135              :                                   ret,
     136              :                                   trait,
     137              :                                   index);
     138              : }
     139              : 
     140              : 
     141              : struct TALER_TESTING_Command
     142            0 : TALER_TESTING_cmd_exec_auditor (const char *label,
     143              :                                 const char *config_filename)
     144              : {
     145              :   struct AuditorState *ks;
     146              : 
     147            0 :   ks = GNUNET_new (struct AuditorState);
     148            0 :   ks->config_filename = config_filename;
     149              :   {
     150            0 :     struct TALER_TESTING_Command cmd = {
     151              :       .cls = ks,
     152              :       .label = label,
     153              :       .run = &auditor_run,
     154              :       .cleanup = &auditor_cleanup,
     155              :       .traits = &auditor_traits
     156              :     };
     157              : 
     158            0 :     return cmd;
     159              :   }
     160              : }
     161              : 
     162              : 
     163              : /* end of testing_auditor_api_cmd_exec_auditor.c */
        

Generated by: LCOV version 2.0-1