This repository has been archived on 2023-06-18. You can view files and clone it, but cannot push or open issues or pull requests.
ima02/resources/defects4j-checkout-closure-1f/test/com/google/javascript/jscomp/graph/StandardUnionFindTest.java
github-classroom[bot] e42e547e48
Initial commit
2023-04-25 11:33:41 +00:00

240 lines
6.9 KiB
Java

/*
* Copyright 2008 The Closure Compiler 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.javascript.jscomp.graph;
import com.google.common.collect.HashMultiset;
import com.google.common.collect.ImmutableSet;
import junit.framework.Assert;
import junit.framework.TestCase;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;
import java.util.Set;
/**
* Unit test for the {@link StandardUnionFind} data structure.
*
*/
public class StandardUnionFindTest extends TestCase {
private StandardUnionFind<String> union;
@Override protected void setUp() {
union = new StandardUnionFind<String>();
}
public void testEmpty() {
assertEquals(0, union.allEquivalenceClasses().size());
}
public void testAdd() {
union.add("foo");
union.add("bar");
assertTrue(null != union.find("foo"));
assertEquals(2, union.allEquivalenceClasses().size());
}
public void testUnion() {
union.union("A", "B");
union.union("C", "D");
assertEquals(union.find("A"), union.find("B"));
assertEquals(union.find("C"), union.find("D"));
assertFalse(union.find("A").equals(union.find("D")));
}
public void testSetSize() {
union.union("A", "B");
union.union("B", "C");
union.union("D", "E");
union.union("F", "F");
assertEquals(3, union.findAll("A").size());
assertEquals(3, union.findAll("B").size());
assertEquals(3, union.findAll("C").size());
assertEquals(2, union.findAll("D").size());
assertEquals(1, union.findAll("F").size());
}
public void testFind() {
union.add("A");
union.add("B");
assertEquals("A", union.find("A"));
assertEquals("B", union.find("B"));
union.union("A", "B");
assertEquals(union.find("A"), union.find("B"));
try {
union.find("Z");
fail("find() on unknown element should not be allowed.");
} catch (IllegalArgumentException e) {
}
}
public void testAllEquivalenceClasses() {
union.union("A", "B");
union.union("A", "B");
union.union("B", "A");
union.union("B", "C");
union.union("D", "E");
union.union("F", "F");
Collection<Set<String>> classes = union.allEquivalenceClasses();
assertEquals(3, classes.size());
assertContentsAnyOrder(classes,
ImmutableSet.of("A", "B", "C"),
ImmutableSet.of("D", "E"),
ImmutableSet.of("F"));
}
public void testFindAll() {
union.union("A", "B");
union.union("A", "B");
union.union("B", "A");
union.union("D", "E");
union.union("F", "F");
Set<String> aSet = union.findAll("A");
assertEquals(2, aSet.size());
assertTrue(aSet.contains("A"));
assertTrue(aSet.contains("B"));
assertFalse(aSet.contains("C"));
assertFalse(aSet.contains("D"));
assertFalse(aSet.contains("E"));
assertFalse(aSet.contains("F"));
union.union("B", "C");
assertTrue(aSet.contains("C"));
assertEquals(3, aSet.size());
try {
union.findAll("Z");
fail("findAll() on unknown element should not be allowed.");
} catch (IllegalArgumentException e) {
}
}
public void testFindAllIterator() {
union.union("A", "B");
union.union("B", "C");
union.union("A", "B");
union.union("D", "E");
Set<String> aSet = union.findAll("A");
Iterator<String> aIter = aSet.iterator();
assertTrue(aIter.hasNext());
assertEquals("A", aIter.next());
assertEquals("B", aIter.next());
assertEquals("C", aIter.next());
assertFalse(aIter.hasNext());
Set<String> dSet = union.findAll("D");
Iterator<String> dIter = dSet.iterator();
assertTrue(dIter.hasNext());
assertEquals("D", dIter.next());
assertEquals("E", dIter.next());
assertFalse(dIter.hasNext());
}
public void testFindAllSize() {
union.union("A", "B");
union.union("B", "C");
assertEquals(3, union.findAll("A").size());
assertEquals(3, union.findAll("B").size());
assertEquals(3, union.findAll("C").size());
union.union("D", "E");
assertEquals(3, union.findAll("C").size());
assertEquals(2, union.findAll("D").size());
union.union("B", "E");
assertEquals(5, union.findAll("C").size());
assertEquals(5, union.findAll("D").size());
}
public void testElements(){
union.union("A", "B");
union.union("B", "C");
union.union("A", "B");
union.union("D", "E");
Set<String> elements = union.elements();
assertEquals(ImmutableSet.of("A", "B", "C", "D", "E"), elements);
assertFalse(elements.contains("F"));
}
public void testCopy() {
union.union("A", "B");
union.union("B", "Z");
union.union("X", "Y");
UnionFind<String> copy = new StandardUnionFind<String>(union);
assertContentsAnyOrder(copy.findAll("Z"), "A", "B", "Z");
assertContentsAnyOrder(copy.findAll("X"), "X", "Y");
}
public void testChangesToCopyDontAffectOriginal() {
union.union("A", "B");
union.union("X", "Y");
union.union("A", "C");
UnionFind<String> copy = new StandardUnionFind<String>(union);
copy.union("A", "D");
assertContentsAnyOrder(copy.findAll("D"), "A", "B", "C", "D");
assertContentsAnyOrder(union.findAll("A"), "A", "B", "C");
assertContentsAnyOrder(copy.findAll("X"), "X", "Y");
try {
union.findAll("D");
fail("D has been inserted to the original collection");
} catch (IllegalArgumentException e) {
// Expected.
}
}
public void testCheckEquivalent() {
union.union("A", "B");
union.add("C");
assertTrue(union.areEquivalent("A", "B"));
assertFalse(union.areEquivalent("C", "A"));
assertFalse(union.areEquivalent("C", "B"));
try {
union.areEquivalent("A", "F");
} catch (IllegalArgumentException e) {
// Expected.
}
}
/**
* Asserts that {@code actual} contains precisely the elements
* {@code expected}, in any order. Both collections may contain
* duplicates, and this method will only pass if the quantities are
* exactly the same.
*/
private static void assertContentsAnyOrder(
String message, Iterable<?> actual, Object... expected) {
Assert.assertEquals(message,
HashMultiset.create(Arrays.asList(expected)),
HashMultiset.create(actual));
}
/**
* Variant of {@link #assertContentsAnyOrder(String,Iterable,Object...)}
* using a generic message.
*/
private static void assertContentsAnyOrder(
Iterable<?> actual, Object... expected) {
assertContentsAnyOrder((String) null, actual, expected);
}
}