mirror of
https://github.com/systemd/systemd.git
synced 2025-01-09 01:18:19 +03:00
verify: ignore nonexistent executables if required
We provide a way via the '-' symbol to ignore errors when nonexistent executable files are passed to Exec* parameters & so on. In such a case, the flag `EXEC_COMMAND_IGNORE_FAILURE` is set and we go on happily with our life if that happens. However, `systemd-analyze verify` complained about missing executables even in such a case. In such a case it is not an error for this to happen so check if the flag is set before checking if the file is accessible and executable. Add some small tests to check this condition. Closes #15218.
This commit is contained in:
parent
5fa5c3e2d0
commit
c90c597ee3
@ -124,10 +124,13 @@ static int verify_socket(Unit *u) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int verify_executable(Unit *u, ExecCommand *exec) {
|
int verify_executable(Unit *u, const ExecCommand *exec) {
|
||||||
if (!exec)
|
if (!exec)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (exec->flags & EXEC_COMMAND_IGNORE_FAILURE)
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (access(exec->path, X_OK) < 0)
|
if (access(exec->path, X_OK) < 0)
|
||||||
return log_unit_error_errno(u, errno, "Command %s is not executable: %m", exec->path);
|
return log_unit_error_errno(u, errno, "Command %s is not executable: %m", exec->path);
|
||||||
|
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
#include "execute.h"
|
||||||
#include "path-lookup.h"
|
#include "path-lookup.h"
|
||||||
|
|
||||||
|
int verify_executable(Unit *u, const ExecCommand *exec);
|
||||||
int verify_units(char **filenames, UnitFileScope scope, bool check_man, bool run_generators);
|
int verify_units(char **filenames, UnitFileScope scope, bool check_man, bool run_generators);
|
||||||
|
19
src/analyze/test-verify.c
Normal file
19
src/analyze/test-verify.c
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
/* SPDX-License-Identifier: LGPL-2.1+ */
|
||||||
|
#include "analyze-verify.h"
|
||||||
|
#include "tests.h"
|
||||||
|
|
||||||
|
static void test_verify_nonexistent(void) {
|
||||||
|
/* Negative cases */
|
||||||
|
assert_se(verify_executable(NULL, &(ExecCommand) {.flags = EXEC_COMMAND_IGNORE_FAILURE, .path = (char*) "/non/existent"}) == 0);
|
||||||
|
assert_se(verify_executable(NULL, &(ExecCommand) {.path = (char*) "/non/existent"}) < 0);
|
||||||
|
|
||||||
|
/* Ordinary cases */
|
||||||
|
assert_se(verify_executable(NULL, &(ExecCommand) {.path = (char*) "/bin/echo"}) == 0);
|
||||||
|
assert_se(verify_executable(NULL, &(ExecCommand) {.flags = EXEC_COMMAND_IGNORE_FAILURE, .path = (char*) "/bin/echo"}) == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
test_setup_logging(LOG_DEBUG);
|
||||||
|
|
||||||
|
test_verify_nonexistent();
|
||||||
|
}
|
@ -1127,6 +1127,10 @@ tests += [
|
|||||||
[],
|
[],
|
||||||
[]],
|
[]],
|
||||||
|
|
||||||
|
[['src/analyze/test-verify.c', 'src/analyze/analyze-verify.c', 'src/analyze/analyze-verify.h'],
|
||||||
|
[libcore, libshared],
|
||||||
|
[]],
|
||||||
|
|
||||||
[['src/login/test-inhibit.c'],
|
[['src/login/test-inhibit.c'],
|
||||||
[],
|
[],
|
||||||
[],
|
[],
|
||||||
|
Loading…
Reference in New Issue
Block a user