[tor-commits] [stem/master] Allowing ControlMessage.from_str() to include conversion

atagar at torproject.org atagar at torproject.org
Mon May 27 04:31:14 UTC 2013


commit 0efbdf80f94574805b0fa080965bb509d535a4db
Author: Damian Johnson <atagar at torproject.org>
Date:   Sun May 26 21:27:43 2013 -0700

    Allowing ControlMessage.from_str() to include conversion
    
    For txtorcon or anything else using our ControlMessage.from_str() function the
    following is very, very common...
    
    msg = stem.response.ControlMessage.from_str(getinfo_content)
    stem.response.convert("GETINFO", msg)
    
    Adding a 'msg_type' argument to from_str() so the two calls can be combined.
    This addresses...
    
    https://trac.torproject.org/8605
---
 stem/response/__init__.py             |   11 +++++++++--
 test/output.py                        |    2 +-
 test/unit/response/control_message.py |   12 ++++++++++++
 3 files changed, 22 insertions(+), 3 deletions(-)

diff --git a/stem/response/__init__.py b/stem/response/__init__.py
index 01af23e..5e0d077 100644
--- a/stem/response/__init__.py
+++ b/stem/response/__init__.py
@@ -136,16 +136,23 @@ class ControlMessage(object):
   """
 
   @staticmethod
-  def from_str(content):
+  def from_str(content, msg_type = None, **kwargs):
     """
     Provides a ControlMessage for the given content.
 
     :param str content: message to construct the message from
+    :param str msg_type: type of tor reply to parse the content as
+    :param kwargs: optional keyword arguments to be passed to the parser method
 
     :returns: stem.response.ControlMessage instance
     """
 
-    return stem.socket.recv_message(StringIO.StringIO(content))
+    msg = stem.socket.recv_message(StringIO.StringIO(content))
+
+    if msg_type is not None:
+      convert(msg_type, msg, **kwargs)
+
+    return msg
 
   def __init__(self, parsed_content, raw_content):
     if not parsed_content:
diff --git a/test/output.py b/test/output.py
index 7cd00b7..3f5efee 100644
--- a/test/output.py
+++ b/test/output.py
@@ -133,7 +133,7 @@ def strip_module(line_type, line_content):
   repetitive, and redundant with the headers.
   """
 
-  m = re.match(".*( \(.*?\)).*", line_content)
+  m = re.match(".*( \(test\..*?\)).*", line_content)
 
   if m:
     line_content = line_content.replace(m.groups()[0], "", 1)
diff --git a/test/unit/response/control_message.py b/test/unit/response/control_message.py
index 75a5f6e..33b2008 100644
--- a/test/unit/response/control_message.py
+++ b/test/unit/response/control_message.py
@@ -7,6 +7,8 @@ import StringIO
 import unittest
 
 import stem.socket
+import stem.response
+import stem.response.getinfo
 
 OK_REPLY = "250 OK\r\n"
 
@@ -32,6 +34,16 @@ version -- The current version of Tor.
 
 
 class TestControlMessage(unittest.TestCase):
+  def test_from_str(self):
+    msg = stem.response.ControlMessage.from_str(GETINFO_VERSION)
+
+    self.assertTrue(isinstance(msg, stem.response.ControlMessage))
+    self.assertEqual('version=0.2.2.23-alpha (git-b85eb949b528f4d7)\nOK', str(msg))
+
+    msg = stem.response.ControlMessage.from_str(GETINFO_VERSION, "GETINFO")
+    self.assertTrue(isinstance(msg, stem.response.getinfo.GetInfoResponse))
+    self.assertEqual({'version': '0.2.2.23-alpha (git-b85eb949b528f4d7)'}, msg.entries)
+
   def test_ok_response(self):
     """
     Checks the basic 'OK' response that we get for most commands.



More information about the tor-commits mailing list