libstdc++: testsuite: conditionalize symlink tests
Several filesystem tests expect to be able to create symlinks even when !defined (_GLIBCXX_HAVE_SYMLINK), and fail predictably, reducing the amount of testing of other filesystem features. They are already skipped for mingw targets. I've extended the skipping to other targets in which _GLIBCXX_HAVE_SYMLINK is undefined, through a new NO_SYMLINKS macro in testsuite_fs.h that guards skippable portions of tests, and dg-require-target-fs-symlinks for tests that would be reduced to nothing. for libstdc++-v3/ChangeLog * testsuite/util/testsuite_fs.h (NO_SYMLINKS): Define on mingw and when create_symlink is a dummy. * testsuite/27_io/filesystem/operations/symlink_status.cc: Drop mingw xfail. (test01, test02): Don't create symlinks when NO_SYMLINKS is defined. * testsuite/27_io/filesystem/operations/canonical.cc (test03): Likewise. * testsuite/27_io/filesystem/operations/copy.cc (test02): Likewise. * testsuite/27_io/filesystem/operations/create_directories.cc (test04): Likewise. * testsuite/27_io/filesystem/operations/create_directory.cc (test01): Likewise. * testsuite/27_io/filesystem/operations/permissions.cc (test03, test04): Likewise. * testsuite/27_io/filesystem/operations/remove.cc (test01): Likewise. * testsuite/27_io/filesystem/operations/remove_all.cc (test01): Likewise. * testsuite/27_io/filesystem/operations/rename.cc (test_symlinks): Likewise. * testsuite/27_io/filesystem/operations/weakly_canonical.cc (test01): Likewise. * testsuite/experimental/filesystem/iterators/recursive_directory_iterator.cc (test06): Likewise. * testsuite/experimental/filesystem/operations/copy.cc (test01): Likewise. * testsuite/experimental/filesystem/operations/create_directories.cc (test04): Likewise. * testsuite/experimental/filesystem/operations/create_directory.cc (test01): Likewise. * testsuite/experimental/filesystem/operations/permissions.cc (test03, test04): Likewise. * testsuite/experimental/filesystem/operations/remove.cc (test01): Likewise. * testsuite/experimental/filesystem/operations/remove_all.cc (test01): Likewise. * testsuite/experimental/filesystem/operations/rename.cc (test01): Likewise. * testsuite/lib/libstdc++.exp (v3_check_preprocessor_condition): Add optional inc parameter. Add it to the test program after include bits/c++config.h. (check_v3_target_fs_symlinks): New. * testsuite/lib/dg-options.exp (dg-require-target-fs-symlinks): New. * testsuite/27_io/filesystem/operations/read_symlink.cc: Replace mingw xfail with require target-fs-symlinks. * testsuite/experimental/filesystem/operations/read_symlink.cc: Likewise.
This commit is contained in:
parent
fc2fb4fd54
commit
9f7f25bb35
|
@ -111,9 +111,12 @@ test03()
|
|||
fs::path foo = dir/"foo", bar = dir/"bar";
|
||||
fs::create_directory(foo);
|
||||
fs::create_directory(bar);
|
||||
#ifdef NO_SYMLINKS
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
const fs::path baz = dir/"foo\\\\..\\bar///";
|
||||
#else
|
||||
const fs::path baz = dir/"foo//../bar///";
|
||||
#endif
|
||||
#else
|
||||
fs::create_symlink("../bar", foo/"baz");
|
||||
const fs::path baz = dir/"foo//./baz///";
|
||||
|
|
|
@ -66,11 +66,7 @@ test01()
|
|||
void
|
||||
test02()
|
||||
{
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
return;
|
||||
#endif
|
||||
|
||||
#ifndef NO_SYMLINKS
|
||||
const std::error_code bad_ec = make_error_code(std::errc::invalid_argument);
|
||||
auto from = __gnu_test::nonexistent_path();
|
||||
std::error_code ec;
|
||||
|
@ -110,6 +106,7 @@ test02()
|
|||
|
||||
remove(from, ec);
|
||||
remove(to, ec);
|
||||
#endif
|
||||
}
|
||||
|
||||
// Test is_regular_file(f) case.
|
||||
|
|
|
@ -148,9 +148,7 @@ test03()
|
|||
void
|
||||
test04()
|
||||
{
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// no symlinks
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
// PR libstdc++/101510
|
||||
// create_directories reports an error if the path is a symlink to a dir
|
||||
std::error_code ec = make_error_code(std::errc::invalid_argument);
|
||||
|
|
|
@ -70,9 +70,7 @@ test01()
|
|||
VERIFY( e.path1() == f );
|
||||
}
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// no symlinks
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
// PR libstdc++/101510 create_directory on an existing symlink to a directory
|
||||
fs::create_directory(p/"dir");
|
||||
auto link = p/"link";
|
||||
|
|
|
@ -76,6 +76,7 @@ test02()
|
|||
void
|
||||
test03()
|
||||
{
|
||||
#ifndef NO_SYMLINKS
|
||||
using std::filesystem::perms;
|
||||
using std::filesystem::perm_options;
|
||||
|
||||
|
@ -111,11 +112,13 @@ test03()
|
|||
VERIFY( !caught );
|
||||
|
||||
remove(p);
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
test04()
|
||||
{
|
||||
#ifndef NO_SYMLINKS
|
||||
using perms = std::filesystem::perms;
|
||||
|
||||
auto p = __gnu_test::nonexistent_path();
|
||||
|
@ -137,6 +140,7 @@ test04()
|
|||
VERIFY( ec == ec2 );
|
||||
|
||||
remove(p);
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
|
||||
// { dg-do run { target c++17 } }
|
||||
// { dg-require-filesystem-ts "" }
|
||||
// { dg-xfail-if "symlinks not supported" { *-*-mingw* } }
|
||||
// { dg-require-target-fs-symlinks "" }
|
||||
|
||||
#include <filesystem>
|
||||
#include <testsuite_hooks.h>
|
||||
|
|
|
@ -41,9 +41,7 @@ test01()
|
|||
VERIFY( !ec );
|
||||
VERIFY( !n );
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
auto link = __gnu_test::nonexistent_path();
|
||||
create_symlink(p, link); // dangling symlink
|
||||
ec = bad_ec;
|
||||
|
|
|
@ -41,9 +41,7 @@ test01()
|
|||
VERIFY( !ec );
|
||||
VERIFY( n == 0 );
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
auto link = __gnu_test::nonexistent_path();
|
||||
create_symlink(p, link); // dangling symlink
|
||||
ec = bad_ec;
|
||||
|
|
|
@ -75,9 +75,7 @@ test01()
|
|||
void
|
||||
test_symlinks()
|
||||
{
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
std::error_code ec;
|
||||
const std::error_code bad_ec = make_error_code(std::errc::invalid_argument);
|
||||
|
||||
|
|
|
@ -17,7 +17,6 @@
|
|||
|
||||
// { dg-do run { target c++17 } }
|
||||
// { dg-require-filesystem-ts "" }
|
||||
// { dg-xfail-if "symlinks not supported" { *-*-mingw* } }
|
||||
|
||||
#include <filesystem>
|
||||
#include <testsuite_hooks.h>
|
||||
|
@ -39,6 +38,7 @@ test01()
|
|||
fs::file_status st2 = fs::symlink_status(dot);
|
||||
VERIFY( st2.type() == fs::file_type::directory );
|
||||
|
||||
#ifndef NO_SYMLINKS
|
||||
fs::path link = __gnu_test::nonexistent_path();
|
||||
create_directory_symlink(dot, link);
|
||||
__gnu_test::scoped_file l(link, __gnu_test::scoped_file::adopt_file);
|
||||
|
@ -49,6 +49,7 @@ test01()
|
|||
st2 = fs::symlink_status(link, ec);
|
||||
VERIFY( !ec );
|
||||
VERIFY( st2.type() == fs::file_type::symlink );
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -68,6 +69,7 @@ test02()
|
|||
void
|
||||
test03()
|
||||
{
|
||||
#ifndef NO_SYMLINKS
|
||||
if (!__gnu_test::permissions_are_testable())
|
||||
return;
|
||||
|
||||
|
@ -111,6 +113,7 @@ test03()
|
|||
VERIFY( st2.type() == fs::file_type::symlink );
|
||||
|
||||
fs::permissions(dir, fs::perms::owner_all, ec);
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
|
|
|
@ -39,9 +39,7 @@ test01()
|
|||
fs::create_directory(bar/"baz");
|
||||
fs::path p;
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
fs::create_symlink("../bar", foo/"bar");
|
||||
|
||||
p = fs::weakly_canonical(dir/"foo//./bar///../biz/.");
|
||||
|
|
|
@ -188,7 +188,7 @@ test05()
|
|||
void
|
||||
test06()
|
||||
{
|
||||
#if !(defined __MINGW32__ || defined __MINGW64__)
|
||||
#ifndef NO_SYMLINKS
|
||||
auto p = __gnu_test::nonexistent_path();
|
||||
create_directories(p/"d1/d2");
|
||||
create_directory_symlink("d1", p/"link");
|
||||
|
|
|
@ -67,11 +67,7 @@ test01()
|
|||
void
|
||||
test02()
|
||||
{
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
return;
|
||||
#endif
|
||||
|
||||
#ifndef NO_SYMLINKS
|
||||
auto from = __gnu_test::nonexistent_path();
|
||||
std::error_code ec, bad = std::make_error_code(std::errc::invalid_argument);
|
||||
|
||||
|
@ -109,6 +105,7 @@ test02()
|
|||
|
||||
remove(from, ec);
|
||||
remove(to, ec);
|
||||
#endif
|
||||
}
|
||||
|
||||
// Test is_regular_file(f) case.
|
||||
|
|
|
@ -147,9 +147,7 @@ test03()
|
|||
void
|
||||
test04()
|
||||
{
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// no symlinks
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
// PR libstdc++/101510
|
||||
// create_directories reports an error if the path is a symlink to a dir
|
||||
std::error_code ec = make_error_code(std::errc::invalid_argument);
|
||||
|
|
|
@ -69,9 +69,7 @@ test01()
|
|||
VERIFY( e.path1() == f );
|
||||
}
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// no symlinks
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
// PR libstdc++/101510 create_directory on an existing symlink to a directory
|
||||
fs::create_directory(p/"dir");
|
||||
auto link = p/"link";
|
||||
|
|
|
@ -72,6 +72,7 @@ test02()
|
|||
void
|
||||
test03()
|
||||
{
|
||||
#ifndef NO_SYMLINKS
|
||||
using perms = std::experimental::filesystem::perms;
|
||||
|
||||
__gnu_test::scoped_file f;
|
||||
|
@ -95,11 +96,13 @@ test03()
|
|||
VERIFY( ec == ec2 );
|
||||
|
||||
remove(p);
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
test04()
|
||||
{
|
||||
#ifndef NO_SYMLINKS
|
||||
using perms = std::experimental::filesystem::perms;
|
||||
|
||||
auto p = __gnu_test::nonexistent_path();
|
||||
|
@ -120,6 +123,7 @@ test04()
|
|||
VERIFY( ec == ec2 );
|
||||
|
||||
remove(p);
|
||||
#endif
|
||||
}
|
||||
|
||||
void
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
// { dg-options "-DUSE_FILESYSTEM_TS -lstdc++fs" }
|
||||
// { dg-do run { target c++11 } }
|
||||
// { dg-require-filesystem-ts "" }
|
||||
// { dg-xfail-if "symlinks not supported" { *-*-mingw* } }
|
||||
// { dg-require-target-fs-symlinks "" }
|
||||
|
||||
#include <experimental/filesystem>
|
||||
#include <testsuite_hooks.h>
|
||||
|
|
|
@ -42,10 +42,7 @@ test01()
|
|||
VERIFY( !ec );
|
||||
VERIFY( !n );
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
return;
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
auto link = __gnu_test::nonexistent_path();
|
||||
create_symlink(p, link); // dangling symlink
|
||||
ec = bad_ec;
|
||||
|
|
|
@ -42,9 +42,7 @@ test01()
|
|||
VERIFY( !ec );
|
||||
VERIFY( n == 0 );
|
||||
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
auto link = __gnu_test::nonexistent_path();
|
||||
create_symlink(p, link); // dangling symlink
|
||||
ec = bad_ec;
|
||||
|
|
|
@ -75,9 +75,7 @@ test01()
|
|||
void
|
||||
test_symlinks()
|
||||
{
|
||||
#if defined(__MINGW32__) || defined(__MINGW64__)
|
||||
// No symlink support
|
||||
#else
|
||||
#ifndef NO_SYMLINKS
|
||||
std::error_code ec;
|
||||
const std::error_code bad_ec = make_error_code(std::errc::invalid_argument);
|
||||
|
||||
|
|
|
@ -241,6 +241,15 @@ proc dg-require-filesystem-ts { args } {
|
|||
return
|
||||
}
|
||||
|
||||
proc dg-require-target-fs-symlinks { args } {
|
||||
if { ![ check_v3_target_fs_symlinks ] } {
|
||||
upvar dg-do-what dg-do-what
|
||||
set dg-do-what [list [lindex ${dg-do-what} 0] "N" "P"]
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
proc add_options_for_no_pch { flags } {
|
||||
# This forces any generated and possibly included PCH to be invalid.
|
||||
return "-D__GLIBCXX__=99999999"
|
||||
|
|
|
@ -974,13 +974,16 @@ proc v3_try_preprocess { name code flags } {
|
|||
}
|
||||
|
||||
# Return 1 if COND evaluates to true in the preprocessor, 0 otherwise.
|
||||
# The <bits/c++config.h> config header is included.
|
||||
proc v3_check_preprocessor_condition { name cond } {
|
||||
# The <bits/c++config.h> config header is included, and INC, if given,
|
||||
# is pasted between it and the condition evaluation, so it can be used
|
||||
# for additional #include's.
|
||||
proc v3_check_preprocessor_condition { name cond { inc "" } } {
|
||||
global cxxflags
|
||||
global DEFAULT_CXXFLAGS
|
||||
|
||||
set code "
|
||||
#include <bits/c++config.h>
|
||||
$inc
|
||||
#if ! ($cond)
|
||||
#error '$cond' is false
|
||||
#endif
|
||||
|
@ -1267,6 +1270,14 @@ proc check_v3_target_filesystem_ts { } {
|
|||
}]
|
||||
}
|
||||
|
||||
# Return 1 if the libstdc++ filesystem create_symlinks implementation
|
||||
# is not an always-failing dummy.
|
||||
proc check_v3_target_fs_symlinks { } {
|
||||
set inc "#include <testsuite_fs.h>"
|
||||
set cond "!defined NO_SYMLINKS"
|
||||
return [v3_check_preprocessor_condition fs_symlinks $cond $inc]
|
||||
}
|
||||
|
||||
# Return 1 if the "cxx11" ABI is in use using the current flags, 0 otherwise.
|
||||
# Any flags provided by RUNTESTFLAGS or a target board will be used here.
|
||||
# Flags added in the test by dg-options or dg-add-options will not be used.
|
||||
|
|
|
@ -42,6 +42,10 @@ namespace test_fs = std::experimental::filesystem;
|
|||
#include <random> // std::random_device
|
||||
#endif
|
||||
|
||||
#ifndef _GLIBCXX_HAVE_SYMLINK
|
||||
#define NO_SYMLINKS
|
||||
#endif
|
||||
|
||||
namespace __gnu_test
|
||||
{
|
||||
#define PATH_CHK(p1, p2, fn) \
|
||||
|
|
Loading…
Reference in New Issue