diff options
| author | Aldo Cortesi <aldo@nullcube.com> | 2012-06-24 15:07:45 +1200 | 
|---|---|---|
| committer | Aldo Cortesi <aldo@nullcube.com> | 2012-06-24 15:07:45 +1200 | 
| commit | 2e558b7e9d435216ff8c4c76df130fbf3936f803 (patch) | |
| tree | 53308d5d051022dcd99411ff94214e870f648a8b | |
| parent | b71e2f6f2bbc3ecaa1e463bae0cc6fd4762c6b8a (diff) | |
| download | mitmproxy-2e558b7e9d435216ff8c4c76df130fbf3936f803.tar.gz mitmproxy-2e558b7e9d435216ff8c4c76df130fbf3936f803.tar.bz2 mitmproxy-2e558b7e9d435216ff8c4c76df130fbf3936f803.zip | |
Fix disconnect, improve coverage, enable file value specifier.
| -rw-r--r-- | doc-src/pathoc.html | 3 | ||||
| -rw-r--r-- | libpathod/pathod.py | 10 | ||||
| -rw-r--r-- | libpathod/rparse.py | 2 | ||||
| -rw-r--r-- | test/test_test.py | 18 | 
4 files changed, 25 insertions, 8 deletions
| diff --git a/doc-src/pathoc.html b/doc-src/pathoc.html index 38b153e7..6f25e19d 100644 --- a/doc-src/pathoc.html +++ b/doc-src/pathoc.html @@ -5,5 +5,6 @@      </h1>  </div> +pathoc hostname get:/foo/bar:h"foo"="bar" get:/wah:b@1m - +pathoc --ssl hostname get:/foo/bar:h"foo"="bar" get:/wah:b@1m diff --git a/libpathod/pathod.py b/libpathod/pathod.py index aed95675..ef37d5ad 100644 --- a/libpathod/pathod.py +++ b/libpathod/pathod.py @@ -26,7 +26,7 @@ class PathodHandler(tcp.BaseHandler):          if path.startswith(self.server.prefix):              spec = urllib.unquote(path)[len(self.server.prefix):]              try: -                presp = rparse.parse({}, spec) +                presp = rparse.parse(self.server.request_settings, spec)              except rparse.ParseException, v:                  presp = rparse.InternalResponse(                      800, @@ -34,8 +34,7 @@ class PathodHandler(tcp.BaseHandler):                  )              ret = presp.serve(self.wfile)              if ret["disconnect"]: -                self.close() - +                self.finish()              ret["request"] = dict(                  path = path,                  method = method, @@ -65,6 +64,7 @@ class Pathod(tcp.TCPServer):      def __init__(self, addr, ssloptions=None, prefix="/p/", staticdir=None, anchors=None):          tcp.TCPServer.__init__(self, addr)          self.ssloptions = ssloptions +        self.staticdir = staticdir          self.prefix = prefix          self.app = app.app          self.app.config["pathod"] = self @@ -73,7 +73,9 @@ class Pathod(tcp.TCPServer):      @property      def request_settings(self): -        return {} +        return dict( +            staticdir = self.staticdir +        )      def handle_connection(self, request, client_address):          PathodHandler(request, client_address, self) diff --git a/libpathod/rparse.py b/libpathod/rparse.py index 92d0a54b..8a407388 100644 --- a/libpathod/rparse.py +++ b/libpathod/rparse.py @@ -2,8 +2,6 @@ import operator, string, random, mmap, os, time  import contrib.pyparsing as pp  from netlib import http_status -TESTING = False -  class ParseException(Exception):      def __init__(self, msg, s, col):          Exception.__init__(self) diff --git a/test/test_test.py b/test/test_test.py index 36d77fd5..7053bd73 100644 --- a/test/test_test.py +++ b/test/test_test.py @@ -44,12 +44,28 @@ class TestDaemon:      def tearDownAll(self):          self.d.shutdown() +    def setUp(self): +        self.d.clear_log() + +    def get(self, spec): +        return requests.get("http://localhost:%s/p/%s"%(self.d.port, spec)) +      def test_info(self):          assert tuple(self.d.info()["version"]) == version.IVERSION      def test_logs(self): -        rsp = requests.get("http://localhost:%s/p/202"%self.d.port) +        rsp = self.get("202")          assert len(self.d.log()) == 1          assert self.d.clear_log()          assert len(self.d.log()) == 0 +    def test_disconnect(self): +        rsp = self.get("202:b@100k:d200") +        assert len(rsp.content) < 200 + +    def test_parserr(self): +        rsp = self.get("400:msg,b:") +        assert rsp.status_code == 800 + + + | 
