diff options
author | Daan De Meyer <daan.j.demeyer@gmail.com> | 2023-03-09 12:59:09 +0100 |
---|---|---|
committer | Daan De Meyer <daan.j.demeyer@gmail.com> | 2023-03-21 15:19:33 +0100 |
commit | aea3ca36135aeb74ea38e7538c710d92b37f479d (patch) | |
tree | ec315249081da1eda7f0bf2c59dd6cb740c06c72 /src/test/test-lock-util.c | |
parent | Merge pull request #26893 from yuwata/uki-util-update-log (diff) | |
download | systemd-aea3ca36135aeb74ea38e7538c710d92b37f479d.tar.xz systemd-aea3ca36135aeb74ea38e7538c710d92b37f479d.zip |
lock-util: Add make_lock_file_at()
Diffstat (limited to 'src/test/test-lock-util.c')
-rw-r--r-- | src/test/test-lock-util.c | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/src/test/test-lock-util.c b/src/test/test-lock-util.c new file mode 100644 index 0000000000..a9a1b438ff --- /dev/null +++ b/src/test/test-lock-util.c @@ -0,0 +1,37 @@ +/* SPDX-License-Identifier: LGPL-2.1-or-later */ + +#include <unistd.h> + +#include "fd-util.h" +#include "lock-util.h" +#include "rm-rf.h" +#include "tests.h" +#include "tmpfile-util.h" + +TEST(make_lock_file) { + _cleanup_(rm_rf_physical_and_freep) char *t = NULL; + _cleanup_close_ int tfd = -EBADF; + _cleanup_(release_lock_file) LockFile lock1 = LOCK_FILE_INIT, lock2 = LOCK_FILE_INIT; + + assert_se((tfd = mkdtemp_open(NULL, 0, &t)) >= 0); + + assert_se(make_lock_file_at(tfd, "lock", LOCK_EX, &lock1) >= 0); + assert_se(faccessat(tfd, "lock", F_OK, 0) >= 0); + assert_se(make_lock_file_at(tfd, "lock", LOCK_EX|LOCK_NB, &lock2) == -EBUSY); + release_lock_file(&lock1); + assert_se(RET_NERRNO(faccessat(tfd, "lock", F_OK, 0)) == -ENOENT); + assert_se(make_lock_file_at(tfd, "lock", LOCK_EX, &lock2) >= 0); + release_lock_file(&lock2); + assert_se(make_lock_file_at(tfd, "lock", LOCK_SH, &lock1) >= 0); + assert_se(faccessat(tfd, "lock", F_OK, 0) >= 0); + assert_se(make_lock_file_at(tfd, "lock", LOCK_SH, &lock2) >= 0); + release_lock_file(&lock1); + assert_se(faccessat(tfd, "lock", F_OK, 0) >= 0); + release_lock_file(&lock2); + + assert_se(fchdir(tfd) >= 0); + assert_se(make_lock_file_at(tfd, "lock", LOCK_EX, &lock1) >= 0); + assert_se(make_lock_file("lock", LOCK_EX|LOCK_NB, &lock2) == -EBUSY); +} + +DEFINE_TEST_MAIN(LOG_INFO); |