//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // UNSUPPORTED: libcpp-has-no-threads // // class promise // template // promise(allocator_arg_t, const Allocator& a); #include #include #include "../test_allocator.h" #include "min_allocator.h" int main() { assert(test_alloc_base::count == 0); { std::promise p(std::allocator_arg, test_allocator()); assert(test_alloc_base::count == 1); std::future f = p.get_future(); assert(test_alloc_base::count == 1); assert(f.valid()); } assert(test_alloc_base::count == 0); { std::promise p(std::allocator_arg, test_allocator()); assert(test_alloc_base::count == 1); std::future f = p.get_future(); assert(test_alloc_base::count == 1); assert(f.valid()); } assert(test_alloc_base::count == 0); { std::promise p(std::allocator_arg, test_allocator()); assert(test_alloc_base::count == 1); std::future f = p.get_future(); assert(test_alloc_base::count == 1); assert(f.valid()); } assert(test_alloc_base::count == 0); // Test with a minimal allocator { std::promise p(std::allocator_arg, bare_allocator()); std::future f = p.get_future(); assert(f.valid()); } { std::promise p(std::allocator_arg, bare_allocator()); std::future f = p.get_future(); assert(f.valid()); } { std::promise p(std::allocator_arg, bare_allocator()); std::future f = p.get_future(); assert(f.valid()); } // Test with a minimal allocator that returns class-type pointers { std::promise p(std::allocator_arg, min_allocator()); std::future f = p.get_future(); assert(f.valid()); } { std::promise p(std::allocator_arg, min_allocator()); std::future f = p.get_future(); assert(f.valid()); } { std::promise p(std::allocator_arg, min_allocator()); std::future f = p.get_future(); assert(f.valid()); } }