X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=tests%2Fbindings%2Fpython%2Fbt2%2Ftest_component.py;h=137a0ddb987b6ddba303f9f1bb018cfb8db35227;hb=768f9bcbf4b5acd09dda85ab32c0ea30d8826136;hp=65338c199b5946b5e7da0ce586dea54d281527d4;hpb=056deb59eb33e87c06c0067907768ab08aff74a2;p=babeltrace.git diff --git a/tests/bindings/python/bt2/test_component.py b/tests/bindings/python/bt2/test_component.py index 65338c19..137a0ddb 100644 --- a/tests/bindings/python/bt2/test_component.py +++ b/tests/bindings/python/bt2/test_component.py @@ -1,23 +1,11 @@ +# SPDX-License-Identifier: GPL-2.0-only # # Copyright (C) 2019 EfficiOS Inc. # -# This program is free software; you can redistribute it and/or -# modify it under the terms of the GNU General Public License -# as published by the Free Software Foundation; only version 2 -# of the License. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -# import unittest import bt2 +from bt2 import component as bt2_component class UserComponentTestCase(unittest.TestCase): @@ -32,37 +20,37 @@ class UserComponentTestCase(unittest.TestCase): def test_name(self): class MySink(bt2._UserSinkComponent): - def __init__(comp_self, params, obj): + def __init__(comp_self, config, params, obj): self.assertEqual(comp_self.name, 'yaes') def _user_consume(self): pass - comp = self._create_comp(MySink, 'yaes') + self._create_comp(MySink, 'yaes') def test_logging_level(self): class MySink(bt2._UserSinkComponent): - def __init__(comp_self, params, obj): + def __init__(comp_self, config, params, obj): self.assertEqual(comp_self.logging_level, bt2.LoggingLevel.INFO) def _user_consume(self): pass - comp = self._create_comp(MySink, 'yaes', bt2.LoggingLevel.INFO) + self._create_comp(MySink, 'yaes', bt2.LoggingLevel.INFO) def test_graph_mip_version(self): class MySink(bt2._UserSinkComponent): - def __init__(comp_self, params, obj): + def __init__(comp_self, config, params, obj): self.assertEqual(comp_self._graph_mip_version, 0) def _user_consume(self): pass - comp = self._create_comp(MySink, 'yaes', bt2.LoggingLevel.INFO) + self._create_comp(MySink, 'yaes', bt2.LoggingLevel.INFO) def test_class(self): class MySink(bt2._UserSinkComponent): - def __init__(comp_self, params, obj): + def __init__(comp_self, config, params, obj): self.assertEqual(comp_self.cls, MySink) def _user_consume(self): @@ -72,7 +60,7 @@ class UserComponentTestCase(unittest.TestCase): def test_addr(self): class MySink(bt2._UserSinkComponent): - def __init__(comp_self, params, obj): + def __init__(comp_self, config, params, obj): self.assertIsInstance(comp_self.addr, int) self.assertNotEqual(comp_self.addr, 0) @@ -99,6 +87,43 @@ class UserComponentTestCase(unittest.TestCase): del comp self.assertTrue(finalized) + def test_source_component_config(self): + class MySource( + bt2._UserSourceComponent, message_iterator_class=bt2._UserMessageIterator + ): + def __init__(comp_self, config, params, obj): + nonlocal cfg_type + cfg_type = type(config) + + cfg_type = None + self._create_comp(MySource) + self.assertIs(cfg_type, bt2_component._UserSourceComponentConfiguration) + + def test_filter_component_config(self): + class MyFilter( + bt2._UserFilterComponent, message_iterator_class=bt2._UserMessageIterator + ): + def __init__(comp_self, config, params, obj): + nonlocal cfg_type + cfg_type = type(config) + + cfg_type = None + self._create_comp(MyFilter) + self.assertIs(cfg_type, bt2_component._UserFilterComponentConfiguration) + + def test_sink_component_config(self): + class MySink(bt2._UserSinkComponent): + def __init__(comp_self, config, params, obj): + nonlocal cfg_type + cfg_type = type(config) + + def _user_consume(self): + pass + + cfg_type = None + self._create_comp(MySink) + self.assertIs(cfg_type, bt2_component._UserSinkComponentConfiguration) + class GenericComponentTestCase(unittest.TestCase): @staticmethod @@ -142,3 +167,7 @@ class GenericComponentTestCase(unittest.TestCase): comp = self._create_comp(MySink) self.assertIsInstance(comp.addr, int) self.assertNotEqual(comp.addr, 0) + + +if __name__ == '__main__': + unittest.main()