[tor-commits] [stem/master] Add note and tests for Cell types that always have empty unused content

atagar at torproject.org atagar at torproject.org
Thu Jul 12 18:53:10 UTC 2018


commit dc7be2c5faa9675279a3e9da263f2975e78ef762
Author: Dave Rolek <dmr-x at riseup.net>
Date:   Mon Jul 9 19:24:26 2018 +0000

    Add note and tests for Cell types that always have empty unused content
---
 stem/client/cell.py      | 5 +++++
 test/unit/client/cell.py | 3 +++
 2 files changed, 8 insertions(+)

diff --git a/stem/client/cell.py b/stem/client/cell.py
index d04c387e..948201fd 100644
--- a/stem/client/cell.py
+++ b/stem/client/cell.py
@@ -80,6 +80,11 @@ class Cell(object):
   Unused padding are **not** used in equality checks or hashing. If two cells
   differ only in their *unused* attribute they are functionally equal.
 
+  The following cell types explicitly don't have *unused* content:
+    * PaddingCell (we consider all content part of payload)
+    * VersionsCell (all content is unpacked and treated as a version specification)
+    * VPaddingCell (we consider all content part of payload)
+
   :var bytes unused: unused filler that padded the cell to the expected size
   """
 
diff --git a/test/unit/client/cell.py b/test/unit/client/cell.py
index bf2b9275..c7eb6f00 100644
--- a/test/unit/client/cell.py
+++ b/test/unit/client/cell.py
@@ -180,6 +180,7 @@ class TestCell(unittest.TestCase):
 
       cell = Cell.pop(cell_bytes, 2)[0]
       self.assertEqual(payload, cell.payload)
+      self.assertEqual(b'', cell.unused)  # always empty
       self.assertEqual(cell_bytes, cell.pack(2))
 
   def test_relay_cell(self):
@@ -264,6 +265,7 @@ class TestCell(unittest.TestCase):
 
       cell = Cell.pop(cell_bytes, link_protocol)[0]
       self.assertEqual(versions, cell.versions)
+      self.assertEqual(b'', cell.unused)  # always empty
       self.assertEqual(cell_bytes, cell.pack(link_protocol))
 
   def test_netinfo_cell(self):
@@ -283,6 +285,7 @@ class TestCell(unittest.TestCase):
 
       cell = Cell.pop(cell_bytes, 2)[0]
       self.assertEqual(payload, cell.payload)
+      self.assertEqual(b'', cell.unused)  # always empty
       self.assertEqual(cell_bytes, cell.pack(2))
 
     empty_constructed_cell = VPaddingCell(size = 0)





More information about the tor-commits mailing list