/* * Copyright (C) 2007 The Guava Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.google.common.collect; import static com.google.common.testing.SerializableTester.reserializeAndAssert; import static org.junit.contrib.truth.Truth.ASSERT; import com.google.common.annotations.GwtCompatible; import com.google.common.annotations.GwtIncompatible; import com.google.common.collect.testing.DerivedComparable; import com.google.common.testing.NullPointerTester; import junit.framework.TestCase; import java.util.Arrays; import java.util.Collections; import java.util.HashSet; import java.util.Set; /** * Tests for {@link Multisets}. * * @author Mike Bostock * @author Jared Levy * @author Louis Wasserman */ @GwtCompatible(emulated = true) public class MultisetsTest extends TestCase { /* See MultisetsImmutableEntryTest for immutableEntry() tests. */ public void testForSet() { Set<String> set = new HashSet<String>(); set.add("foo"); set.add("bar"); set.add(null); Multiset<String> multiset = HashMultiset.create(); multiset.addAll(set); Multiset<String> multisetView = Multisets.forSet(set); assertTrue(multiset.equals(multisetView)); assertTrue(multisetView.equals(multiset)); assertEquals(multiset.toString(), multisetView.toString()); assertEquals(multiset.hashCode(), multisetView.hashCode()); assertEquals(multiset.size(), multisetView.size()); assertTrue(multisetView.contains("foo")); assertEquals(set, multisetView.elementSet()); assertEquals(multisetView.elementSet(), set); assertEquals(multiset.elementSet(), multisetView.elementSet()); assertEquals(multisetView.elementSet(), multiset.elementSet()); try { multisetView.add("baz"); fail("UnsupportedOperationException expected"); } catch (UnsupportedOperationException expected) {} try { multisetView.addAll(Collections.singleton("baz")); fail("UnsupportedOperationException expected"); } catch (UnsupportedOperationException expected) {} try { multisetView.elementSet().add("baz"); fail("UnsupportedOperationException expected"); } catch (UnsupportedOperationException expected) {} try { multisetView.elementSet().addAll(Collections.singleton("baz")); fail("UnsupportedOperationException expected"); } catch (UnsupportedOperationException expected) {} multisetView.remove("bar"); assertFalse(multisetView.contains("bar")); assertFalse(set.contains("bar")); assertEquals(set, multisetView.elementSet()); ASSERT.that(multisetView.elementSet()).hasContentsAnyOrder("foo", null); ASSERT.that(multisetView.entrySet()).hasContentsAnyOrder( Multisets.immutableEntry("foo", 1), Multisets.immutableEntry((String) null, 1)); multisetView.clear(); assertFalse(multisetView.contains("foo")); assertFalse(set.contains("foo")); assertTrue(set.isEmpty()); assertTrue(multisetView.isEmpty()); multiset.clear(); assertEquals(multiset.toString(), multisetView.toString()); assertEquals(multiset.hashCode(), multisetView.hashCode()); assertEquals(multiset.size(), multisetView.size()); } @GwtIncompatible("SerializableTester") public void testForSetSerialization() { Set<String> set = new HashSet<String>(); set.add("foo"); set.add("bar"); set.add(null); Multiset<String> multiset = HashMultiset.create(); multiset.addAll(set); Multiset<String> multisetView = Multisets.forSet(set); assertTrue(multiset.equals(multisetView)); reserializeAndAssert(multisetView); } public void testNewTreeMultisetDerived() { TreeMultiset<DerivedComparable> set = TreeMultiset.create(); assertTrue(set.isEmpty()); set.add(new DerivedComparable("foo"), 2); set.add(new DerivedComparable("bar"), 3); ASSERT.that(set).hasContentsInOrder( new DerivedComparable("bar"), new DerivedComparable("bar"), new DerivedComparable("bar"), new DerivedComparable("foo"), new DerivedComparable("foo")); } public void testNewTreeMultisetNonGeneric() { TreeMultiset<LegacyComparable> set = TreeMultiset.create(); assertTrue(set.isEmpty()); set.add(new LegacyComparable("foo"), 2); set.add(new LegacyComparable("bar"), 3); ASSERT.that(set).hasContentsInOrder(new LegacyComparable("bar"), new LegacyComparable("bar"), new LegacyComparable("bar"), new LegacyComparable("foo"), new LegacyComparable("foo")); } public void testNewTreeMultisetComparator() { TreeMultiset<String> multiset = TreeMultiset.create(Collections.reverseOrder()); multiset.add("bar", 3); multiset.add("foo", 2); ASSERT.that(multiset).hasContentsInOrder("foo", "foo", "bar", "bar", "bar"); } public void testRetainOccurrencesEmpty() { Multiset<String> multiset = HashMultiset.create(); Multiset<String> toRetain = HashMultiset.create(Arrays.asList("a", "b", "a")); assertFalse(Multisets.retainOccurrences(multiset, toRetain)); ASSERT.that(multiset).hasContentsInOrder(); } public void testRemoveOccurrencesEmpty() { Multiset<String> multiset = HashMultiset.create(); Multiset<String> toRemove = HashMultiset.create(Arrays.asList("a", "b", "a")); assertFalse(Multisets.retainOccurrences(multiset, toRemove)); assertTrue(multiset.isEmpty()); } public void testIntersectEmptyNonempty() { Multiset<String> ms1 = HashMultiset.create(); Multiset<String> ms2 = HashMultiset.create(Arrays.asList("a", "b", "a")); ASSERT.that(Multisets.intersection(ms1, ms2)).hasContentsInOrder(); } public void testIntersectNonemptyEmpty() { Multiset<String> ms1 = HashMultiset.create(Arrays.asList("a", "b", "a")); Multiset<String> ms2 = HashMultiset.create(); ASSERT.that(Multisets.intersection(ms1, ms2)).hasContentsInOrder(); } public void testContainsOccurrencesEmpty() { Multiset<String> superMultiset = HashMultiset.create(Arrays.asList("a", "b", "a")); Multiset<String> subMultiset = HashMultiset.create(); assertTrue(Multisets.containsOccurrences(superMultiset, subMultiset)); assertFalse(Multisets.containsOccurrences(subMultiset, superMultiset)); } public void testContainsOccurrences() { Multiset<String> superMultiset = HashMultiset.create(Arrays.asList("a", "b", "a")); Multiset<String> subMultiset = HashMultiset.create(Arrays.asList("a", "b")); assertTrue(Multisets.containsOccurrences(superMultiset, subMultiset)); assertFalse(Multisets.containsOccurrences(subMultiset, superMultiset)); Multiset<String> diffMultiset = HashMultiset.create(Arrays.asList("a", "b", "c")); assertFalse(Multisets.containsOccurrences(superMultiset, diffMultiset)); assertTrue(Multisets.containsOccurrences(diffMultiset, subMultiset)); } public void testRetainEmptyOccurrences() { Multiset<String> multiset = HashMultiset.create(Arrays.asList("a", "b", "a")); Multiset<String> toRetain = HashMultiset.create(); assertTrue(Multisets.retainOccurrences(multiset, toRetain)); assertTrue(multiset.isEmpty()); } public void testRetainOccurrences() { Multiset<String> multiset = TreeMultiset.create(Arrays.asList("a", "b", "a", "c")); Multiset<String> toRetain = HashMultiset.create(Arrays.asList("a", "b", "b")); assertTrue(Multisets.retainOccurrences(multiset, toRetain)); ASSERT.that(multiset).hasContentsInOrder("a", "b"); } public void testRemoveEmptyOccurrences() { Multiset<String> multiset = TreeMultiset.create(Arrays.asList("a", "b", "a")); Multiset<String> toRemove = HashMultiset.create(); assertFalse(Multisets.removeOccurrences(multiset, toRemove)); ASSERT.that(multiset).hasContentsInOrder("a", "a", "b"); } public void testRemoveOccurrences() { Multiset<String> multiset = TreeMultiset.create(Arrays.asList("a", "b", "a", "c")); Multiset<String> toRemove = HashMultiset.create(Arrays.asList("a", "b", "b")); assertTrue(Multisets.removeOccurrences(multiset, toRemove)); ASSERT.that(multiset).hasContentsInOrder("a", "c"); } @SuppressWarnings("deprecation") public void testUnmodifiableMultisetShortCircuit() { Multiset<String> mod = HashMultiset.create(); Multiset<String> unmod = Multisets.unmodifiableMultiset(mod); assertNotSame(mod, unmod); assertSame(unmod, Multisets.unmodifiableMultiset(unmod)); ImmutableMultiset<String> immutable = ImmutableMultiset.of("a", "a", "b", "a"); assertSame(immutable, Multisets.unmodifiableMultiset(immutable)); assertSame(immutable, Multisets.unmodifiableMultiset((Multiset<String>) immutable)); } public void testHighestCountFirst() { Multiset<String> multiset = HashMultiset.create( Arrays.asList("a", "a", "a", "b", "c", "c")); ImmutableMultiset<String> sortedMultiset = Multisets.copyHighestCountFirst(multiset); ASSERT.that(sortedMultiset.entrySet()).hasContentsInOrder( Multisets.immutableEntry("a", 3), Multisets.immutableEntry("c", 2), Multisets.immutableEntry("b", 1)); ASSERT.that(sortedMultiset).hasContentsInOrder( "a", "a", "a", "c", "c", "b"); ASSERT.that(Multisets.copyHighestCountFirst(ImmutableMultiset.of())).isEmpty(); } @GwtIncompatible("NullPointerTester") public void testNullPointers() { NullPointerTester tester = new NullPointerTester(); tester.setDefault(Multiset.class, ImmutableMultiset.of()); tester.testAllPublicStaticMethods(Multisets.class); } }