1 /*
2  Copyright (c) 2008-2018, Benoit AUTHEMAN All rights reserved.
3 
4  Redistribution and use in source and binary forms, with or without
5  modification, are permitted provided that the following conditions are met:
6     * Redistributions of source code must retain the above copyright
7       notice, this list of conditions and the following disclaimer.
8     * Redistributions in binary form must reproduce the above copyright
9       notice, this list of conditions and the following disclaimer in the
10       documentation and/or other materials provided with the distribution.
11     * Neither the name of the author or Destrat.io nor the
12       names of its contributors may be used to endorse or promote products
13       derived from this software without specific prior written permission.
14 
15  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18  DISCLAIMED. IN NO EVENT SHALL AUTHOR BE LIABLE FOR ANY
19  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 */
26 
27 //-----------------------------------------------------------------------------
28 // This file is a part of the GTpo software.
29 //
30 // \file	gtpo_containers_tests.cpp
31 // \author	benoit@qanava.org
32 // \date	2016 01 26
33 //-----------------------------------------------------------------------------
34 
35 // STD headers
36 #include <iostream>
37 
38 // GTpo headers
39 #include "../src/container_adapter.h"
40 
41 // Google Test
42 #include <gtest/gtest.h>
43 #include <gmock/gmock.h>
44 
45 using gtpo::std_container_adapter;
46 
47 //-----------------------------------------------------------------------------
48 // GTpo container adapter tests
49 //-----------------------------------------------------------------------------
TEST(GTpoContainerAdapter,stdVector)50 TEST(GTpoContainerAdapter, stdVector)
51 {
52     {
53         using IntVector = std::vector<int>;
54         IntVector iv;
55         int i = 42;
56         EXPECT_TRUE( std_container_adapter<IntVector>::size(iv) == 0 );
57         EXPECT_FALSE( std_container_adapter<IntVector>::contains(iv, i) );
58         std_container_adapter<IntVector>::insert(i, iv);
59         EXPECT_TRUE( std_container_adapter<IntVector>::size(iv) == 1 );
60         EXPECT_TRUE( std_container_adapter<IntVector>::contains(iv, i) );
61         std_container_adapter<IntVector>::remove(i, iv);
62         EXPECT_TRUE( std_container_adapter<IntVector>::size(iv) == 0 );
63         EXPECT_FALSE( std_container_adapter<IntVector>::contains(iv, i) );
64 
65         std_container_adapter<IntVector>::reserve(iv, 2);
66     }
67 
68     {
69         using SharedIntVector = std::vector< std::shared_ptr<int> >;
70         SharedIntVector siv;
71         auto si = std::make_shared<int>( 42 );
72         EXPECT_TRUE( std_container_adapter<SharedIntVector>::size(siv) == 0 );
73         EXPECT_FALSE( std_container_adapter<SharedIntVector>::contains(siv, si) );
74         std_container_adapter<SharedIntVector>::insert(si, siv);
75         EXPECT_TRUE( std_container_adapter<SharedIntVector>::size(siv) == 1 );
76         EXPECT_TRUE( std_container_adapter<SharedIntVector>::contains(siv, si) );
77         std_container_adapter<SharedIntVector>::remove(si, siv);
78 
79         std_container_adapter<SharedIntVector>::reserve(siv, 2);
80     }
81     {
82         using WeakIntVector = std::vector< std::weak_ptr<int> >;
83         auto si = std::make_shared<int>( 42 );
84         auto wi = std::weak_ptr<int>{si};
85         WeakIntVector wiv;
86         EXPECT_TRUE( std_container_adapter<WeakIntVector>::size(wiv) == 0 );
87         EXPECT_FALSE( std_container_adapter<WeakIntVector>::contains(wiv, wi) );
88         std_container_adapter<WeakIntVector>::insert(wi, wiv);
89         EXPECT_TRUE( std_container_adapter<WeakIntVector>::size(wiv) == 1 );
90         EXPECT_TRUE( std_container_adapter<WeakIntVector>::contains(wiv, wi) );
91         std_container_adapter<WeakIntVector>::remove(wi, wiv);
92 
93         std_container_adapter<WeakIntVector>::reserve(wiv, 2);
94     }
95 }
96 
TEST(GTpoContainerAdapter,stdListInsertRemove)97 TEST(GTpoContainerAdapter, stdListInsertRemove)
98 {
99     using SharedIntList = std::list< std::shared_ptr<int> >;
100     SharedIntList sil;
101     auto si = std::make_shared<int>( 42 );
102     std_container_adapter<SharedIntList>::insert(si, sil);
103     std_container_adapter<SharedIntList>::remove(si, sil);
104 
105     using IntList = std::list<int>;
106     IntList il;
107     int i = 42;
108     std_container_adapter<IntList>::insert(i, il);
109     std_container_adapter<IntList>::remove(i, il);
110 }
111 
TEST(GTpoContainerAdapter,stdSetInsertRemove)112 TEST(GTpoContainerAdapter, stdSetInsertRemove)
113 {
114     using SharedIntSet = std::set< std::shared_ptr<int> >;
115     SharedIntSet sil;
116     auto si = std::make_shared<int>( 42 );
117     std_container_adapter<SharedIntSet>::insert(si, sil);
118     std_container_adapter<SharedIntSet>::remove(si, sil);
119 
120     using IntSet = std::set<int>;
121     IntSet il;
122     int i = 42;
123     std_container_adapter<IntSet>::insert(i, il);
124     std_container_adapter<IntSet>::remove(i, il);
125 }
126 
TEST(GTpoContainerAdapter,stdUnorderedSetInsertRemove)127 TEST(GTpoContainerAdapter, stdUnorderedSetInsertRemove)
128 {
129     using SharedIntUnorderedSet = std::unordered_set< std::shared_ptr<int> >;
130     SharedIntUnorderedSet sil;
131     auto si = std::make_shared<int>( 42 );
132     std_container_adapter<SharedIntUnorderedSet>::insert(si, sil);
133     std_container_adapter<SharedIntUnorderedSet>::remove(si, sil);
134 
135     using IntUnorderedSet = std::unordered_set<int>;
136     IntUnorderedSet il;
137     int i = 42;
138     std_container_adapter<IntUnorderedSet>::insert(i, il);
139     std_container_adapter<IntUnorderedSet>::remove(i, il);
140 }
141