
The libc++ test suite has a lot of old Lit features used to XFAIL tests and mark them as UNSUPPORTED. Many of them are to workaround problems on old compilers or old platforms. As time goes by, it is good to go and clean those up to simplify the configuration of the test suite, and also to reflect the testing reality. It's not useful to have markup that gives the impression that e.g. clang-3.3 is supported, when we don't really test on it anymore (and hence several new tests probably don't have the necessary markup on them).
38 lines
1.2 KiB
C++
38 lines
1.2 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Due to C++17 inline variables ASAN flags this test as containing an ODR
|
|
// violation because Clock::is_steady is defined in both the dylib and this TU.
|
|
// UNSUPPORTED: asan
|
|
|
|
// <chrono>
|
|
|
|
// system_clock
|
|
|
|
// check clock invariants
|
|
|
|
#include <chrono>
|
|
|
|
#include "test_macros.h"
|
|
|
|
template <class T>
|
|
void test(const T &) {}
|
|
|
|
int main(int, char**)
|
|
{
|
|
typedef std::chrono::system_clock C;
|
|
static_assert((std::is_same<C::rep, C::duration::rep>::value), "");
|
|
static_assert((std::is_same<C::period, C::duration::period>::value), "");
|
|
static_assert((std::is_same<C::duration, C::time_point::duration>::value), "");
|
|
static_assert((std::is_same<C::time_point::clock, C>::value), "");
|
|
static_assert((C::is_steady || !C::is_steady), "");
|
|
test(std::chrono::system_clock::is_steady);
|
|
|
|
return 0;
|
|
}
|