blob: 4ee90064832aa2cf6715261d84748fdd6a3287e9 [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() {
34 Set<TestVertex> vertexes = new HashSet<>(vertices());
35 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
41 g = new AdjacencyListsGraph<>(vertexes, edges);
42
43 GraphPathSearch<TestVertex, TestEdge> search = graphSearch();
44 Set<Path<TestVertex, TestEdge>> paths = search.search(g, A, H, weight).paths();
45 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
53 paths = search.search(g, A, G, weight).paths();
54 assertEquals("incorrect paths count", 0, paths.size());
55
56 paths = search.search(g, A, null, weight).paths();
57 printPaths(paths);
58 assertEquals("incorrect paths count", 6, paths.size());
59 }
60
61}