import collections.abc
import bt2.ctf_writer
import bt2.stream
-import copy
import bt2
-class _EventClassIterator(collections.abc.Iterator):
- def __init__(self, stream_class):
- self._stream_class = stream_class
- self._at = 0
-
- def __next__(self):
- if self._at == len(self._stream_class):
- raise StopIteration
-
- ec_ptr = native_bt.stream_class_get_event_class_by_index(self._stream_class._ptr,
- self._at)
- assert(ec_ptr)
- ev_id = native_bt.event_class_get_id(ec_ptr)
- native_bt.put(ec_ptr)
- utils._handle_ret(ev_id, "cannot get event class object's ID")
- self._at += 1
- return ev_id
-
-
class StreamClass(object._SharedObject, collections.abc.Mapping):
_get_ref = staticmethod(native_bt.stream_class_get_ref)
_put_ref = staticmethod(native_bt.stream_class_put_ref)
- def __init__(self, name=None, id=None, packet_context_field_class=None,
- event_header_field_class=None, event_context_field_class=None,
- event_classes=None):
- ptr = native_bt.stream_class_create_empty(None)
-
- if ptr is None:
- raise bt2.CreationError('cannot create stream class object')
-
- super().__init__(ptr)
-
- if name is not None:
- self.name = name
-
- if id is not None:
- self.id = id
-
- if packet_context_field_class is not None:
- self.packet_context_field_class = packet_context_field_class
-
- if event_header_field_class is not None:
- self.event_header_field_class = event_header_field_class
-
- if event_context_field_class is not None:
- self.event_context_field_class = event_context_field_class
-
- if event_classes is not None:
- for event_class in event_classes:
- self.add_event_class(event_class)
-
def __getitem__(self, key):
utils._check_int64(key)
- ec_ptr = native_bt.stream_class_get_event_class_by_id(self._ptr,
- key)
+ ec_ptr = native_bt.stream_class_borrow_event_class_by_id(self._ptr, key)
if ec_ptr is None:
raise KeyError(key)
- return bt2.EventClass._create_from_ptr(ec_ptr)
+ return bt2.EventClass._create_from_ptr_and_get_ref(ec_ptr)
def __len__(self):
count = native_bt.stream_class_get_event_class_count(self._ptr)
- assert(count >= 0)
+ assert count >= 0
return count
def __iter__(self):
- return _EventClassIterator(self)
+ for idx in range(len(self)):
+ ec_ptr = native_bt.stream_class_borrow_event_class_by_index_const(self._ptr, idx)
+ assert ec_ptr is not None
+
+ id = native_bt.event_class_get_id(ec_ptr)
+ assert id >= 0
+
+ yield id
- def add_event_class(self, event_class):
- utils._check_type(event_class, bt2.EventClass)
- ret = native_bt.stream_class_add_event_class(self._ptr, event_class._ptr)
- utils._handle_ret(ret, "cannot add event class object to stream class object's")
+ def create_event_class(self, id=None):
+ if self.assigns_automatic_event_class_id:
+ if id is not None:
+ raise bt2.CreationError('id provided, but stream class assigns automatic event class ids')
+
+ ec_ptr = native_bt.event_class_create(self._ptr)
+ else:
+ if id is None:
+ raise bt2.CreationError('id not provided, but stream class does not assign automatic event class ids')
+
+ utils._check_uint64(id)
+ ec_ptr = native_bt.event_class_create_with_id(self._ptr, id)
+
+ return bt2.event_class.EventClass._create_from_ptr(ec_ptr)
@property
- def trace(self):
- tc_ptr = native_bt.stream_class_get_trace(self._ptr)
+ def trace_class(self):
+ tc_ptr = native_bt.stream_class_borrow_trace_class_const(self._ptr)
if tc_ptr is not None:
- return bt2.Trace._create_from_ptr(tc_ptr)
+ return bt2.TraceClass._create_from_ptr_and_get_ref(tc_ptr)
@property
def name(self):
return native_bt.stream_class_get_name(self._ptr)
- @name.setter
- def name(self, name):
+ def _name(self, name):
utils._check_str(name)
ret = native_bt.stream_class_set_name(self._ptr, name)
utils._handle_ret(ret, "cannot set stream class object's name")
+ _name = property(fset=_name)
+
+ @property
+ def assigns_automatic_event_class_id(self):
+ return native_bt.stream_class_assigns_automatic_event_class_id(self._ptr)
+
+ def _assigns_automatic_event_class_id(self, auto_id):
+ utils._check_bool(auto_id)
+ return native_bt.stream_class_set_assigns_automatic_event_class_id(self._ptr, auto_id)
+
+ _assigns_automatic_event_class_id = property(fset=_assigns_automatic_event_class_id)
+
@property
def assigns_automatic_stream_id(self):
return native_bt.stream_class_assigns_automatic_stream_id(self._ptr)
_assigns_automatic_stream_id = property(fset=_assigns_automatic_stream_id)
+ @property
+ def packets_have_default_beginning_clock_snapshot(self):
+ return native_bt.stream_class_packets_have_default_beginning_clock_snapshot(self._ptr)
+
+ def _packets_have_default_beginning_clock_snapshot(self, value):
+ utils._check_bool(value)
+ native_bt.stream_class_set_packets_have_default_beginning_clock_snapshot(self._ptr, value)
+
+ _packets_have_default_beginning_clock_snapshot = property(fset=_packets_have_default_beginning_clock_snapshot)
+
+ @property
+ def packets_have_default_end_clock_snapshot(self):
+ return native_bt.stream_class_packets_have_default_end_clock_snapshot(self._ptr)
+
+ def _packets_have_default_end_clock_snapshot(self, value):
+ utils._check_bool(value)
+ native_bt.stream_class_set_packets_have_default_end_clock_snapshot(self._ptr, value)
+
+ _packets_have_default_end_clock_snapshot = property(fset=_packets_have_default_end_clock_snapshot)
+
@property
def id(self):
id = native_bt.stream_class_get_id(self._ptr)
@property
def packet_context_field_class(self):
- fc_ptr = native_bt.stream_class_get_packet_context_type(self._ptr)
+ fc_ptr = native_bt.stream_class_borrow_packet_context_field_class_const(self._ptr)
if fc_ptr is None:
return
- return bt2.field_class._create_from_ptr(fc_ptr)
-
- @packet_context_field_class.setter
- def packet_context_field_class(self, packet_context_field_class):
- packet_context_field_class_ptr = None
+ return bt2.field_class._create_field_class_from_ptr_and_get_ref(fc_ptr)
+ def _packet_context_field_class(self, packet_context_field_class):
if packet_context_field_class is not None:
- utils._check_type(packet_context_field_class, bt2.field_class._FieldClass)
- packet_context_field_class_ptr = packet_context_field_class._ptr
+ utils._check_type(packet_context_field_class,
+ bt2.field_class._StructureFieldClass)
+ ret = native_bt.stream_class_set_packet_context_field_class(self._ptr,
+ packet_context_field_class._ptr)
+ utils._handle_ret(ret, "cannot set stream class' packet context field class")
- ret = native_bt.stream_class_set_packet_context_type(self._ptr,
- packet_context_field_class_ptr)
- utils._handle_ret(ret, "cannot set stream class object's packet context field class")
+ _packet_context_field_class = property(fset=_packet_context_field_class)
@property
- def event_header_field_class(self):
- fc_ptr = native_bt.stream_class_get_event_header_type(self._ptr)
+ def event_common_context_field_class(self):
+ fc_ptr = native_bt.stream_class_borrow_event_common_context_field_class_const(self._ptr)
if fc_ptr is None:
return
- return bt2.field_class._create_from_ptr(fc_ptr)
+ return bt2.field_class._create_field_class_from_ptr_and_get_ref(fc_ptr)
- @event_header_field_class.setter
- def event_header_field_class(self, event_header_field_class):
- event_header_field_class_ptr = None
+ def _event_common_context_field_class(self, event_common_context_field_class):
+ if event_common_context_field_class is not None:
+ utils._check_type(event_common_context_field_class,
+ bt2.field_class._StructureFieldClass)
- if event_header_field_class is not None:
- utils._check_type(event_header_field_class, bt2.field_class._FieldClass)
- event_header_field_class_ptr = event_header_field_class._ptr
+ set_context_fn = native_bt.stream_class_set_event_common_context_field_class
+ ret = set_context_fn(self._ptr, event_common_context_field_class._ptr)
- ret = native_bt.stream_class_set_event_header_type(self._ptr,
- event_header_field_class_ptr)
- utils._handle_ret(ret, "cannot set stream class object's event header field class")
+ utils._handle_ret(ret, "cannot set stream class' event context field type")
- @property
- def event_context_field_class(self):
- fc_ptr = native_bt.stream_class_get_event_context_type(self._ptr)
+ _event_common_context_field_class = property(fset=_event_common_context_field_class)
- if fc_ptr is None:
+ @property
+ def default_clock_class(self):
+ cc_ptr = native_bt.stream_class_borrow_default_clock_class(self._ptr)
+ if cc_ptr is None:
return
- return bt2.field_class._create_from_ptr(fc_ptr)
-
- @event_context_field_class.setter
- def event_context_field_class(self, event_context_field_class):
- event_context_field_class_ptr = None
-
- if event_context_field_class is not None:
- utils._check_type(event_context_field_class, bt2.field_class._FieldClass)
- event_context_field_class_ptr = event_context_field_class._ptr
+ return bt2.clock_class.ClockClass._create_from_ptr_and_get_ref(cc_ptr)
- ret = native_bt.stream_class_set_event_context_type(self._ptr,
- event_context_field_class_ptr)
- utils._handle_ret(ret, "cannot set stream class object's event context field class")
+ def _default_clock_class(self, clock_class):
+ utils._check_type(clock_class, bt2.clock_class.ClockClass)
+ native_bt.stream_class_set_default_clock_class(
+ self._ptr, clock_class._ptr)
- def __call__(self, name=None, id=None):
- if name is not None:
- utils._check_str(name)
-
- if id is None:
- stream_ptr = native_bt.stream_create(self._ptr, name)
- else:
- stream_ptr = native_bt.stream_create_with_id(self._ptr, name, id)
-
- if stream_ptr is None:
- raise bt2.CreationError('cannot create stream object')
-
- return bt2.stream._create_from_ptr(stream_ptr)
-
- def __eq__(self, other):
- if type(other) is not type(self):
- return False
-
- if self.addr == other.addr:
- return True
-
- self_event_classes = list(self.values())
- other_event_classes = list(other.values())
- self_props = (
- self_event_classes,
- self.name,
- self.id,
- self.packet_context_field_class,
- self.event_header_field_class,
- self.event_context_field_class,
- self.clock,
- )
- other_props = (
- other_event_classes,
- other.name,
- other.id,
- other.packet_context_field_class,
- other.event_header_field_class,
- other.event_context_field_class,
- other.clock,
- )
-
- return self_props == other_props
-
- def _copy(self, fc_copy_func, ev_copy_func):
- cpy = StreamClass()
-
- if self.id is not None:
- cpy.id = self.id
-
- if self.name is not None:
- cpy.name = self.name
-
- if self.clock is not None:
- cpy.clock = self.clock
-
- cpy.packet_context_field_class = fc_copy_func(self.packet_context_field_class)
- cpy.event_header_field_class = fc_copy_func(self.event_header_field_class)
- cpy.event_context_field_class = fc_copy_func(self.event_context_field_class)
-
- for event_class in self.values():
- cpy.add_event_class(ev_copy_func(event_class))
-
- return cpy
-
- def __copy__(self):
- return self._copy(lambda fc: fc, copy.copy)
-
- def __deepcopy__(self, memo):
- cpy = self._copy(copy.deepcopy, copy.deepcopy)
- memo[id(self)] = cpy
- return cpy
+ _default_clock_class = property(fset=_default_clock_class)
-from bt2 import value
import unittest
-import copy
import bt2
+from utils import run_in_component_init
-@unittest.skip("this is broken")
class StreamClassTestCase(unittest.TestCase):
def setUp(self):
- self._packet_context_fc = bt2.StructureFieldClass()
- self._packet_context_fc.append_field('menu', bt2.FloatingPointNumberFieldClass())
- self._packet_context_fc.append_field('sticker', bt2.StringFieldClass())
- self._event_header_fc = bt2.StructureFieldClass()
- self._event_header_fc.append_field('id', bt2.IntegerFieldClass(19))
- self._event_context_fc = bt2.StructureFieldClass()
- self._event_context_fc.append_field('msg', bt2.StringFieldClass())
- self._ec1, self._ec2 = self._create_event_classes()
- self._sc = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(self._ec1, self._ec2))
-
- def tearDown(self):
- del self._packet_context_fc
- del self._event_header_fc
- del self._event_context_fc
- del self._ec1
- del self._sc
-
- def _create_event_classes(self):
- context_fc = bt2.StructureFieldClass()
- context_fc.append_field('allo', bt2.StringFieldClass())
- context_fc.append_field('zola', bt2.IntegerFieldClass(18))
- payload_fc = bt2.StructureFieldClass()
- payload_fc.append_field('zoom', bt2.StringFieldClass())
- ec1 = bt2.EventClass('event23', id=23, context_field_class=context_fc,
- payload_field_class=payload_fc)
- ec2 = bt2.EventClass('event17', id=17, context_field_class=payload_fc,
- payload_field_class=context_fc)
- return ec1, ec2
-
- def test_create(self):
- self.assertEqual(self._sc.name, 'my_stream_class')
- self.assertEqual(self._sc.id, 12)
- self.assertEqual(self._sc.packet_context_field_class, self._packet_context_fc)
- self.assertEqual(self._sc.event_header_field_class, self._event_header_fc)
- self.assertEqual(self._sc.event_context_field_class, self._event_context_fc)
- self.assertEqual(self._sc[23], self._ec1)
- self.assertEqual(self._sc[17], self._ec2)
- self.assertEqual(len(self._sc), 2)
-
- def test_assign_name(self):
- self._sc.name = 'lel'
- self.assertEqual(self._sc.name, 'lel')
-
- def test_assign_invalid_name(self):
+ def f(comp_self):
+ tc = comp_self._create_trace_class(assigns_automatic_stream_class_id=True)
+ cc = comp_self._create_clock_class()
+ return tc, cc
+
+ self._tc, self._cc = run_in_component_init(f)
+ self._trace = self._tc()
+
+ def test_create_default(self):
+ sc = self._tc.create_stream_class()
+
+ self.assertIsNone(sc.name)
+ self.assertIsNone(sc.packet_context_field_class)
+ self.assertIsNone(sc.event_common_context_field_class)
+ self.assertIsNone(sc.default_clock_class)
+ self.assertTrue(sc.assigns_automatic_event_class_id)
+ self.assertTrue(sc.assigns_automatic_stream_id)
+ self.assertFalse(sc.packets_have_default_beginning_clock_snapshot)
+ self.assertFalse(sc.packets_have_default_end_clock_snapshot)
+
+ def test_create_name(self):
+ sc = self._tc.create_stream_class(name='bozo')
+ self.assertEqual(sc.name, 'bozo')
+
+ def test_create_invalid_name(self):
with self.assertRaises(TypeError):
- self._sc.name = 17
+ self._tc.create_stream_class(name=17)
- def test_assign_id(self):
- self._sc.id = 1717
- self.assertEqual(self._sc.id, 1717)
+ def test_create_packet_context_field_class(self):
+ fc = self._tc.create_structure_field_class()
+ sc = self._tc.create_stream_class(packet_context_field_class=fc)
+ self.assertEqual(sc.packet_context_field_class, fc)
- def test_assign_invalid_id(self):
+ def test_create_invalid_packet_context_field_class(self):
with self.assertRaises(TypeError):
- self._sc.id = 'lel'
+ self._tc.create_stream_class(packet_context_field_class=22)
- def test_no_id(self):
- sc = bt2.StreamClass()
- self.assertIsNone(sc.id)
+ def test_create_event_common_context_field_class(self):
+ fc = self._tc.create_structure_field_class()
+ sc = self._tc.create_stream_class(event_common_context_field_class=fc)
+ self.assertEqual(sc.event_common_context_field_class, fc)
- def test_assign_packet_context_field_class(self):
- self._sc.packet_context_field_class = self._event_context_fc
- self.assertEqual(self._sc.packet_context_field_class, self._event_context_fc)
+ def test_create_invalid_event_common_context_field_class(self):
+ with self.assertRaises(TypeError):
+ self._tc.create_stream_class(event_common_context_field_class=22)
- def test_assign_no_packet_context_field_class(self):
- self._sc.packet_context_field_class = None
- self.assertIsNone(self._sc.packet_context_field_class)
+ def test_create_default_clock_class(self):
+ sc = self._tc.create_stream_class(default_clock_class=self._cc)
+ self.assertEqual(sc.default_clock_class.addr, self._cc.addr)
- def test_assign_invalid_packet_context_field_class(self):
+ def test_create_invalid_default_clock_class(self):
with self.assertRaises(TypeError):
- self._sc.packet_context_field_class = 'lel'
+ self._tc.create_stream_class(default_clock_class=12)
- def test_assign_event_header_field_class(self):
- self._sc.event_header_field_class = self._event_header_fc
- self.assertEqual(self._sc.event_header_field_class, self._event_header_fc)
+ def test_automatic_stream_ids(self):
+ sc = self._tc.create_stream_class(assigns_automatic_stream_id=True)
+ self.assertTrue(sc.assigns_automatic_stream_id)
- def test_assign_no_event_header_field_class(self):
- self._sc.event_header_field_class = None
- self.assertIsNone(self._sc.event_header_field_class)
+ stream = self._trace.create_stream(sc)
+ self.assertIsNotNone(stream.id)
- def test_assign_invalid_event_header_field_class(self):
- with self.assertRaises(TypeError):
- self._sc.event_header_field_class = 'lel'
+ def test_automatic_stream_ids_raises(self):
+ sc = self._tc.create_stream_class(assigns_automatic_stream_id=True)
+ self.assertTrue(sc.assigns_automatic_stream_id)
+
+ with self.assertRaises(bt2.CreationError):
+ self._trace.create_stream(sc, id=123)
+
+ def test_no_automatic_stream_ids(self):
+ sc = self._tc.create_stream_class(assigns_automatic_stream_id=False)
+ self.assertFalse(sc.assigns_automatic_stream_id)
+
+ stream = self._trace.create_stream(sc, id=333)
+ self.assertEqual(stream.id, 333)
+
+ def test_no_automatic_stream_ids_raises(self):
+ sc = self._tc.create_stream_class(assigns_automatic_stream_id=False)
+ self.assertFalse(sc.assigns_automatic_stream_id)
+
+ with self.assertRaises(bt2.CreationError):
+ self._trace.create_stream(sc)
+
+ def test_automatic_event_class_ids(self):
+ sc = self._tc.create_stream_class(assigns_automatic_event_class_id=True)
+ self.assertTrue(sc.assigns_automatic_event_class_id)
+
+ ec = sc.create_event_class()
+ self.assertIsNotNone(ec.id)
+
+ def test_automatic_event_class_ids_raises(self):
+ sc = self._tc.create_stream_class(assigns_automatic_event_class_id=True)
+ self.assertTrue(sc.assigns_automatic_event_class_id)
+
+ with self.assertRaises(bt2.CreationError):
+ sc.create_event_class(id=123)
+
+ def test_no_automatic_event_class_ids(self):
+ sc = self._tc.create_stream_class(assigns_automatic_event_class_id=False)
+ self.assertFalse(sc.assigns_automatic_event_class_id)
- def test_assign_event_context_field_class(self):
- self._sc.event_context_field_class = self._packet_context_fc
- self.assertEqual(self._sc.event_context_field_class, self._packet_context_fc)
+ ec = sc.create_event_class(id=333)
+ self.assertEqual(ec.id, 333)
- def test_assign_no_event_context_field_class(self):
- self._sc.event_context_field_class = None
- self.assertIsNone(self._sc.event_context_field_class)
+ def test_no_automatic_event_class_ids_raises(self):
+ sc = self._tc.create_stream_class(assigns_automatic_event_class_id=False)
+ self.assertFalse(sc.assigns_automatic_event_class_id)
- def test_assign_invalid_event_context_field_class(self):
+ with self.assertRaises(bt2.CreationError):
+ sc.create_event_class()
+
+ def test_packets_have_default_beginning_clock_snapshot(self):
+ sc = self._tc.create_stream_class(default_clock_class=self._cc, packets_have_default_beginning_clock_snapshot=True)
+ self.assertTrue(sc.packets_have_default_beginning_clock_snapshot)
+
+ def test_packets_have_default_beginning_clock_snapshot_raises(self):
+ with self.assertRaises(TypeError):
+ sc = self._tc.create_stream_class(packets_have_default_beginning_clock_snapshot="something")
+
+ def test_packets_have_default_end_clock_snapshot(self):
+ sc = self._tc.create_stream_class(default_clock_class=self._cc, packets_have_default_end_clock_snapshot=True)
+ self.assertTrue(sc.packets_have_default_end_clock_snapshot)
+
+ def test_packets_have_default_end_clock_snapshot_raises(self):
with self.assertRaises(TypeError):
- self._sc.event_context_field_class = 'lel'
-
- def test_trace_prop_no_tc(self):
- self.assertIsNone(self._sc.trace)
-
- def test_trace_prop(self):
- tc = bt2.Trace()
- tc.add_stream_class(self._sc)
- self.assertEqual(self._sc.trace.addr, tc.addr)
-
- def _test_copy(self, cpy):
- self.assertIsNot(cpy, self._sc)
- self.assertNotEqual(cpy.addr, self._sc.addr)
- self.assertEqual(cpy, self._sc)
-
- def test_copy(self):
- cpy = copy.copy(self._sc)
- self._test_copy(cpy)
- self.assertEqual(self._sc.packet_context_field_class.addr, cpy.packet_context_field_class.addr)
- self.assertEqual(self._sc.event_header_field_class.addr, cpy.event_header_field_class.addr)
- self.assertEqual(self._sc.event_context_field_class.addr, cpy.event_context_field_class.addr)
-
- def test_deepcopy(self):
- cpy = copy.deepcopy(self._sc)
- self._test_copy(cpy)
- self.assertNotEqual(self._sc.packet_context_field_class.addr, cpy.packet_context_field_class.addr)
- self.assertNotEqual(self._sc.event_header_field_class.addr, cpy.event_header_field_class.addr)
- self.assertNotEqual(self._sc.event_context_field_class.addr, cpy.event_context_field_class.addr)
+ sc = self._tc.create_stream_class(packets_have_default_end_clock_snapshot="something")
+
+ def test_trace_class(self):
+ sc = self._tc.create_stream_class()
+ self.assertEqual(sc.trace_class.addr, self._tc.addr)
+
+ def _create_stream_class_with_event_classes(self):
+ sc = self._tc.create_stream_class(assigns_automatic_event_class_id=False)
+ ec1 = sc.create_event_class(id=23)
+ ec2 = sc.create_event_class(id=17)
+ return sc, ec1, ec2
def test_getitem(self):
- self.assertEqual(self._sc[23], self._ec1)
- self.assertEqual(self._sc[17], self._ec2)
+ sc, ec1, ec2 = self._create_stream_class_with_event_classes()
+
+ self.assertEqual(sc[23].addr, ec1.addr)
+ self.assertEqual(sc[17].addr, ec2.addr)
def test_getitem_wrong_key_type(self):
+ sc, _, _ = self._create_stream_class_with_event_classes()
+
with self.assertRaises(TypeError):
- self._sc['event23']
+ sc['event23']
def test_getitem_wrong_key(self):
+ sc, _, _ = self._create_stream_class_with_event_classes()
+
with self.assertRaises(KeyError):
- self._sc[19]
+ sc[19]
def test_len(self):
- self.assertEqual(len(self._sc), 2)
+ sc, _, _ = self._create_stream_class_with_event_classes()
+
+ self.assertEqual(len(sc), 2)
def test_iter(self):
- for ec_id, event_class in self._sc.items():
- self.assertIsInstance(event_class, bt2.EventClass)
-
- if ec_id == 23:
- self.assertEqual(event_class, self._ec1)
- elif ec_id == 17:
- self.assertEqual(event_class, self._ec2)
-
- def test_eq(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertEqual(sc1, sc2)
-
- def test_ne_name(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class1', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertNotEqual(sc1, sc2)
-
- def test_ne_id(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class', id=13,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertNotEqual(sc1, sc2)
-
- def test_ne_packet_context_field_class(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._event_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertNotEqual(sc1, sc2)
-
- def test_ne_event_header_field_class(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertNotEqual(sc1, sc2)
-
- def test_ne_event_context_field_class(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._packet_context_fc,
- event_classes=(ec1, ec2))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertNotEqual(sc1, sc2)
-
- def test_ne_event_class(self):
- ec1, ec2 = self._create_event_classes()
- sc1 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1,))
- ec1, ec2 = self._create_event_classes()
- sc2 = bt2.StreamClass(name='my_stream_class', id=12,
- packet_context_field_class=self._packet_context_fc,
- event_header_field_class=self._event_header_fc,
- event_context_field_class=self._event_context_fc,
- event_classes=(ec1, ec2))
- self.assertNotEqual(sc1, sc2)
-
- def test_eq_invalid(self):
- self.assertFalse(self._sc == 23)
+ sc, _, _ = self._create_stream_class_with_event_classes()
+
+ ec_ids = sorted(sc)
+ self.assertEqual(ec_ids, [17, 23])