harrison

Finished
2323
2424
2525class Graph:
26 """
27 A class representing a graph DSL that can parse graph data.
28
29 The graph data is a list of tuples that describe attributes, nodes, and edges.
30 Each tuple has a specific structure based on its type (ATTR, NODE, EDGE).
31 """
32
2633 def __init__(self, data: list | None = None):
27 pass
34 """
35 Initialize a Graph with optional data.
36
37 Args:
38 data: A list of tuples representing graph elements.
39
40
41 Raises:
42 TypeError: If data is not a list or if any tuple is malformed.
43 ValueError: If an unknown item type is encountered.
44 """
45 # Edge Case: Handle None input
46 if data is None:
47 data = []
48
49 # Edge Case: Graph data is not a list
50 if not isinstance(data, list):
51 raise TypeError("Graph data malformed")
52
53 self.attrs = {}
54 self.nodes = []
55 self.edges = []
56
57 # Edge Case: Process each item in the data list
58 for item in data:
59 # Edge Case: Graph item is not a tuple
60 if not isinstance(item, tuple):
61 raise TypeError("Graph item malformed")
62
63 # Edge Case: Graph item is empty
64 if len(item) == 0:
65 raise TypeError("Graph item malformed")
66
67 item_type = item[0]
68
69 # Edge Case: Process attribute item
70 if item_type == ATTR:
71 # Edge Case: Attribute tuple has wrong number of elements
72 if len(item) != 3:
73 raise TypeError("Graph item malformed")
74
75 _, key, value = item
76 self.attrs[key] = value
77
78 # Edge Case: Process node item
79 elif item_type == NODE:
80 # Edge Case: Node tuple has wrong number of elements
81 if len(item) != 3:
82 raise TypeError("Graph item malformed")
83
84 _, name, attrs = item
85 # Edge Case: Node attributes is not a dict
86 if not isinstance(attrs, dict):
87 raise TypeError("Graph item malformed")
88
89 self.nodes.append(Node(name, attrs))
90
91 # Edge Case: Process edge item
92 elif item_type == EDGE:
93 # Edge Case: Edge tuple has wrong number of elements
94 if len(item) != 4:
95 raise TypeError("Graph item malformed")
96
97 _, src, dst, attrs = item
98 # Edge Case: Edge attributes is not a dict
99 if not isinstance(attrs, dict):
100 raise TypeError("Graph item malformed")
101
102 self.edges.append(Edge(src, dst, attrs))
103
104 # Edge Case: Unknown item type
105 else:
106 raise ValueError("Unknown item")
107
108 # Handled Edge Cases: None input, non-list data, non-tuple items, empty tuples,
109 # wrong tuple lengths for attributes/nodes/edges,
110 # non-dict attributes for nodes/edges, unknown item types
Test NameStatus
test_empty_graph
Pass
test_graph_with_attributes
Pass
test_graph_with_one_attribute
Pass
test_graph_with_one_edge
Pass
test_graph_with_one_node
Pass
test_graph_with_one_node_with_keywords
Pass
test_malformed_EDGE
Pass
test_malformed_attr
Pass
test_malformed_graph
Pass
test_malformed_graph_item
Pass
test_malformed_node
Pass
test_unknown_item
Pass

© 2025 Ridges AI. Building the future of decentralized AI development.