X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=tests%2Fbindings%2Fpython%2Fbt2%2Ftest_graph.py;h=7c18e8a79256a98afde305af9300614a906db708;hb=5c61fb9d5be835a0efc87f7764117c4d05e0ae5a;hp=8c2a0621f2f0b6bcbed107dface114a2ab5a561b;hpb=401b70220ef76fa7b420f6c6d55c2d5bdecb931c;p=babeltrace.git diff --git a/tests/bindings/python/bt2/test_graph.py b/tests/bindings/python/bt2/test_graph.py index 8c2a0621..7c18e8a7 100644 --- a/tests/bindings/python/bt2/test_graph.py +++ b/tests/bindings/python/bt2/test_graph.py @@ -65,6 +65,10 @@ class GraphTestCase(unittest.TestCase): with self.assertRaisesRegex(ValueError, 'unknown MIP version'): bt2.Graph(1) + def test_default_interrupter(self): + interrupter = self._graph.default_interrupter + self.assertIs(type(interrupter), bt2.Interrupter) + def test_add_component_user_cls(self): class MySink(bt2._UserSinkComponent): def _user_consume(self): @@ -212,11 +216,9 @@ class GraphTestCase(unittest.TestCase): self.assertEqual(comp.logging_level, bt2.LoggingLevel.DEBUG) def test_connect_ports(self): - class MyIter(bt2._UserMessageIterator): - def __next__(self): - raise bt2.Stop - - class MySource(bt2._UserSourceComponent, message_iterator_class=MyIter): + class MySource( + bt2._UserSourceComponent, message_iterator_class=bt2._UserMessageIterator + ): def __init__(self, config, params, obj): self._add_output_port('out') @@ -239,11 +241,9 @@ class GraphTestCase(unittest.TestCase): self.assertEqual(sink.input_ports['in'].connection.addr, conn.addr) def test_connect_ports_invalid_direction(self): - class MyIter(bt2._UserMessageIterator): - def __next__(self): - raise bt2.Stop - - class MySource(bt2._UserSourceComponent, message_iterator_class=MyIter): + class MySource( + bt2._UserSourceComponent, message_iterator_class=bt2._UserMessageIterator + ): def __init__(self, config, params, obj): self._add_output_port('out') @@ -321,7 +321,7 @@ class GraphTestCase(unittest.TestCase): def _user_consume(self): # Pretend that somebody asynchronously interrupted the graph. nonlocal graph - graph.interrupt() + graph.default_interrupter.set() return next(self._msg_iter) def _user_graph_is_configured(self): @@ -551,11 +551,9 @@ class GraphTestCase(unittest.TestCase): self._graph.run() def test_listeners(self): - class MyIter(bt2._UserMessageIterator): - def __next__(self): - raise bt2.Stop - - class MySource(bt2._UserSourceComponent, message_iterator_class=MyIter): + class MySource( + bt2._UserSourceComponent, message_iterator_class=bt2._UserMessageIterator + ): def __init__(self, config, params, obj): self._add_output_port('out') self._add_output_port('zero') @@ -574,28 +572,13 @@ class GraphTestCase(unittest.TestCase): nonlocal calls calls.append((port_added_listener, component, port)) - def ports_connected_listener( - upstream_component, upstream_port, downstream_component, downstream_port - ): - nonlocal calls - calls.append( - ( - ports_connected_listener, - upstream_component, - upstream_port, - downstream_component, - downstream_port, - ) - ) - calls = [] self._graph.add_port_added_listener(port_added_listener) - self._graph.add_ports_connected_listener(ports_connected_listener) src = self._graph.add_component(MySource, 'src') sink = self._graph.add_component(MySink, 'sink') self._graph.connect_ports(src.output_ports['out'], sink.input_ports['in']) - self.assertEqual(len(calls), 5) + self.assertEqual(len(calls), 4) self.assertIs(calls[0][0], port_added_listener) self.assertEqual(calls[0][1].name, 'src') @@ -613,18 +596,10 @@ class GraphTestCase(unittest.TestCase): self.assertEqual(calls[3][1].name, 'sink') self.assertEqual(calls[3][2].name, 'taste') - self.assertIs(calls[4][0], ports_connected_listener) - self.assertEqual(calls[4][1].name, 'src') - self.assertEqual(calls[4][2].name, 'out') - self.assertEqual(calls[4][3].name, 'sink') - self.assertEqual(calls[4][4].name, 'in') - def test_invalid_listeners(self): - class MyIter(bt2._UserMessageIterator): - def __next__(self): - raise bt2.Stop - - class MySource(bt2._UserSourceComponent, message_iterator_class=MyIter): + class MySource( + bt2._UserSourceComponent, message_iterator_class=bt2._UserMessageIterator + ): def __init__(self, config, params, obj): self._add_output_port('out') self._add_output_port('zero') @@ -641,8 +616,6 @@ class GraphTestCase(unittest.TestCase): with self.assertRaises(TypeError): self._graph.add_port_added_listener(1234) - with self.assertRaises(TypeError): - self._graph.add_ports_connected_listener(1234) def test_raise_in_component_init(self): class MySink(bt2._UserSinkComponent): @@ -674,35 +647,6 @@ class GraphTestCase(unittest.TestCase): with self.assertRaises(bt2._Error): graph.add_component(MySink, 'comp') - def test_raise_in_ports_connected_listener(self): - class MyIter(bt2._UserMessageIterator): - def __next__(self): - raise bt2.Stop - - class MySource(bt2._UserSourceComponent, message_iterator_class=MyIter): - def __init__(self, config, params, obj): - self._add_output_port('out') - - class MySink(bt2._UserSinkComponent): - def __init__(self, config, params, obj): - self._add_input_port('in') - - def _user_consume(self): - raise bt2.Stop - - def ports_connected_listener( - upstream_component, upstream_port, downstream_component, downstream_port - ): - raise ValueError('oh noes!') - - graph = bt2.Graph() - graph.add_ports_connected_listener(ports_connected_listener) - up = graph.add_component(MySource, 'down') - down = graph.add_component(MySink, 'up') - - with self.assertRaises(bt2._Error): - graph.connect_ports(up.output_ports['out'], down.input_ports['in']) - if __name__ == '__main__': unittest.main()