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/GraphTest.java

385 lines
12 KiB
Java
Raw Permalink Normal View History

2023-04-25 11:33:41 +00:00
/*
* 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.javascript.jscomp.graph.Graph;
import com.google.javascript.jscomp.graph.LinkedDirectedGraph;
import com.google.javascript.jscomp.graph.LinkedUndirectedGraph;
import com.google.javascript.jscomp.graph.Annotatable;
import com.google.javascript.jscomp.graph.Annotation;
import com.google.javascript.jscomp.graph.GraphNode;
import com.google.javascript.jscomp.graph.SubGraph;
import com.google.javascript.jscomp.graph.DiGraph;
import com.google.javascript.jscomp.graph.Graph.GraphEdge;
import com.google.javascript.jscomp.graph.UndiGraph;
import junit.framework.TestCase;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
/**
* Tests for the graph data structure.
*
*/
public class GraphTest extends TestCase {
public void testDirectedSimple() {
DiGraph<String, String> graph =
LinkedDirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.connect("a", "->", "b");
assertTrue(graph.hasNode("a"));
assertTrue(graph.hasNode("b"));
assertTrue(graph.hasNode("c"));
assertFalse(graph.hasNode("d"));
assertTrue(graph.isConnected("a", "b"));
assertTrue(graph.isConnected("b", "a"));
assertFalse(graph.isConnected("a", "c"));
assertFalse(graph.isConnected("b", "c"));
assertFalse(graph.isConnected("c", "a"));
assertFalse(graph.isConnected("c", "b"));
assertFalse(graph.isConnected("a", "a"));
assertFalse(graph.isConnected("b", "b"));
assertFalse(graph.isConnected("b", "c"));
assertTrue(graph.isConnectedInDirection("a", "b"));
assertFalse(graph.isConnectedInDirection("b", "a"));
assertFalse(graph.isConnectedInDirection("a", "c"));
assertFalse(graph.isConnectedInDirection("b", "c"));
assertFalse(graph.isConnectedInDirection("c", "a"));
assertFalse(graph.isConnectedInDirection("c", "b"));
// Removal.
graph.disconnect("a", "b");
assertFalse(graph.isConnected("a", "b"));
assertFalse(graph.isConnected("b", "a"));
// Disconnect both ways.
graph.connect("a", "->", "b");
graph.connect("b", "->", "a");
graph.disconnect("a", "b");
assertFalse(graph.isConnected("a", "b"));
assertFalse(graph.isConnected("b", "a"));
// Disconnect one way.
graph.connect("a", "->", "b");
graph.connect("b", "->", "a");
graph.disconnectInDirection("a", "b");
assertTrue(graph.isConnected("b", "a"));
assertTrue(graph.isConnected("a", "b"));
assertFalse(graph.isConnectedInDirection("a", "b"));
assertTrue(graph.isConnectedInDirection("b", "a"));
}
public void testUndirectedSimple() {
UndiGraph<String, String> graph =
LinkedUndirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.connect("a", "--", "b");
assertTrue(graph.hasNode("a"));
assertTrue(graph.hasNode("b"));
assertTrue(graph.hasNode("c"));
assertFalse(graph.hasNode("d"));
assertTrue(graph.isConnected("a", "b"));
assertTrue(graph.isConnected("b", "a"));
assertFalse(graph.isConnected("a", "c"));
assertFalse(graph.isConnected("b", "c"));
assertFalse(graph.isConnected("c", "a"));
assertFalse(graph.isConnected("c", "b"));
assertFalse(graph.isConnected("a", "a"));
assertFalse(graph.isConnected("b", "b"));
assertFalse(graph.isConnected("b", "c"));
// Removal.
graph.disconnect("a", "b");
assertFalse(graph.isConnected("a", "b"));
assertFalse(graph.isConnected("b", "a"));
}
public void testDirectedSelfLoop() {
DiGraph<String, String> graph =
LinkedDirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.connect("a", "->", "a");
assertTrue(graph.isConnected("a", "a"));
assertFalse(graph.isConnected("a", "b"));
assertFalse(graph.isConnected("b", "a"));
assertTrue(graph.isConnectedInDirection("a", "a"));
assertFalse(graph.isConnectedInDirection("a", "b"));
assertFalse(graph.isConnectedInDirection("b", "a"));
// Removal.
graph.disconnect("a", "a");
assertFalse(graph.isConnected("a", "a"));
// Disconnect both ways.
graph.connect("a", "->", "a");
graph.disconnect("a", "a");
assertFalse(graph.isConnected("a", "a"));
assertFalse(graph.isConnected("a", "a"));
// Disconnect one way.
graph.connect("a", "->", "a");
graph.disconnectInDirection("a", "a");
assertFalse(graph.isConnected("a", "a"));
}
public void testUndirectedSelfLoop() {
UndiGraph<String, String> graph =
LinkedUndirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.connect("a", "--", "a");
assertTrue(graph.isConnected("a", "a"));
assertFalse(graph.isConnected("a", "b"));
assertFalse(graph.isConnected("b", "a"));
// Removal.
graph.disconnect("a", "a");
assertFalse(graph.isConnected("a", "a"));
}
public void testDirectedInAndOutEdges() {
DiGraph<String, String> graph =
LinkedDirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.createNode("d");
graph.connect("a", "->", "b");
graph.connect("a", "-->", "b");
graph.connect("a", "--->", "b");
graph.connect("a", "->", "c");
graph.connect("c", "->", "d");
assertSetEquals(graph.getDirectedSuccNodes("a"), "b", "c");
assertSetEquals(graph.getDirectedPredNodes("b"), "a");
assertSetEquals(graph.getDirectedPredNodes("c"), "a");
assertListCount(graph.getDirectedSuccNodes("a"), "b", 3);
// Removal.
graph.disconnect("a", "b");
assertFalse(graph.isConnected("a", "b"));
}
public void testUndirectedNeighbors() {
UndiGraph<String, String> graph =
LinkedUndirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.createNode("d");
graph.connect("a", "-", "b");
graph.connect("a", "--", "b");
graph.connect("a", "---", "b");
graph.connect("a", "-", "c");
graph.connect("c", "-", "d");
assertSetEquals(graph.getNeighborNodes("a"), "b", "c");
assertSetEquals(graph.getNeighborNodes("b"), "a");
assertSetEquals(graph.getNeighborNodes("c"), "a", "d");
assertListCount(graph.getNeighborNodes("a"), "b", 3);
// Removal.
graph.disconnect("a", "b");
assertFalse(graph.isConnected("a", "b"));
}
public void testDirectedGetFirstEdge() {
DiGraph<String, String> graph =
LinkedDirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.connect("a", "-", "b");
assertEquals(graph.getFirstEdge("a", "b").getValue(), "-");
assertEquals(graph.getFirstEdge("b", "a").getValue(), "-");
assertNull(graph.getFirstEdge("a", "c"));
}
public void testUndirectedGetFirstEdge() {
UndiGraph<String, String> graph =
LinkedUndirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.connect("a", "-", "b");
assertEquals(graph.getFirstEdge("a", "b").getValue(), "-");
assertEquals(graph.getFirstEdge("b", "a").getValue(), "-");
assertNull(graph.getFirstEdge("a", "c"));
}
public void testNodeAnnotations() {
Graph<String, String> graph = LinkedUndirectedGraph.create();
GraphNode<String, String> a = graph.createNode("a");
GraphNode<String, String> b = graph.createNode("b");
checkAnnotations(graph, a, b);
}
public void testEdgeAnnotations() {
Graph<String, String> graph = LinkedUndirectedGraph.create();
graph.createNode("1");
graph.createNode("2");
graph.createNode("3");
graph.connect("1", "a", "2");
graph.connect("2", "b", "3");
GraphEdge<String, String> a = graph.getEdges("1", "2").get(0);
GraphEdge<String, String> b = graph.getEdges("2", "3").get(0);
checkAnnotations(graph, a, b);
}
private static void checkAnnotations(
Graph<String, String> graph, Annotatable a, Annotatable b) {
final Annotation A = new Annotation() {};
final Annotation B = new Annotation() {};
// Initially null.
assertNull(a.getAnnotation());
assertNull(b.getAnnotation());
// Test basic setting.
a.setAnnotation(A);
b.setAnnotation(B);
assertSame(A, a.getAnnotation());
assertSame(B, b.getAnnotation());
// Test clearing.
graph.clearEdgeAnnotations();
graph.clearNodeAnnotations();
assertNull(a.getAnnotation());
assertNull(b.getAnnotation());
a.setAnnotation(A);
b.setAnnotation(B);
// Pushing clears.
graph.pushEdgeAnnotations();
graph.pushNodeAnnotations();
assertNull(a.getAnnotation());
assertNull(b.getAnnotation());
a.setAnnotation(B);
b.setAnnotation(B);
graph.pushEdgeAnnotations();
graph.pushNodeAnnotations();
a.setAnnotation(B);
b.setAnnotation(A);
// Test restoring then restoring old values with pop.
assertSame(B, a.getAnnotation());
assertSame(A, b.getAnnotation());
graph.popEdgeAnnotations();
graph.popNodeAnnotations();
assertSame(B, a.getAnnotation());
assertSame(B, b.getAnnotation());
graph.popEdgeAnnotations();
graph.popNodeAnnotations();
assertSame(A, a.getAnnotation());
assertSame(B, b.getAnnotation());
}
public void testDegree() {
testDirectedDegree(LinkedDirectedGraph.<String, String>create());
testDirectedDegree(LinkedUndirectedGraph.<String, String>create());
}
public void testDirectedDegree(Graph<String, String> graph) {
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.createNode("d");
assertEquals(0, graph.getNodeDegree("a"));
graph.connect("a", "-", "b");
assertEquals(1, graph.getNodeDegree("a"));
graph.connect("b", "-", "c");
assertEquals(1, graph.getNodeDegree("a"));
graph.connect("a", "-", "c");
assertEquals(2, graph.getNodeDegree("a"));
graph.connect("d", "-", "a");
assertEquals(3, graph.getNodeDegree("a"));
}
public void testDirectedConnectIfNotFound() {
testDirectedConnectIfNotFound(
LinkedDirectedGraph.<String, String>create());
testDirectedConnectIfNotFound(
LinkedUndirectedGraph.<String, String>create());
}
public void testDirectedConnectIfNotFound(Graph<String, String> graph) {
graph.createNode("a");
graph.createNode("b");
graph.connectIfNotFound("a", "-", "b");
assertEquals(1, graph.getNodeDegree("a"));
graph.connectIfNotFound("a", "-", "b");
assertEquals(1, graph.getNodeDegree("a"));
graph.connectIfNotFound("a", null, "b");
assertEquals(2, graph.getNodeDegree("a"));
graph.connectIfNotFound("a", null, "b");
assertEquals(2, graph.getNodeDegree("a"));
}
public void testSimpleSubGraph() {
UndiGraph<String, String> graph =
LinkedUndirectedGraph.create();
graph.createNode("a");
graph.createNode("b");
graph.createNode("c");
graph.connect("a", "--", "b");
SubGraph<String, String> subGraph = graph.newSubGraph();
subGraph.addNode("a");
subGraph.addNode("b");
try {
subGraph.addNode("d");
fail("SubGraph should not allow add for node that is not in graph.");
} catch (IllegalArgumentException e) {
// exception expected
}
assertFalse(subGraph.isIndependentOf("a"));
assertFalse(subGraph.isIndependentOf("b"));
assertTrue(subGraph.isIndependentOf("c"));
}
private <T extends GraphNode<String, String>> void assertListCount(
List<T> list, String target, int count) {
for (GraphNode<String, String> node : list) {
if (node.getValue().equals(target)) {
count--;
}
}
assertTrue(count == 0);
}
private <T extends GraphNode<String, String>> void assertSetEquals(
List<T> list, String ... targets) {
Set<String> set = new HashSet<String>();
for (GraphNode<String, String> node : list) {
set.add(node.getValue());
}
Set<String> otherSet = new HashSet<String>();
for (String target : targets) {
otherSet.add(target);
}
assertTrue(otherSet.equals(set));
}
}