These two tests were clumsily using time measurements to determine whether std::lock_guard was working correctly. In practice, this approach merely verified that the underlying lock properly waits. Now these two tests verify that lock is acquired, not dropped prematurely, and finally, actually dropped at the end of the scope.
45 lines
992 B
C++
45 lines
992 B
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: libcpp-has-no-threads
|
|
|
|
// <mutex>
|
|
|
|
// template <class Mutex> class lock_guard;
|
|
|
|
// explicit lock_guard(mutex_type& m);
|
|
|
|
// template<class _Mutex> lock_guard(lock_guard<_Mutex>)
|
|
// -> lock_guard<_Mutex>; // C++17
|
|
|
|
#include <mutex>
|
|
#include <cstdlib>
|
|
#include <cassert>
|
|
|
|
#include "test_macros.h"
|
|
|
|
std::mutex m;
|
|
|
|
int main()
|
|
{
|
|
{
|
|
std::lock_guard<std::mutex> lg(m);
|
|
assert(m.try_lock() == false);
|
|
}
|
|
|
|
m.lock();
|
|
m.unlock();
|
|
|
|
#ifdef __cpp_deduction_guides
|
|
std::lock_guard lg(m);
|
|
static_assert((std::is_same<decltype(lg), std::lock_guard<decltype(m)>>::value), "" );
|
|
#endif
|
|
|
|
return 0;
|
|
}
|