mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 20:29:39 +08:00

When I applied r356500 (https://reviews.llvm.org/D59152), I somehow deleted all of filesystem's tests. I will revert r356500 and re-apply it properly. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@356505 91177308-0d34-0410-b5e6-96231b3b80d8
47 lines
1.3 KiB
C++
47 lines
1.3 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03
|
|
|
|
// <filesystem>
|
|
|
|
// class file_status
|
|
|
|
// file_type type() const noexcept;
|
|
// perms permissions(p) const noexcept;
|
|
|
|
#include "filesystem_include.hpp"
|
|
#include <type_traits>
|
|
#include <cassert>
|
|
|
|
|
|
int main(int, char**) {
|
|
using namespace fs;
|
|
|
|
const file_status st(file_type::regular, perms::owner_read);
|
|
|
|
// type test
|
|
{
|
|
static_assert(noexcept(st.type()),
|
|
"operation must be noexcept");
|
|
static_assert(std::is_same<decltype(st.type()), file_type>::value,
|
|
"operation must return file_type");
|
|
assert(st.type() == file_type::regular);
|
|
}
|
|
// permissions test
|
|
{
|
|
static_assert(noexcept(st.permissions()),
|
|
"operation must be noexcept");
|
|
static_assert(std::is_same<decltype(st.permissions()), perms>::value,
|
|
"operation must return perms");
|
|
assert(st.permissions() == perms::owner_read);
|
|
}
|
|
|
|
return 0;
|
|
}
|