xref: /llvm-project/libcxx/test/std/containers/associative/set/set.cons/from_range.pass.cpp (revision ef70fe4d264d20abdd8476605650479a96a62071)
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 // UNSUPPORTED: c++03, c++11, c++14, c++17, c++20
10 
11 // template<container-compatible-range<value_type> R>
12 //   set(from_range_t, R&& rg, const Compare& comp = Compare(), const Allocator& = Allocator()); // C++23
13 //
14 // template<container-compatible-range<value_type> R>
15 //   set(from_range_t, R&& rg, const Allocator& a))
16 //     : set(from_range, std::forward<R>(rg), Compare(), a) { } // C++23
17 
18 #include <array>
19 #include <set>
20 
21 #include "../../from_range_associative_containers.h"
22 #include "test_macros.h"
23 
test_duplicates()24 void test_duplicates() {
25   using T = KeyValue;
26 
27   std::array input = {
28     T{1, 'a'}, T{2, 'a'}, T{3, 'a'}, T{3, 'b'}, T{3, 'c'}, T{2, 'b'}, T{4, 'a'}
29   };
30   std::array expected = {
31     T{1, 'a'}, T{2, 'b'}, T{3, 'c'}, T{4, 'a'}
32   };
33   auto c = std::set<T>(std::from_range, input);
34   assert(std::ranges::is_permutation(expected, c));
35 }
36 
main(int,char **)37 int main(int, char**) {
38   for_all_iterators_and_allocators<int>([]<class Iter, class Sent, class Alloc>() {
39     test_associative_set<std::set, int, Iter, Sent, test_less<int>, Alloc>();
40   });
41   test_associative_set_move_only<std::set>();
42   test_duplicates();
43 
44   static_assert(test_set_constraints<std::set, int, double>());
45 
46   test_set_exception_safety_throwing_copy<std::set>();
47   test_set_exception_safety_throwing_allocator<std::set, int>();
48 
49   return 0;
50 }
51