diff options
author | Eric Fiselier <eric@efcs.ca> | 2016-06-21 22:42:42 +0000 |
---|---|---|
committer | Eric Fiselier <eric@efcs.ca> | 2016-06-21 22:42:42 +0000 |
commit | 7c96ddb5639078164a3fe8bcfbf7a11d7f502afb (patch) | |
tree | b0b801e68b60672cfdf67815b85cb344c22d33bb /test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp | |
parent | 756a6bd1776c371a33fff55bf5f85aebeb61ccd8 (diff) | |
download | libcxx-7c96ddb5639078164a3fe8bcfbf7a11d7f502afb.tar.gz |
Implement LWG issue 2720. Replace perms::resolve_symlinks with perms::symlink_nofollow.
This changes how filesystem::permissions(p, perms) handles symlinks. Previously
symlinks were not resolved by default instead only getting resolved when
"perms::resolve_symlinks" was used. After this change symlinks are resolved
by default and perms::symlink_nofollow must be given to change this.
This issue has not yet been moved to Ready status, and I will revert if it
doesn't get moved at the current meeting. However I feel confident that it
will and it's nice to have implementations when moving issues.
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@273328 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp')
-rw-r--r-- | test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp b/test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp index 7b3013a4d..b177693c0 100644 --- a/test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp +++ b/test/std/experimental/filesystem/fs.op.funcs/fs.op.permissions/permissions.pass.cpp @@ -67,9 +67,9 @@ TEST_CASE(test_error_reporting) } { std::error_code ec; - fs::permissions(dne_sym, perms::resolve_symlinks, ec); + fs::permissions(dne_sym, fs::perms{}, ec); TEST_REQUIRE(ec); - TEST_CHECK(checkThrow(dne_sym, perms::resolve_symlinks, ec)); + TEST_CHECK(checkThrow(dne_sym, fs::perms{}, ec)); } } @@ -82,7 +82,7 @@ TEST_CASE(basic_permissions_test) const path sym = env.create_symlink(file_for_sym, "sym"); const perms AP = perms::add_perms; const perms RP = perms::remove_perms; - const perms RS = perms::resolve_symlinks; + const perms NF = perms::symlink_nofollow; struct TestCase { path p; perms set_perms; @@ -98,11 +98,15 @@ TEST_CASE(basic_permissions_test) {dir, perms::owner_all, perms::owner_all}, {dir, perms::group_all | AP, perms::owner_all | perms::group_all}, {dir, perms::group_all | RP, perms::owner_all}, - // test symlink with resolve symlinks on symlink - {sym, perms::none | RS, perms::none}, - {sym, perms::owner_all | RS, perms::owner_all}, - {sym, perms::group_all | AP | RS, perms::owner_all | perms::group_all}, - {sym, perms::group_all | RP | RS, perms::owner_all} + // test symlink without symlink_nofollow + {sym, perms::none, perms::none}, + {sym, perms::owner_all, perms::owner_all}, + {sym, perms::group_all | AP, perms::owner_all | perms::group_all}, + {sym, perms::group_all | RP , perms::owner_all}, + // test non-symlink with symlink_nofollow. The last test on file/dir + // will have set their permissions to perms::owner_all + {file, perms::group_all | AP | NF, perms::owner_all | perms::group_all}, + {dir, perms::group_all | AP | NF, perms::owner_all | perms::group_all} }; for (auto const& TC : cases) { TEST_CHECK(status(TC.p).permissions() != TC.expected); @@ -144,7 +148,7 @@ TEST_CASE(test_no_resolve_symlink_on_symlink) std::error_code expected_ec = std::make_error_code(std::errc::operation_not_supported); #endif std::error_code ec = std::make_error_code(std::errc::bad_address); - permissions(sym, TC.set_perms, ec); + permissions(sym, TC.set_perms | perms::symlink_nofollow, ec); TEST_CHECK(ec == expected_ec); TEST_CHECK(status(file).permissions() == file_perms); TEST_CHECK(symlink_status(sym).permissions() == expected_link_perms); |