test-btrfs.c revision d9e2daaf3d8649650cf9784b4fe9d9de4507da0c
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering This file is part of systemd.
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering Copyright 2014 Lennart Poettering
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering systemd is free software; you can redistribute it and/or modify it
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering under the terms of the GNU Lesser General Public License as published by
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering the Free Software Foundation; either version 2.1 of the License, or
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering (at your option) any later version.
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering systemd is distributed in the hope that it will be useful, but
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering WITHOUT ANY WARRANTY; without even the implied warranty of
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering Lesser General Public License for more details.
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering You should have received a copy of the GNU Lesser General Public License
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering along with systemd; If not, see <http://www.gnu.org/licenses/>.
10f9c75519671e7c7ab8993b54fe22da7c2d0c38Lennart Poettering fd = open("/", O_RDONLY|O_CLOEXEC|O_DIRECTORY);
10f9c75519671e7c7ab8993b54fe22da7c2d0c38Lennart Poettering log_error_errno(errno, "Failed to open root directory: %m");
b6b1849830f5e4a6065c3b0c993668e500c954d3Lennart Poettering char ts[FORMAT_TIMESTAMP_MAX], bs[FORMAT_BYTES_MAX];
10f9c75519671e7c7ab8993b54fe22da7c2d0c38Lennart Poettering log_error_errno(r, "Failed to get subvolume info: %m");
10f9c75519671e7c7ab8993b54fe22da7c2d0c38Lennart Poettering log_info("otime: %s", format_timestamp(ts, sizeof(ts), info.otime));
c75f27ea2b483f91d437ebaf8494457dc76f3fd6Lennart Poettering log_info("read-only (search): %s", yes_no(info.read_only));
b6b1849830f5e4a6065c3b0c993668e500c954d3Lennart Poettering r = btrfs_subvol_get_quota_fd(fd, "a);
b6b1849830f5e4a6065c3b0c993668e500c954d3Lennart Poettering log_error_errno(r, "Failed to get quota info: %m");
cb81cd8073392936882643af0129934bf67e96c4Lennart Poettering log_info("referenced: %s", strna(format_bytes(bs, sizeof(bs), quota.referenced)));
b6b1849830f5e4a6065c3b0c993668e500c954d3Lennart Poettering log_info("exclusive: %s", strna(format_bytes(bs, sizeof(bs), quota.exclusive)));
cb81cd8073392936882643af0129934bf67e96c4Lennart Poettering log_info("referenced_max: %s", strna(format_bytes(bs, sizeof(bs), quota.referenced_max)));
b6b1849830f5e4a6065c3b0c993668e500c954d3Lennart Poettering log_info("exclusive_max: %s", strna(format_bytes(bs, sizeof(bs), quota.exclusive_max)));
c75f27ea2b483f91d437ebaf8494457dc76f3fd6Lennart Poettering log_error_errno(r, "Failed to get read only flag: %m");
c75f27ea2b483f91d437ebaf8494457dc76f3fd6Lennart Poettering log_info("read-only (ioctl): %s", yes_no(r));
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering r = write_string_file("/xxxtest/afile", "ljsadhfljasdkfhlkjdsfha");
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to write file: %m");
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering r = btrfs_subvol_snapshot("/xxxtest", "/xxxtest2", false, false);
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to make snapshot: %m");
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering r = btrfs_subvol_snapshot("/xxxtest", "/xxxtest3", true, false);
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to make snapshot: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_remove("/xxxtest", false);
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to remove subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_remove("/xxxtest2", false);
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to remove subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_remove("/xxxtest3", false);
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to remove subvolume: %m");
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering r = btrfs_subvol_snapshot("/etc", "/etc2", true, true);
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to make snapshot: %m");
d7c7c334f56edab8cfc102b657366277a65738cfLennart Poettering log_error_errno(r, "Failed to remove subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_make("/xxxrectest/xxxrectest2");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_make("/xxxrectest/xxxrectest3");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_make("/xxxrectest/xxxrectest3/sub");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(errno, "Failed to make directory: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_make("/xxxrectest/dir/xxxrectest4");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering if (mkdir("/xxxrectest/dir/xxxrectest4/dir", 0755) < 0)
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(errno, "Failed to make directory: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_make("/xxxrectest/dir/xxxrectest4/dir/xxxrectest5");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to make subvolume: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(errno, "Failed to make directory: %m");
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering r = btrfs_subvol_remove("/xxxrectest", true);
d9e2daaf3d8649650cf9784b4fe9d9de4507da0cLennart Poettering log_error_errno(r, "Failed to recursively remove subvolume: %m");