test_digraph_historical.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. """Original NetworkX graph tests"""
  2. import pytest
  3. import networkx
  4. import networkx as nx
  5. from .historical_tests import HistoricalTests
  6. class TestDiGraphHistorical(HistoricalTests):
  7. @classmethod
  8. def setup_class(cls):
  9. HistoricalTests.setup_class()
  10. cls.G = nx.DiGraph
  11. def test_in_degree(self):
  12. G = self.G()
  13. G.add_nodes_from("GJK")
  14. G.add_edges_from([("A", "B"), ("A", "C"), ("B", "D"), ("B", "C"), ("C", "D")])
  15. assert sorted(d for n, d in G.in_degree()) == [0, 0, 0, 0, 1, 2, 2]
  16. assert dict(G.in_degree()) == {
  17. "A": 0,
  18. "C": 2,
  19. "B": 1,
  20. "D": 2,
  21. "G": 0,
  22. "K": 0,
  23. "J": 0,
  24. }
  25. def test_out_degree(self):
  26. G = self.G()
  27. G.add_nodes_from("GJK")
  28. G.add_edges_from([("A", "B"), ("A", "C"), ("B", "D"), ("B", "C"), ("C", "D")])
  29. assert sorted(v for k, v in G.in_degree()) == [0, 0, 0, 0, 1, 2, 2]
  30. assert dict(G.out_degree()) == {
  31. "A": 2,
  32. "C": 1,
  33. "B": 2,
  34. "D": 0,
  35. "G": 0,
  36. "K": 0,
  37. "J": 0,
  38. }
  39. def test_degree_digraph(self):
  40. H = nx.DiGraph()
  41. H.add_edges_from([(1, 24), (1, 2)])
  42. assert sorted(d for n, d in H.in_degree([1, 24])) == [0, 1]
  43. assert sorted(d for n, d in H.out_degree([1, 24])) == [0, 2]
  44. assert sorted(d for n, d in H.degree([1, 24])) == [1, 2]
  45. def test_neighbors(self):
  46. G = self.G()
  47. G.add_nodes_from("GJK")
  48. G.add_edges_from([("A", "B"), ("A", "C"), ("B", "D"), ("B", "C"), ("C", "D")])
  49. assert sorted(G.neighbors("C")) == ["D"]
  50. assert sorted(G["C"]) == ["D"]
  51. assert sorted(G.neighbors("A")) == ["B", "C"]
  52. pytest.raises(nx.NetworkXError, G.neighbors, "j")
  53. pytest.raises(nx.NetworkXError, G.neighbors, "j")
  54. def test_successors(self):
  55. G = self.G()
  56. G.add_nodes_from("GJK")
  57. G.add_edges_from([("A", "B"), ("A", "C"), ("B", "D"), ("B", "C"), ("C", "D")])
  58. assert sorted(G.successors("A")) == ["B", "C"]
  59. assert sorted(G.successors("A")) == ["B", "C"]
  60. assert sorted(G.successors("G")) == []
  61. assert sorted(G.successors("D")) == []
  62. assert sorted(G.successors("G")) == []
  63. pytest.raises(nx.NetworkXError, G.successors, "j")
  64. pytest.raises(nx.NetworkXError, G.successors, "j")
  65. def test_predecessors(self):
  66. G = self.G()
  67. G.add_nodes_from("GJK")
  68. G.add_edges_from([("A", "B"), ("A", "C"), ("B", "D"), ("B", "C"), ("C", "D")])
  69. assert sorted(G.predecessors("C")) == ["A", "B"]
  70. assert sorted(G.predecessors("C")) == ["A", "B"]
  71. assert sorted(G.predecessors("G")) == []
  72. assert sorted(G.predecessors("A")) == []
  73. assert sorted(G.predecessors("G")) == []
  74. assert sorted(G.predecessors("A")) == []
  75. assert sorted(G.successors("D")) == []
  76. pytest.raises(nx.NetworkXError, G.predecessors, "j")
  77. pytest.raises(nx.NetworkXError, G.predecessors, "j")
  78. def test_reverse(self):
  79. G = nx.complete_graph(10)
  80. H = G.to_directed()
  81. HR = H.reverse()
  82. assert nx.is_isomorphic(H, HR)
  83. assert sorted(H.edges()) == sorted(HR.edges())
  84. def test_reverse2(self):
  85. H = nx.DiGraph()
  86. foo = [H.add_edge(u, u + 1) for u in range(0, 5)]
  87. HR = H.reverse()
  88. for u in range(0, 5):
  89. assert HR.has_edge(u + 1, u)
  90. def test_reverse3(self):
  91. H = nx.DiGraph()
  92. H.add_nodes_from([1, 2, 3, 4])
  93. HR = H.reverse()
  94. assert sorted(HR.nodes()) == [1, 2, 3, 4]