summaryrefslogtreecommitdiff
path: root/test/std/strings/basic.string/string.cons/alloc.pass.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/std/strings/basic.string/string.cons/alloc.pass.cpp')
-rw-r--r--test/std/strings/basic.string/string.cons/alloc.pass.cpp96
1 files changed, 0 insertions, 96 deletions
diff --git a/test/std/strings/basic.string/string.cons/alloc.pass.cpp b/test/std/strings/basic.string/string.cons/alloc.pass.cpp
deleted file mode 100644
index 9e3fb07226044..0000000000000
--- a/test/std/strings/basic.string/string.cons/alloc.pass.cpp
+++ /dev/null
@@ -1,96 +0,0 @@
-//===----------------------------------------------------------------------===//
-//
-// 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.
-//
-//===----------------------------------------------------------------------===//
-
-// <string>
-
-// explicit basic_string(const Allocator& a = Allocator());
-
-#include <string>
-#include <cassert>
-
-#include "test_macros.h"
-#include "test_allocator.h"
-#include "min_allocator.h"
-
-template <class S>
-void
-test()
-{
- {
-#if TEST_STD_VER > 14
- static_assert((noexcept(S{})), "" );
-#elif TEST_STD_VER >= 11
- static_assert((noexcept(S()) == noexcept(typename S::allocator_type())), "" );
-#endif
- S s;
- LIBCPP_ASSERT(s.__invariants());
- assert(s.data());
- assert(s.size() == 0);
- assert(s.capacity() >= s.size());
- assert(s.get_allocator() == typename S::allocator_type());
- }
- {
-#if TEST_STD_VER > 14
- static_assert((noexcept(S{typename S::allocator_type{}})), "" );
-#elif TEST_STD_VER >= 11
- static_assert((noexcept(S(typename S::allocator_type())) == std::is_nothrow_copy_constructible<typename S::allocator_type>::value), "" );
-#endif
- S s(typename S::allocator_type(5));
- LIBCPP_ASSERT(s.__invariants());
- assert(s.data());
- assert(s.size() == 0);
- assert(s.capacity() >= s.size());
- assert(s.get_allocator() == typename S::allocator_type(5));
- }
-}
-
-#if TEST_STD_VER >= 11
-
-template <class S>
-void
-test2()
-{
- {
-#if TEST_STD_VER > 14
- static_assert((noexcept(S{})), "" );
-#elif TEST_STD_VER >= 11
- static_assert((noexcept(S()) == noexcept(typename S::allocator_type())), "" );
-#endif
- S s;
- LIBCPP_ASSERT(s.__invariants());
- assert(s.data());
- assert(s.size() == 0);
- assert(s.capacity() >= s.size());
- assert(s.get_allocator() == typename S::allocator_type());
- }
- {
-#if TEST_STD_VER > 14
- static_assert((noexcept(S{typename S::allocator_type{}})), "" );
-#elif TEST_STD_VER >= 11
- static_assert((noexcept(S(typename S::allocator_type())) == std::is_nothrow_copy_constructible<typename S::allocator_type>::value), "" );
-#endif
- S s(typename S::allocator_type{});
- LIBCPP_ASSERT(s.__invariants());
- assert(s.data());
- assert(s.size() == 0);
- assert(s.capacity() >= s.size());
- assert(s.get_allocator() == typename S::allocator_type());
- }
-}
-
-#endif
-
-int main()
-{
- test<std::basic_string<char, std::char_traits<char>, test_allocator<char> > >();
-#if TEST_STD_VER >= 11
- test2<std::basic_string<char, std::char_traits<char>, min_allocator<char> > >();
- test2<std::basic_string<char, std::char_traits<char>, explicit_allocator<char> > >();
-#endif
-}