@@ -1283,6 +1283,9 @@ return value is '255' if 'execvp()' failed with 'ENOENT' and '254' otherwise.
'stdout_path' and 'stderr_path' determine where to redirect the program
stdout and stderr I/O streams.
+The 'SAFE_RUN_CMD()' macro can be used automatic handling non zero exits (exits
+with 'TBROK') or 'ENOENT' (exits with 'TCONF').
+
.Example
[source,c]
-------------------------------------------------------------------------------
@@ -21,6 +21,7 @@
#include <grp.h>
#include "safe_macros_fn.h"
+#include "tst_cmd.h"
#define SAFE_BASENAME(path) \
safe_basename(__FILE__, __LINE__, NULL, (path))
@@ -534,4 +535,23 @@ int safe_personality(const char *filename, unsigned int lineno,
void safe_unshare(const char *file, const int lineno, int flags);
#define SAFE_UNSHARE(flags) safe_unshare(__FILE__, __LINE__, (flags))
+static inline void safe_run_cmd(const char *file, const int lineno,
+ const char *const argv[],
+ const char *stdout_path,
+ const char *stderr_path)
+{
+ int rval;
+
+ switch ((rval = tst_run_cmd(argv, stdout_path, stderr_path,
+ TST_RUN_CMD_PASS_EXIT_VAL |
+ TST_RUN_CMD_CHECK_CMD))) {
+ case 0:
+ break;
+ default:
+ tst_brk(TBROK, "%s:%d: %s failed (%d)", file, lineno, argv[0], rval);
+ }
+}
+#define SAFE_RUN_CMD(argv, stdout_path, stderr_path) \
+ safe_run_cmd(__FILE__, __LINE__, (argv), (stdout_path), (stderr_path))
+
#endif /* SAFE_MACROS_H__ */