diff options
| author | Lennart Poettering <lennart@poettering.net> | 2015-11-30 17:53:39 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2015-11-30 17:53:39 +0100 | 
| commit | a00405285e5ee25d7532f66f470b0bb7fb8df7de (patch) | |
| tree | e5acf9d862a5f60887f138a235816860d90add49 /src/test/test-acl-util.c | |
| parent | 3a89c3a0fcff52d02608da7d4f7d8183d620995b (diff) | |
| parent | afae249efa4774c6676738ac5de6aeb4daf4889f (diff) | |
Merge pull request #2063 from keszybz/issue-1977-2
journal: clean up permission setting and acl adjustements on user journals
Diffstat (limited to 'src/test/test-acl-util.c')
| -rw-r--r-- | src/test/test-acl-util.c | 85 | 
1 files changed, 85 insertions, 0 deletions
| diff --git a/src/test/test-acl-util.c b/src/test/test-acl-util.c new file mode 100644 index 0000000000..bdea04d7f0 --- /dev/null +++ b/src/test/test-acl-util.c @@ -0,0 +1,85 @@ +/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ + +/*** +  This file is part of systemd. + +  Copyright 2015 Zbigniew Jędrzejewski-Szmek + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU Lesser General Public License as published by +  the Free Software Foundation; either version 2.1 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  Lesser General Public License for more details. + +  You should have received a copy of the GNU Lesser General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +***/ + +#include <fcntl.h> +#include <stdlib.h> +#include <sys/stat.h> +#include <unistd.h> + +#include "acl-util.h" +#include "fd-util.h" +#include "fileio.h" +#include "string-util.h" +#include "user-util.h" + +static void test_add_acls_for_user(void) { +        char fn[] = "/tmp/test-empty.XXXXXX"; +        _cleanup_close_ int fd = -1; +        char *cmd; +        uid_t uid; +        int r; + +        fd = mkostemp_safe(fn, O_RDWR|O_CLOEXEC); +        assert_se(fd >= 0); + +        /* Use the mode that user journal files use */ +        assert(fchmod(fd, 0640) == 0); + +        cmd = strjoina("ls -l ", fn); +        assert_se(system(cmd) == 0); + +        cmd = strjoina("getfacl -p ", fn); +        assert_se(system(cmd) == 0); + +        if (getuid() == 0) { +                const char *nobody = "nobody"; +                r = get_user_creds(&nobody, &uid, NULL, NULL, NULL); +                if (r < 0) +                        uid = 0; +        } else +                uid = getuid(); + +        r = add_acls_for_user(fd, uid); +        assert_se(r >= 0); + +        cmd = strjoina("ls -l ", fn); +        assert_se(system(cmd) == 0); + +        cmd = strjoina("getfacl -p ", fn); +        assert_se(system(cmd) == 0); + +        /* set the acls again */ + +        r = add_acls_for_user(fd, uid); +        assert_se(r >= 0); + +        cmd = strjoina("ls -l ", fn); +        assert_se(system(cmd) == 0); + +        cmd = strjoina("getfacl -p ", fn); +        assert_se(system(cmd) == 0); + +        unlink(fn); +} + +int main(int argc, char **argv) { +        test_add_acls_for_user(); +} | 
