[tor-commits] [stem/master] Only report connection resolvers that are in our PATH

atagar at torproject.org atagar at torproject.org
Mon Sep 23 22:02:55 UTC 2013


commit 276fb65ef4dbf0536be91e3fcb1912363d5ada73
Author: Damian Johnson <atagar at torproject.org>
Date:   Mon Sep 23 12:03:25 2013 -0700

    Only report connection resolvers that are in our PATH
    
    Having get_system_resolvers() check that resolvers are in our PATH before
    returning them.
---
 stem/util/connection.py      |    4 ++++
 test/unit/util/connection.py |    9 ++++++++-
 2 files changed, 12 insertions(+), 1 deletion(-)

diff --git a/stem/util/connection.py b/stem/util/connection.py
index 4605a57..0b93130 100644
--- a/stem/util/connection.py
+++ b/stem/util/connection.py
@@ -249,6 +249,10 @@ def get_system_resolvers(system = None):
 
     resolvers = [Resolver.NETSTAT, Resolver.SOCKSTAT, Resolver.LSOF, Resolver.SS]
 
+  # remove any that aren't in the user's PATH
+
+  resolvers = filter(lambda r: stem.util.system.is_available(RESOLVER_COMMAND[r]), resolvers)
+
   # proc resolution, by far, outperforms the others so defaults to this is able
 
   if stem.util.proc.is_available():
diff --git a/test/unit/util/connection.py b/test/unit/util/connection.py
index 03d83c1..1d9e6f6 100644
--- a/test/unit/util/connection.py
+++ b/test/unit/util/connection.py
@@ -88,12 +88,14 @@ BSD_PROCSTAT_OUTPUT = """\
 
 
 class TestConnection(unittest.TestCase):
+  @patch('stem.util.system.is_available')
   @patch('stem.util.proc.is_available')
-  def test_get_system_resolvers(self, proc_mock):
+  def test_get_system_resolvers(self, proc_mock, is_available_mock):
     """
     Checks the get_system_resolvers function.
     """
 
+    is_available_mock.return_value = True
     proc_mock.return_value = False
 
     self.assertEqual([], stem.util.connection.get_system_resolvers('Windows'))
@@ -110,6 +112,11 @@ class TestConnection(unittest.TestCase):
 
     self.assertEqual(stem.util.connection.get_system_resolvers(platform.system()), stem.util.connection.get_system_resolvers())
 
+    # check that lacking commands in our PATH drops them from the results
+
+    is_available_mock.return_value = False
+    self.assertEqual([Resolver.PROC], stem.util.connection.get_system_resolvers('Linux'))
+
   @patch('stem.util.proc.get_connections')
   def test_get_connections_by_proc(self, proc_mock):
     """



More information about the tor-commits mailing list