class QueryExecutorTestCase(unittest.TestCase):
def test_query(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
+ def _user_query(cls, priv_query_exec, obj, params):
nonlocal query_params
query_params = params
- return {
- 'null': None,
- 'bt2': 'BT2',
- }
+ return {'null': None, 'bt2': 'BT2'}
query_params = None
params = {
'array': ['coucou', 23, None],
- 'other_map': {
- 'yes': 'yeah',
- '19': 19,
- 'minus 1.5': -1.5,
- },
+ 'other_map': {'yes': 'yeah', '19': 19, 'minus 1.5': -1.5},
'null': None,
}
- res = bt2.QueryExecutor().query(MySink, 'obj', params)
+ res = bt2.QueryExecutor(MySink, 'obj', params).query()
self.assertEqual(query_params, params)
- self.assertEqual(res, {
- 'null': None,
- 'bt2': 'BT2',
- })
+ self.assertEqual(res, {'null': None, 'bt2': 'BT2'})
del query_params
def test_query_params_none(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
+ def _user_consume(self):
pass
- def _graph_is_configured(self):
+ @classmethod
+ def _user_query(cls, priv_query_exec, obj, params):
+ nonlocal query_params
+ query_params = params
+
+ query_params = 23
+ res = bt2.QueryExecutor(MySink, 'obj', None).query()
+ self.assertIs(query_params, None)
+ del query_params
+
+ def test_query_no_params(self):
+ class MySink(bt2._UserSinkComponent):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
+ def _user_query(cls, priv_query_exec, obj, params):
nonlocal query_params
query_params = params
query_params = 23
- res = bt2.QueryExecutor().query(MySink, 'obj', None)
- self.assertEqual(query_params, None)
+ res = bt2.QueryExecutor(MySink, 'obj').query()
+ self.assertIs(query_params, None)
del query_params
def test_query_logging_level(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
+ def _user_query(cls, priv_query_exec, obj, params):
nonlocal query_log_level
- query_log_level = log_level
+ query_log_level = priv_query_exec.logging_level
query_log_level = None
- res = bt2.QueryExecutor().query(MySink, 'obj', None,
- bt2.LoggingLevel.INFO)
+ query_exec = bt2.QueryExecutor(MySink, 'obj', None)
+ query_exec.logging_level = bt2.LoggingLevel.INFO
+ query_exec.query()
self.assertEqual(query_log_level, bt2.LoggingLevel.INFO)
del query_log_level
def test_query_gen_error(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
+ def _user_query(cls, priv_query_exec, obj, params):
raise ValueError
- with self.assertRaises(bt2.Error):
- res = bt2.QueryExecutor().query(MySink, 'obj', [17, 23])
+ with self.assertRaises(bt2._Error) as ctx:
+ res = bt2.QueryExecutor(MySink, 'obj', [17, 23]).query()
- def test_query_invalid_object(self):
- class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
+ exc = ctx.exception
+ self.assertEqual(len(exc), 2)
+ cause = exc[0]
+ self.assertIsInstance(cause, bt2._ComponentClassErrorCause)
+ self.assertIn('raise ValueError', cause.message)
+ self.assertEqual(cause.component_class_type, bt2.ComponentClassType.SINK)
+ self.assertEqual(cause.component_class_name, 'MySink')
- def _graph_is_configured(self):
+ def test_query_unknown_object(self):
+ class MySink(bt2._UserSinkComponent):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
- raise bt2.InvalidObject
+ def _user_query(cls, priv_query_exec, obj, params):
+ raise bt2.UnknownObject
- with self.assertRaises(bt2.InvalidObject):
- res = bt2.QueryExecutor().query(MySink, 'obj', [17, 23])
+ with self.assertRaises(bt2.UnknownObject):
+ res = bt2.QueryExecutor(MySink, 'obj', [17, 23]).query()
def test_query_logging_level_invalid_type(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
+ def _user_query(cls, priv_query_exec, obj, params):
pass
+ query_exec = bt2.QueryExecutor(MySink, 'obj', [17, 23])
+
with self.assertRaises(TypeError):
- res = bt2.QueryExecutor().query(MySink, 'obj', [17, 23], 'yeah')
+ query_exec.logging_level = 'yeah'
def test_query_logging_level_invalid_value(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
+ def _user_query(cls, priv_query_exec, obj, params):
pass
+ query_exec = bt2.QueryExecutor(MySink, 'obj', [17, 23])
+
with self.assertRaises(ValueError):
- res = bt2.QueryExecutor().query(MySink, 'obj', [17, 23], 12345)
+ query_exec.logging_level = 12345
- def test_query_invalid_params(self):
+ def test_query_try_again(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
- raise bt2.InvalidParams
+ def _user_query(cls, priv_query_exec, obj, params):
+ raise bt2.TryAgain
- with self.assertRaises(bt2.InvalidParams):
- res = bt2.QueryExecutor().query(MySink, 'obj', [17, 23])
+ with self.assertRaises(bt2.TryAgain):
+ res = bt2.QueryExecutor(MySink, 'obj', [17, 23]).query()
- def test_query_try_again(self):
+ def test_query_add_interrupter(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
+ def _user_consume(self):
pass
- def _graph_is_configured(self):
+ @classmethod
+ def _user_query(cls, priv_query_exec, obj, params):
+ nonlocal interrupter2
+ test_self.assertFalse(query_exec.is_interrupted)
+ interrupter2.set()
+ test_self.assertTrue(query_exec.is_interrupted)
+ interrupter2.reset()
+ test_self.assertFalse(query_exec.is_interrupted)
+
+ interrupter1 = bt2.Interrupter()
+ interrupter2 = bt2.Interrupter()
+ test_self = self
+ query_exec = bt2.QueryExecutor(MySink, 'obj', [17, 23])
+ query_exec.add_interrupter(interrupter1)
+ query_exec.add_interrupter(interrupter2)
+ query_exec.query()
+
+ def test_query_interrupt(self):
+ class MySink(bt2._UserSinkComponent):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
- raise bt2.TryAgain
-
- with self.assertRaises(bt2.TryAgain):
- res = bt2.QueryExecutor().query(MySink, 'obj', [17, 23])
+ def _user_query(cls, priv_query_exec, obj, params):
+ test_self.assertFalse(query_exec.is_interrupted)
+ query_exec.interrupt()
+ test_self.assertTrue(query_exec.is_interrupted)
- def test_cancel_no_query(self):
- query_exec = bt2.QueryExecutor()
- self.assertFalse(query_exec.is_canceled)
- query_exec.cancel()
- self.assertTrue(query_exec.is_canceled)
+ test_self = self
+ query_exec = bt2.QueryExecutor(MySink, 'obj', [17, 23])
+ query_exec.query()
- def test_query_canceled(self):
+ def test_query_priv_executor_invalid_after(self):
class MySink(bt2._UserSinkComponent):
- def _consume(self):
- pass
-
- def _graph_is_configured(self):
+ def _user_consume(self):
pass
@classmethod
- def _query(cls, query_exec, obj, params, log_level):
- raise bt2.TryAgain
+ def _user_query(cls, priv_query_exec, obj, params):
+ nonlocal test_priv_query_exec
+ test_priv_query_exec = priv_query_exec
+
+ test_priv_query_exec = None
+ query_exec = bt2.QueryExecutor(MySink, 'obj', [17, 23])
+ query_exec.query()
+ assert test_priv_query_exec is not None
- query_exec = bt2.QueryExecutor()
- query_exec.cancel()
+ with self.assertRaises(RuntimeError):
+ test_priv_query_exec.logging_level
- with self.assertRaises(bt2.Canceled):
- res = query_exec.query(MySink, 'obj', [17, 23])
+ del test_priv_query_exec