blob: 96985b5ba8e4f82810ba61ccd55e0fad6b7e92c4 [file] [log] [blame]
tom2e1f0712014-08-29 13:32:00 -07001package org.onlab.graph;
2
3import org.junit.Test;
4
5import java.util.HashSet;
6import java.util.Set;
7
8import static org.junit.Assert.assertEquals;
9
10/**
11 * Test of the Bellman-Ford algorithm.
12 */
13public class BellmanFordGraphSearchTest extends BreadthFirstSearchTest {
14
15 @Override
16 protected AbstractGraphPathSearch<TestVertex, TestEdge> graphSearch() {
17 return new BellmanFordGraphSearch<>();
18 }
19
20 @Test
21 @Override
22 public void defaultGraphTest() {
23 executeDefaultTest(7, 5, 5.0);
24 }
25
26 @Test
27 public void defaultHopCountWeight() {
28 weight = null;
29 executeDefaultTest(10, 3, 3.0);
30 }
31
32 @Test
33 public void searchGraphWithNegativeCycles() {
tom0633d682014-09-10 12:10:03 -070034 Set<TestVertex> vertexes = new HashSet<>(vertexes());
tom2e1f0712014-08-29 13:32:00 -070035 vertexes.add(Z);
36
37 Set<TestEdge> edges = new HashSet<>(edges());
38 edges.add(new TestEdge(G, Z, 1.0));
39 edges.add(new TestEdge(Z, G, -2.0));
40
tom0633d682014-09-10 12:10:03 -070041 graph = new AdjacencyListsGraph<>(vertexes, edges);
tom2e1f0712014-08-29 13:32:00 -070042
43 GraphPathSearch<TestVertex, TestEdge> search = graphSearch();
tom0633d682014-09-10 12:10:03 -070044 Set<Path<TestVertex, TestEdge>> paths = search.search(graph, A, H, weight).paths();
tom2e1f0712014-08-29 13:32:00 -070045 assertEquals("incorrect paths count", 1, paths.size());
46
47 Path p = paths.iterator().next();
48 assertEquals("incorrect src", A, p.src());
49 assertEquals("incorrect dst", H, p.dst());
50 assertEquals("incorrect path length", 5, p.edges().size());
51 assertEquals("incorrect path cost", 5.0, p.cost(), 0.1);
52
tom0633d682014-09-10 12:10:03 -070053 paths = search.search(graph, A, G, weight).paths();
tom2e1f0712014-08-29 13:32:00 -070054 assertEquals("incorrect paths count", 0, paths.size());
55
tom0633d682014-09-10 12:10:03 -070056 paths = search.search(graph, A, null, weight).paths();
tom2e1f0712014-08-29 13:32:00 -070057 printPaths(paths);
58 assertEquals("incorrect paths count", 6, paths.size());
59 }
60
61}