commit e04f453314f015ef994f798d1418670f62003386
Author: Damian Johnson <atagar(a)torproject.org>
Date: Tue Jan 26 09:36:52 2016 -0800
Proc connections skipped due to incorrect file mode
toralf reports that proc connection resolution no longer works and think I see
the issue. Under python3 we read the contents as unicode but our checks all
expect bytes, causing us to skip all the lines.
---
stem/util/proc.py | 4 ++--
test/unit/util/proc.py | 4 ++--
2 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/stem/util/proc.py b/stem/util/proc.py
index 2b16ccb..7fdd70f 100644
--- a/stem/util/proc.py
+++ b/stem/util/proc.py
@@ -393,7 +393,7 @@ def connections(pid):
continue
try:
- with open(proc_file_path) as proc_file:
+ with open(proc_file_path, 'rb') as proc_file:
proc_file.readline() # skip the first line
for line in proc_file:
@@ -458,7 +458,7 @@ def _decode_proc_address_encoding(addr, is_ipv6):
grouping = ip[8 * i:8 * (i + 1)]
inverted += [grouping[2 * i:2 * (i + 1)] for i in range(4)][::-1]
- ip = ''.join(inverted)
+ ip = b''.join(inverted)
ip = socket.inet_ntop(socket.AF_INET6, base64.b16decode(ip))
diff --git a/test/unit/util/proc.py b/test/unit/util/proc.py
index f852820..ee52d21 100644
--- a/test/unit/util/proc.py
+++ b/test/unit/util/proc.py
@@ -220,7 +220,7 @@ class TestProc(unittest.TestCase):
'/proc/net/udp6': False
}[param]
- open_mock.side_effect = lambda param: {
+ open_mock.side_effect = lambda param, mode: {
'/proc/net/tcp': io.BytesIO(tcp),
'/proc/net/udp': io.BytesIO(udp)
}[param]
@@ -262,7 +262,7 @@ class TestProc(unittest.TestCase):
'/proc/net/udp6': False
}[param]
- open_mock.side_effect = lambda param: {
+ open_mock.side_effect = lambda param, mode: {
'/proc/net/tcp6': io.BytesIO(TCP6_CONTENT),
}[param]