* its direct dependencies. Hence, search for any of the filenames in the set and if found,
* return a non-zero process exit status. */
if (recursive_errors == RECURSIVE_ERRORS_ONE)
- STRV_FOREACH(filename, filenames)
- if (set_contains(s, basename(*filename)))
+ STRV_FOREACH(filename, filenames) {
+ _cleanup_free_ char *unit_file = NULL;
+
+ r = path_extract_filename(*filename, &unit_file);
+ if (r < 0)
+ return log_error_errno(r, "Failed to extract file name from '%s': %m", *filename);
+
+ if (set_contains(s, unit_file))
return -ENOTRECOVERABLE;
+ }
return 0;
}
#include "load-fragment.h"
#include "log.h"
#include "manager.h"
+#include "path-util.h"
#include "stat-util.h"
#include "strv.h"
#include "unit.h"
return r;
STRV_FOREACH(p, paths) {
- _cleanup_free_ char *target = NULL;
- const char *entry;
-
- entry = basename(*p);
+ _cleanup_free_ char *target = NULL, *target_file = NULL, *entry = NULL;
if (null_or_empty_path(*p) > 0) {
/* an error usually means an invalid symlink, which is not a mask */
continue;
}
+ r = path_extract_filename(*p, &entry);
+ if (r < 0) {
+ log_unit_warning_errno(u, r, "Failed to extract file name of %s dependency dropin %s, ignoring: %m",
+ unit_dependency_to_string(dependency), *p);
+ continue;
+ }
+
if (!unit_name_is_valid(entry, UNIT_NAME_ANY)) {
log_unit_warning(u, "%s dependency dropin %s is not a valid unit name, ignoring.",
unit_dependency_to_string(dependency), *p);
continue;
}
+ r = path_extract_filename(target, &target_file);
+ if (r < 0) {
+ log_unit_warning_errno(u, r, "Failed to extract file name for dropin target %s, ignoring: %m",
+ target);
+ continue;
+ }
+
/* We don't treat this as an error, especially because we didn't check this for a
* long time. Nevertheless, we warn, because such mismatch can be mighty confusing. */
- r = unit_symlink_name_compatible(entry, basename(target), u->instance);
+ r = unit_symlink_name_compatible(entry, target_file, u->instance);
if (r < 0) {
log_unit_warning_errno(u, r, "Can't check if names %s and %s are compatible, ignoring: %m",
- entry, basename(target));
+ entry, target_file);
continue;
}
if (r == 0)
};
static void* thread_server(void *p) {
- _cleanup_free_ char *suffixed = NULL, *suffixed2 = NULL, *d = NULL;
+ _cleanup_free_ char *suffixed = NULL, *suffixed_basename = NULL, *suffixed2 = NULL, *d = NULL;
_cleanup_close_ int fd = -EBADF;
union sockaddr_union u;
const char *path = p;
assert_se(symlink(suffixed2, d) >= 0);
usleep_safe(100 * USEC_PER_MSEC);
- assert_se(symlink(basename(suffixed), suffixed2) >= 0);
+ assert_se(path_extract_filename(suffixed, &suffixed_basename) >= 0);
+ assert_se(symlink(suffixed_basename, suffixed2) >= 0);
usleep_safe(100 * USEC_PER_MSEC);
socklen_t sa_len;
#include "networkd-sriov.h"
#include "networkd-state-file.h"
#include "nlmon.h"
+#include "path-util.h"
#include "stat-util.h"
#include "string-table.h"
#include "string-util.h"
int netdev_load_one(Manager *manager, const char *filename, NetDev **ret) {
_cleanup_(netdev_unrefp) NetDev *netdev_raw = NULL, *netdev = NULL;
+ _cleanup_free_ char *file_basename = NULL;
const char *dropin_dirname;
int r;
.state = _NETDEV_STATE_INVALID, /* an invalid state means done() of the implementation won't be called on destruction */
};
- dropin_dirname = strjoina(basename(filename), ".d");
+ r = path_extract_filename(filename, &file_basename);
+ if (r < 0)
+ return log_warning_errno(r, "Failed to extract file name of '%s': %m", filename);
+
+ dropin_dirname = strjoina(file_basename, ".d");
r = config_parse_many(
STRV_MAKE_CONST(filename), NETWORK_DIRS, dropin_dirname, /* root = */ NULL,
NETDEV_COMMON_SECTIONS NETDEV_OTHER_SECTIONS,
#include "networkd-routing-policy-rule.h"
#include "ordered-set.h"
#include "parse-util.h"
+#include "path-util.h"
#include "qdisc.h"
#include "radv-internal.h"
#include "set.h"
if (!fname)
return log_oom();
- name = strdup(basename(filename));
- if (!name)
- return log_oom();
+ r = path_extract_filename(filename, &name);
+ if (r < 0)
+ return log_warning_errno(r, "Failed to extract file name of \"%s\": %m", filename);
d = strrchr(name, '.');
if (!d)
/* Let's also put the names in the reverse db. */
const char *dummy, *src;
HASHMAP_FOREACH_KEY(dummy, src, ids) {
- _cleanup_free_ char *inst = NULL, *dst_inst = NULL;
- const char *dst;
+ _cleanup_free_ char *inst = NULL, *dst = NULL;
+ const char *dst_path;
- r = unit_ids_map_get(ids, src, &dst);
+ r = unit_ids_map_get(ids, src, &dst_path);
if (r < 0)
continue;
- if (null_or_empty_path(dst) != 0)
+ if (null_or_empty_path(dst_path) != 0)
continue;
- dst = basename(dst);
+ r = path_extract_filename(dst_path, &dst);
+ if (r < 0) {
+ log_debug_errno(r, "Failed to extract file name from %s, ignoring: %m", dst_path);
+ continue;
+ }
/* If we have an symlink from an instance name to a template name, it is an alias just for
* this specific instance, foo@id.service ↔ template@id.service. */
if (t < 0)
return log_error_errno(t, "Failed to extract instance part from %s: %m", src);
if (t == UNIT_NAME_INSTANCE) {
+ _cleanup_free_ char *dst_inst = NULL;
+
r = unit_name_replace_instance(dst, inst, &dst_inst);
if (r < 0) {
/* This might happen e.g. if the combined length is too large.
continue;
}
- dst = dst_inst;
+ free_and_replace(dst, dst_inst);
}
}
bool last = false;
STRV_FOREACH(dropin, i->dropin_paths) {
- _cleanup_free_ char *dropin_formatted = NULL;
+ _cleanup_free_ char *dropin_formatted = NULL, *dropin_basename = NULL;
const char *df;
if (!dir || last) {
last = ! (*(dropin + 1) && startswith(*(dropin + 1), dir));
- if (terminal_urlify_path(*dropin, basename(*dropin), &dropin_formatted) >= 0)
+ r = path_extract_filename(*dropin, &dropin_basename);
+ if (r < 0) {
+ log_error_errno(r, "Failed to extract file name of '%s': %m", *dropin);
+ break;
+ }
+
+ if (terminal_urlify_path(*dropin, dropin_basename, &dropin_formatted) >= 0)
df = dropin_formatted;
else
df = *dropin;
NULL,
};
- _cleanup_free_ char *p = NULL, *q = NULL, *l = NULL, *v = NULL;
+ _cleanup_free_ char *p = NULL, *q = NULL, *l = NULL, *v = NULL, *b = NULL;
bool found_native = false, found_sysv;
const char *name;
unsigned c = 1;
if (!v)
return log_oom();
+ j = path_extract_filename(p, &b);
+ if (j < 0)
+ return log_error_errno(j, "Failed to extract file name from '%s': %m", p);
+
argv[c++] = v;
- argv[c++] = basename(p);
+ argv[c++] = b;
argv[c] = NULL;
l = strv_join((char**)argv, " ");
};
char name[] = "/tmp/test-search_and_fopen.XXXXXX";
_cleanup_fclose_ FILE *f = NULL;
- _cleanup_free_ char *p = NULL;
+ _cleanup_free_ char *p = NULL, *bn = NULL;
_cleanup_close_ int fd = -EBADF;
const char *e;
int r;
assert_se(fd >= 0);
fd = safe_close(fd);
- r = search_and_fopen(basename(name), "re", NULL, (const char**) dirs, &f, &p);
- assert_se(r >= 0);
+ ASSERT_OK(path_extract_filename(name, &bn));
+ ASSERT_OK(search_and_fopen(bn, "re", NULL, (const char**) dirs, &f, &p));
assert_se(e = path_startswith(p, "/tmp/"));
- ASSERT_STREQ(basename(name), e);
+ ASSERT_STREQ(bn, e);
f = safe_fclose(f);
p = mfree(p);
- r = search_and_fopen(basename(name), NULL, NULL, (const char**) dirs, NULL, &p);
- assert_se(r >= 0);
+ ASSERT_OK(search_and_fopen(bn, NULL, NULL, (const char**) dirs, NULL, &p));
assert_se(e = path_startswith(p, "/tmp/"));
- ASSERT_STREQ(basename(name), e);
+ ASSERT_STREQ(bn, e);
p = mfree(p);
- r = search_and_fopen(name, "re", NULL, (const char**) dirs, &f, &p);
- assert_se(r >= 0);
+ ASSERT_OK(search_and_fopen(name, "re", NULL, (const char**) dirs, &f, &p));
assert_se(path_equal(name, p));
f = safe_fclose(f);
p = mfree(p);
- r = search_and_fopen(name, NULL, NULL, (const char**) dirs, NULL, &p);
- assert_se(r >= 0);
+ ASSERT_OK(search_and_fopen(name, NULL, NULL, (const char**) dirs, NULL, &p));
assert_se(path_equal(name, p));
p = mfree(p);
- r = search_and_fopen(basename(name), "re", "/", (const char**) dirs, &f, &p);
- assert_se(r >= 0);
+ ASSERT_OK(search_and_fopen(bn, "re", "/", (const char**) dirs, &f, &p));
assert_se(e = path_startswith(p, "/tmp/"));
- ASSERT_STREQ(basename(name), e);
+ ASSERT_STREQ(bn, e);
f = safe_fclose(f);
p = mfree(p);
- r = search_and_fopen(basename(name), NULL, "/", (const char**) dirs, NULL, &p);
- assert_se(r >= 0);
+ ASSERT_OK(search_and_fopen(bn, NULL, "/", (const char**) dirs, NULL, &p));
assert_se(e = path_startswith(p, "/tmp/"));
- ASSERT_STREQ(basename(name), e);
+ ASSERT_STREQ(bn, e);
p = mfree(p);
- r = search_and_fopen("/a/file/which/does/not/exist/i/guess", "re", NULL, (const char**) dirs, &f, &p);
- assert_se(r == -ENOENT);
- r = search_and_fopen("/a/file/which/does/not/exist/i/guess", NULL, NULL, (const char**) dirs, NULL, &p);
- assert_se(r == -ENOENT);
- r = search_and_fopen("afilewhichdoesnotexistiguess", "re", NULL, (const char**) dirs, &f, &p);
- assert_se(r == -ENOENT);
- r = search_and_fopen("afilewhichdoesnotexistiguess", NULL, NULL, (const char**) dirs, NULL, &p);
- assert_se(r == -ENOENT);
+ ASSERT_ERROR(search_and_fopen("/a/file/which/does/not/exist/i/guess", "re", NULL, (const char**) dirs, &f, &p), ENOENT);
+ ASSERT_ERROR(search_and_fopen("/a/file/which/does/not/exist/i/guess", NULL, NULL, (const char**) dirs, NULL, &p), ENOENT);
+ ASSERT_ERROR(search_and_fopen("afilewhichdoesnotexistiguess", "re", NULL, (const char**) dirs, &f, &p), ENOENT);
+ ASSERT_ERROR(search_and_fopen("afilewhichdoesnotexistiguess", NULL, NULL, (const char**) dirs, NULL, &p), ENOENT);
r = unlink(name);
assert_se(r == 0);
- r = search_and_fopen(basename(name), "re", NULL, (const char**) dirs, &f, &p);
- assert_se(r == -ENOENT);
- r = search_and_fopen(basename(name), NULL, NULL, (const char**) dirs, NULL, &p);
- assert_se(r == -ENOENT);
+ ASSERT_ERROR(search_and_fopen(bn, "re", NULL, (const char**) dirs, &f, &p), ENOENT);
+ ASSERT_ERROR(search_and_fopen(bn, NULL, NULL, (const char**) dirs, NULL, &p), ENOENT);
}
TEST(search_and_fopen_nulstr) {
_cleanup_(unlink_tempfilep) char name[] = "/tmp/test-search_and_fopen.XXXXXX";
_cleanup_fclose_ FILE *f = NULL;
- _cleanup_free_ char *p = NULL;
+ _cleanup_free_ char *p = NULL, *bn = NULL;
_cleanup_close_ int fd = -EBADF;
const char *e;
int r;
assert_se(fd >= 0);
fd = safe_close(fd);
- r = search_and_fopen_nulstr(basename(name), "re", NULL, dirs, &f, &p);
- assert_se(r >= 0);
+ ASSERT_OK(path_extract_filename(name, &bn));
+ ASSERT_OK(search_and_fopen_nulstr(bn, "re", NULL, dirs, &f, &p));
assert_se(e = path_startswith(p, "/tmp/"));
- ASSERT_STREQ(basename(name), e);
+ ASSERT_STREQ(bn, e);
f = safe_fclose(f);
p = mfree(p);
- r = search_and_fopen_nulstr(name, "re", NULL, dirs, &f, &p);
- assert_se(r >= 0);
+ ASSERT_OK(search_and_fopen_nulstr(name, "re", NULL, dirs, &f, &p));
assert_se(path_equal(name, p));
f = safe_fclose(f);
p = mfree(p);
- r = search_and_fopen_nulstr("/a/file/which/does/not/exist/i/guess", "re", NULL, dirs, &f, &p);
- assert_se(r == -ENOENT);
- r = search_and_fopen_nulstr("afilewhichdoesnotexistiguess", "re", NULL, dirs, &f, &p);
- assert_se(r == -ENOENT);
+ ASSERT_ERROR(search_and_fopen_nulstr("/a/file/which/does/not/exist/i/guess", "re", NULL, dirs, &f, &p), ENOENT);
+ ASSERT_ERROR(search_and_fopen_nulstr("afilewhichdoesnotexistiguess", "re", NULL, dirs, &f, &p), ENOENT);
r = unlink(name);
assert_se(r == 0);
- r = search_and_fopen_nulstr(basename(name), "re", NULL, dirs, &f, &p);
- assert_se(r == -ENOENT);
+ ASSERT_ERROR(search_and_fopen_nulstr(bn, "re", NULL, dirs, &f, &p), ENOENT);
}
TEST(writing_tmpfile) {
#include "hashmap.h"
#include "install.h"
#include "mkdir.h"
+#include "path-util.h"
#include "rm-rf.h"
#include "special.h"
#include "string-util.h"
q = strjoina(root, "/usr/lib/systemd/system/preset-no.service");
HASHMAP_FOREACH(fl, h) {
- assert_se(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, root, basename(fl->path), &state) >= 0);
+ _cleanup_free_ char *unit_filename = NULL;
+
+ ASSERT_OK(path_extract_filename(fl->path, &unit_filename));
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, root, unit_filename, &state));
assert_se(fl->state == state);
if (streq(fl->path, p)) {
#include "hashmap.h"
#include "install.h"
+#include "path-util.h"
#include "tests.h"
static void dump_changes(InstallChange *c, unsigned n) {
UnitFileList *p;
int r;
const char *const files[] = { "avahi-daemon.service", NULL };
+ const char *files_name = "avahi-daemon.service";
const char *const files2[] = { "/home/lennart/test.service", NULL };
+ const char *files2_name = "test.service";
InstallChange *changes = NULL;
size_t n_changes = 0;
UnitFileState state = 0;
HASHMAP_FOREACH(p, h) {
UnitFileState s = _UNIT_FILE_STATE_INVALID;
+ _cleanup_free_ char *unit_filename = NULL;
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(p->path), &s);
+ ASSERT_OK(path_extract_filename(p->path, &unit_filename));
+ r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, unit_filename, &s);
assert_se((r < 0 && p->state == UNIT_FILE_BAD) ||
(p->state == s));
log_info("/*** enable **/");
- r = unit_file_enable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_enable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
log_info("/*** enable2 **/");
- r = unit_file_enable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_enable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_ENABLED);
log_info("/*** disable ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_DISABLED);
log_info("/*** mask ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_mask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_mask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
log_info("/*** mask2 ***/");
- r = unit_file_mask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_mask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_MASKED);
log_info("/*** unmask ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_unmask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_unmask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
log_info("/*** unmask2 ***/");
- r = unit_file_unmask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_unmask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_DISABLED);
log_info("/*** mask ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_mask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_mask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_MASKED);
log_info("/*** disable ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
log_info("/*** disable2 ***/");
- r = unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_MASKED);
log_info("/*** umask ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_unmask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_unmask(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files[0], &state));
assert_se(state == UNIT_FILE_DISABLED);
log_info("/*** enable files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_enable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_enable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
assert_se(state == UNIT_FILE_ENABLED);
log_info("/*** disable files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, STRV_MAKE(basename(files2[0])), &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, STRV_MAKE(files2_name), &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r < 0);
+ ASSERT_FAIL(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
log_info("/*** link files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_link(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_link(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
assert_se(state == UNIT_FILE_LINKED);
log_info("/*** disable files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, STRV_MAKE(basename(files2[0])), &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, STRV_MAKE(files2_name), &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r < 0);
+ ASSERT_FAIL(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
log_info("/*** link files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_link(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_link(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
assert_se(state == UNIT_FILE_LINKED);
log_info("/*** reenable files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_reenable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_reenable(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files2, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
assert_se(state == UNIT_FILE_ENABLED);
log_info("/*** disable files2 ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, STRV_MAKE(basename(files2[0])), &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_disable(RUNTIME_SCOPE_SYSTEM, 0, NULL, STRV_MAKE(files2_name), &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files2[0]), &state);
- assert_se(r < 0);
+ ASSERT_FAIL(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files2_name, &state));
log_info("/*** preset files ***/");
changes = NULL;
n_changes = 0;
- r = unit_file_preset(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, UNIT_FILE_PRESET_FULL, &changes, &n_changes);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_preset(RUNTIME_SCOPE_SYSTEM, 0, NULL, (char**) files, UNIT_FILE_PRESET_FULL, &changes, &n_changes));
dump_changes(changes, n_changes);
install_changes_free(changes, n_changes);
- r = unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, basename(files[0]), &state);
- assert_se(r >= 0);
+ ASSERT_OK(unit_file_get_state(RUNTIME_SCOPE_SYSTEM, NULL, files_name, &state));
assert_se(state == UNIT_FILE_ENABLED);
return 0;
TEST(is_mount_point_at) {
_cleanup_(rm_rf_physical_and_freep) char *tmpdir = NULL;
- _cleanup_free_ char *pwd = NULL;
+ _cleanup_free_ char *pwd = NULL, *tmpdir_basename = NULL;
_cleanup_close_ int fd = -EBADF;
int r;
assert_se(fd >= 0);
assert_se(mkdtemp_malloc("/tmp/not-mounted-XXXXXX", &tmpdir) >= 0);
- assert_se(is_mount_point_at(fd, basename(tmpdir), 0) == 0);
- assert_se(is_mount_point_at(fd, strjoina(basename(tmpdir), "/"), 0) == 0);
+ ASSERT_OK(path_extract_filename(tmpdir, &tmpdir_basename));
+ ASSERT_OK_ZERO(is_mount_point_at(fd, tmpdir_basename, 0));
+ ASSERT_OK_ZERO(is_mount_point_at(fd, strjoina(tmpdir_basename, "/"), 0));
safe_close(fd);
fd = open("/proc", O_RDONLY|O_CLOEXEC|O_DIRECTORY|O_NOCTTY);
#include "sd-json.h"
#include "parse-argument.h"
+#include "path-util.h"
#include "stdio-util.h"
#include "tests.h"
}
TEST(parse_path_argument) {
- _cleanup_free_ char *path = NULL;
+ _cleanup_free_ char *path = NULL, *file = NULL;
assert_se(parse_path_argument("help", false, &path) == 0);
- ASSERT_STREQ(basename(path), "help");
+ ASSERT_OK(path_extract_filename(path, &file));
+ ASSERT_STREQ(file, "help");
assert_se(parse_path_argument("/", false, &path) == 0);
ASSERT_STREQ(path, "/");
assert_se( path_is_absolute("/"));
assert_se(!path_is_absolute("./"));
- ASSERT_STREQ(basename("./aa/bb/../file.da."), "file.da.");
- ASSERT_STREQ(basename("/aa///.file"), ".file");
- ASSERT_STREQ(basename("/aa///file..."), "file...");
- ASSERT_STREQ(basename("file.../"), "");
-
assert_se( PATH_IN_SET("/bin", "/", "/bin", "/foo"));
assert_se( PATH_IN_SET("/bin", "/bin"));
assert_se( PATH_IN_SET("/bin", "/foo/bar", "/bin"));
}
TEST(find_executable_full) {
- char *p;
- char* test_file_name;
+ char *p, *bp;
+ _cleanup_free_ char *test_file_name = NULL;
_cleanup_close_ int fd = -EBADF;
char fn[] = "/tmp/test-XXXXXX";
assert_se(find_executable_full("sh", NULL, NULL, true, &p, NULL) == 0);
puts(p);
- ASSERT_STREQ(basename(p), "sh");
+ ASSERT_OK(path_extract_filename(p, &bp));
+ ASSERT_STREQ(bp, "sh");
free(p);
+ free(bp);
assert_se(find_executable_full("sh", NULL, NULL, false, &p, NULL) == 0);
puts(p);
- ASSERT_STREQ(basename(p), "sh");
+ ASSERT_OK(path_extract_filename(p, &bp));
+ ASSERT_STREQ(bp, "sh");
free(p);
+ free(bp);
_cleanup_free_ char *oldpath = NULL;
p = getenv("PATH");
assert_se(find_executable_full("sh", NULL, NULL, true, &p, NULL) == 0);
puts(p);
- ASSERT_STREQ(basename(p), "sh");
+ ASSERT_OK(path_extract_filename(p, &bp));
+ ASSERT_STREQ(bp, "sh");
free(p);
+ free(bp);
assert_se(find_executable_full("sh", NULL, NULL, false, &p, NULL) == 0);
puts(p);
- ASSERT_STREQ(basename(p), "sh");
+ ASSERT_OK(path_extract_filename(p, &bp));
+ ASSERT_STREQ(bp, "sh");
free(p);
+ free(bp);
if (oldpath)
- assert_se(setenv("PATH", oldpath, true) >= 0);
+ ASSERT_OK_ERRNO(setenv("PATH", oldpath, true));
- assert_se((fd = mkostemp_safe(fn)) >= 0);
- assert_se(fchmod(fd, 0755) >= 0);
+ ASSERT_OK(fd = mkostemp_safe(fn));
+ ASSERT_OK_ERRNO(fchmod(fd, 0755));
- test_file_name = basename(fn);
+ ASSERT_OK(path_extract_filename(fn, &test_file_name));
assert_se(find_executable_full(test_file_name, NULL, STRV_MAKE("/doesnotexist", "/tmp", "/bin"), false, &p, NULL) == 0);
puts(p);
TEST(find_executable) {
char *p;
+ _cleanup_free_ char *bp = NULL;
assert_se(find_executable("/bin/sh", &p) == 0);
puts(p);
assert_se(find_executable("touch", &p) == 0);
assert_se(path_is_absolute(p));
- ASSERT_STREQ(basename(p), "touch");
+ ASSERT_OK(path_extract_filename(p, &bp));
+ ASSERT_STREQ(bp, "touch");
free(p);
assert_se(find_executable("xxxx-xxxx", &p) == -ENOENT);
int link_load_one(LinkConfigContext *ctx, const char *filename) {
_cleanup_(link_config_freep) LinkConfig *config = NULL;
_cleanup_hashmap_free_ Hashmap *stats_by_path = NULL;
- _cleanup_free_ char *name = NULL;
+ _cleanup_free_ char *name = NULL, *file_basename = NULL;
const char *dropin_dirname;
int r;
FOREACH_ELEMENT(feature, config->features)
*feature = -1;
- dropin_dirname = strjoina(basename(filename), ".d");
+ r = path_extract_filename(filename, &file_basename);
+ if (r < 0)
+ return log_error_errno(r, "Failed to extract file name of '%s': %m", filename);
+
+ dropin_dirname = strjoina(file_basename, ".d");
r = config_parse_many(
STRV_MAKE_CONST(filename),
NETWORK_DIRS,