You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							53 lines
						
					
					
						
							1.3 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							53 lines
						
					
					
						
							1.3 KiB
						
					
					
				| #include "gtest/gtest.h" | |
|  | |
| #include <cstdint> | |
|  | |
| #include "src/storage/BitVector.h" | |
| #include "src/storage/BitVectorHashMap.h" | |
|  | |
| TEST(BitVectorHashMapTest, FindOrAdd) { | |
|     storm::storage::BitVectorHashMap<uint64_t> map(64, 3); | |
|      | |
|     storm::storage::BitVector first(64); | |
|     first.set(4); | |
|     first.set(47); | |
|     ASSERT_NO_THROW(map.findOrAdd(first, 1)); | |
|      | |
|     storm::storage::BitVector second(64); | |
|     second.set(8); | |
|     second.set(18); | |
|     ASSERT_NO_THROW(map.findOrAdd(second, 2)); | |
|      | |
|     EXPECT_EQ(1, map.findOrAdd(first, 3)); | |
|      | |
|     storm::storage::BitVector third(64); | |
|     third.set(10); | |
|     third.set(63); | |
|      | |
|     ASSERT_NO_THROW(map.findOrAdd(third, 3)); | |
| 
 | |
|     storm::storage::BitVector fourth(64); | |
|     fourth.set(12); | |
|     fourth.set(14); | |
| 
 | |
|     ASSERT_NO_THROW(map.findOrAdd(fourth, 4)); | |
| 
 | |
|     storm::storage::BitVector fifth(64); | |
|     fifth.set(44); | |
|     fifth.set(55); | |
|      | |
|     ASSERT_NO_THROW(map.findOrAdd(fifth, 5)); | |
| 
 | |
|     storm::storage::BitVector sixth(64); | |
|     sixth.set(45); | |
|     sixth.set(55); | |
|      | |
|     ASSERT_NO_THROW(map.findOrAdd(sixth, 6)); | |
|      | |
|     EXPECT_EQ(1, map.findOrAdd(first, 0)); | |
|     EXPECT_EQ(2, map.findOrAdd(second, 0)); | |
|     EXPECT_EQ(3, map.findOrAdd(third, 0)); | |
|     EXPECT_EQ(4, map.findOrAdd(fourth, 0)); | |
|     EXPECT_EQ(5, map.findOrAdd(fifth, 0)); | |
|     EXPECT_EQ(6, map.findOrAdd(sixth, 0)); | |
| }
 |