1 /* 2 * Copyright (C) 2007 The Guava Authors 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package com.google.common.collect; 18 19 import static com.google.common.truth.Truth.assertThat; 20 21 import com.google.common.annotations.GwtCompatible; 22 import com.google.common.annotations.GwtIncompatible; 23 import com.google.common.collect.ImmutableSet.Builder; 24 import com.google.common.collect.testing.ListTestSuiteBuilder; 25 import com.google.common.collect.testing.SetTestSuiteBuilder; 26 import com.google.common.collect.testing.features.CollectionFeature; 27 import com.google.common.collect.testing.features.CollectionSize; 28 import com.google.common.collect.testing.google.SetGenerators.DegeneratedImmutableSetGenerator; 29 import com.google.common.collect.testing.google.SetGenerators.ImmutableSetAsListGenerator; 30 import com.google.common.collect.testing.google.SetGenerators.ImmutableSetCopyOfGenerator; 31 import com.google.common.collect.testing.google.SetGenerators.ImmutableSetWithBadHashesGenerator; 32 import com.google.common.testing.EqualsTester; 33 34 import junit.framework.Test; 35 import junit.framework.TestSuite; 36 37 import java.util.Collection; 38 import java.util.Collections; 39 import java.util.Iterator; 40 import java.util.Set; 41 42 /** 43 * Unit test for {@link ImmutableSet}. 44 * 45 * @author Kevin Bourrillion 46 * @author Jared Levy 47 * @author Nick Kralevich 48 */ 49 @GwtCompatible(emulated = true) 50 public class ImmutableSetTest extends AbstractImmutableSetTest { 51 52 @GwtIncompatible("suite") 53 public static Test suite() { 54 TestSuite suite = new TestSuite(); 55 56 suite.addTest(SetTestSuiteBuilder.using(new ImmutableSetCopyOfGenerator()) 57 .named(ImmutableSetTest.class.getName()) 58 .withFeatures(CollectionSize.ANY, CollectionFeature.KNOWN_ORDER, 59 CollectionFeature.SERIALIZABLE, 60 CollectionFeature.ALLOWS_NULL_QUERIES) 61 .createTestSuite()); 62 63 suite.addTest(SetTestSuiteBuilder.using( 64 new ImmutableSetWithBadHashesGenerator()) 65 .named(ImmutableSetTest.class.getName() + ", with bad hashes") 66 .withFeatures(CollectionSize.ANY, CollectionFeature.KNOWN_ORDER, 67 CollectionFeature.ALLOWS_NULL_QUERIES) 68 .createTestSuite()); 69 70 suite.addTest(SetTestSuiteBuilder.using( 71 new DegeneratedImmutableSetGenerator()) 72 .named(ImmutableSetTest.class.getName() + ", degenerate") 73 .withFeatures(CollectionSize.ONE, CollectionFeature.KNOWN_ORDER, 74 CollectionFeature.ALLOWS_NULL_QUERIES) 75 .createTestSuite()); 76 77 suite.addTest(ListTestSuiteBuilder.using(new ImmutableSetAsListGenerator()) 78 .named("ImmutableSet.asList") 79 .withFeatures(CollectionSize.ANY, 80 CollectionFeature.REJECTS_DUPLICATES_AT_CREATION, 81 CollectionFeature.SERIALIZABLE, 82 CollectionFeature.ALLOWS_NULL_QUERIES) 83 .createTestSuite()); 84 85 suite.addTestSuite(ImmutableSetTest.class); 86 87 return suite; 88 } 89 90 @Override protected Set<String> of() { 91 return ImmutableSet.of(); 92 } 93 94 @Override protected Set<String> of(String e) { 95 return ImmutableSet.of(e); 96 } 97 98 @Override protected Set<String> of(String e1, String e2) { 99 return ImmutableSet.of(e1, e2); 100 } 101 102 @Override protected Set<String> of(String e1, String e2, String e3) { 103 return ImmutableSet.of(e1, e2, e3); 104 } 105 106 @Override protected Set<String> of( 107 String e1, String e2, String e3, String e4) { 108 return ImmutableSet.of(e1, e2, e3, e4); 109 } 110 111 @Override protected Set<String> of( 112 String e1, String e2, String e3, String e4, String e5) { 113 return ImmutableSet.of(e1, e2, e3, e4, e5); 114 } 115 116 @Override protected Set<String> of(String e1, String e2, String e3, 117 String e4, String e5, String e6, String... rest) { 118 return ImmutableSet.of(e1, e2, e3, e4, e5, e6, rest); 119 } 120 121 @Override protected Set<String> copyOf(String[] elements) { 122 return ImmutableSet.copyOf(elements); 123 } 124 125 @Override protected Set<String> copyOf(Collection<String> elements) { 126 return ImmutableSet.copyOf(elements); 127 } 128 129 @Override protected Set<String> copyOf(Iterable<String> elements) { 130 return ImmutableSet.copyOf(elements); 131 } 132 133 @Override protected Set<String> copyOf(Iterator<String> elements) { 134 return ImmutableSet.copyOf(elements); 135 } 136 137 public void testCreation_allDuplicates() { 138 ImmutableSet<String> set = ImmutableSet.copyOf(Lists.newArrayList("a", "a")); 139 assertTrue(set instanceof SingletonImmutableSet); 140 assertEquals(Lists.newArrayList("a"), Lists.newArrayList(set)); 141 } 142 143 public void testCreation_oneDuplicate() { 144 // now we'll get the varargs overload 145 ImmutableSet<String> set = ImmutableSet.of( 146 "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "a"); 147 assertEquals(Lists.newArrayList( 148 "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m"), 149 Lists.newArrayList(set)); 150 } 151 152 public void testCreation_manyDuplicates() { 153 // now we'll get the varargs overload 154 ImmutableSet<String> set = ImmutableSet.of( 155 "a", "b", "c", "c", "c", "c", "b", "b", "a", "a", "c", "c", "c", "a"); 156 assertThat(set).has().exactly("a", "b", "c").inOrder(); 157 } 158 159 public void testCreation_arrayOfArray() { 160 String[] array = new String[] { "a" }; 161 Set<String[]> set = ImmutableSet.<String[]>of(array); 162 assertEquals(Collections.singleton(array), set); 163 } 164 165 @GwtIncompatible("ImmutableSet.chooseTableSize") 166 public void testChooseTableSize() { 167 assertEquals(8, ImmutableSet.chooseTableSize(3)); 168 assertEquals(8, ImmutableSet.chooseTableSize(4)); 169 170 assertEquals(1 << 29, ImmutableSet.chooseTableSize(1 << 28)); 171 assertEquals(1 << 29, ImmutableSet.chooseTableSize(1 << 29 - 1)); 172 173 // Now we hit the cap 174 assertEquals(1 << 30, ImmutableSet.chooseTableSize(1 << 29)); 175 assertEquals(1 << 30, ImmutableSet.chooseTableSize(1 << 30 - 1)); 176 177 // Now we've gone too far 178 try { 179 ImmutableSet.chooseTableSize(1 << 30); 180 fail(); 181 } catch (IllegalArgumentException expected) { 182 } 183 } 184 185 @GwtIncompatible("RegularImmutableSet.table not in emulation") 186 public void testResizeTable() { 187 verifyTableSize(100, 2, 4); 188 verifyTableSize(100, 5, 8); 189 verifyTableSize(100, 33, 64); 190 verifyTableSize(17, 17, 32); 191 verifyTableSize(17, 16, 32); 192 verifyTableSize(17, 15, 32); 193 } 194 195 @GwtIncompatible("RegularImmutableSet.table not in emulation") 196 private void verifyTableSize(int inputSize, int setSize, int tableSize) { 197 Builder<Integer> builder = ImmutableSet.builder(); 198 for (int i = 0; i < inputSize; i++) { 199 builder.add(i % setSize); 200 } 201 ImmutableSet<Integer> set = builder.build(); 202 assertTrue(set instanceof RegularImmutableSet); 203 assertEquals("Input size " + inputSize + " and set size " + setSize, 204 tableSize, ((RegularImmutableSet<Integer>) set).table.length); 205 } 206 207 public void testCopyOf_copiesImmutableSortedSet() { 208 ImmutableSortedSet<String> sortedSet = ImmutableSortedSet.of("a"); 209 ImmutableSet<String> copy = ImmutableSet.copyOf(sortedSet); 210 assertNotSame(sortedSet, copy); 211 } 212 213 @GwtIncompatible("GWT is single threaded") 214 public void testCopyOf_threadSafe() { 215 verifyThreadSafe(); 216 } 217 218 @Override <E extends Comparable<E>> Builder<E> builder() { 219 return ImmutableSet.builder(); 220 } 221 222 @Override int getComplexBuilderSetLastElement() { 223 return LAST_COLOR_ADDED; 224 } 225 226 public void testEquals() { 227 new EqualsTester() 228 .addEqualityGroup(ImmutableSet.of(), ImmutableSet.of()) 229 .addEqualityGroup(ImmutableSet.of(1), ImmutableSet.of(1), ImmutableSet.of(1, 1)) 230 .addEqualityGroup(ImmutableSet.of(1, 2, 1), ImmutableSet.of(2, 1, 1)) 231 .testEquals(); 232 } 233 } 234