diff options
| author | Aldo Cortesi <aldo@nullcube.com> | 2012-10-28 22:00:19 +1300 | 
|---|---|---|
| committer | Aldo Cortesi <aldo@nullcube.com> | 2012-10-28 22:00:19 +1300 | 
| commit | 07560ffe307f13ffb5a8fa4ef593902cc69807b9 (patch) | |
| tree | badc64443007a6e080fc02083b19fcf04f3882ef | |
| parent | 35f37626a97c8dd4bcbf24f3330c1b795d7310fe (diff) | |
| download | mitmproxy-07560ffe307f13ffb5a8fa4ef593902cc69807b9.tar.gz mitmproxy-07560ffe307f13ffb5a8fa4ef593902cc69807b9.tar.bz2 mitmproxy-07560ffe307f13ffb5a8fa4ef593902cc69807b9.zip | |
Cleaup, ABC for Value classes.
| -rw-r--r-- | libpathod/language.py | 42 | ||||
| -rw-r--r-- | test/test_language.py | 1 | ||||
| -rw-r--r-- | test/test_pathod.py | 3 | 
3 files changed, 24 insertions, 22 deletions
| diff --git a/libpathod/language.py b/libpathod/language.py index 5a00d17e..7f1d8cec 100644 --- a/libpathod/language.py +++ b/libpathod/language.py @@ -113,9 +113,6 @@ class LiteralGenerator:      def __init__(self, s):          self.s = s -    def __eq__(self, other): -        return self[:] == other -      def __len__(self):          return len(self.s) @@ -168,18 +165,29 @@ class FileGenerator:          return "<%s"%self.path -class _Value: +class _Value(object): +    __metaclass__ = abc.ABCMeta +    def __repr__(self): +        return self.spec() + +    @abc.abstractmethod +    def spec(self): # pragma: no cover +        return None + +    @abc.abstractmethod +    def expr(self): # pragma: no cover +        return None + + +class _ValueLiteral(_Value):      def __init__(self, val):          self.val = val.decode("string_escape")      def get_generator(self, settings):          return LiteralGenerator(self.val) -    def __repr__(self): -        return self.spec() - -class ValueLiteral(_Value): +class ValueLiteral(_ValueLiteral):      @classmethod      def expr(klass):          e = v_literal.copy() @@ -189,7 +197,7 @@ class ValueLiteral(_Value):          return '"%s"'%self.val.encode("string_escape") -class ValueNakedLiteral(_Value): +class ValueNakedLiteral(_ValueLiteral):      @classmethod      def expr(klass):          e = v_naked_literal.copy() @@ -199,7 +207,7 @@ class ValueNakedLiteral(_Value):          return self.val.encode("string_escape") -class ValueGenerate: +class ValueGenerate(_Value):      def __init__(self, usize, unit, datatype):          if not unit:              unit = "b" @@ -231,11 +239,8 @@ class ValueGenerate:              s += ",%s"%self.datatype          return s -    def __repr__(self): -        return self.spec() - -class ValueFile: +class ValueFile(_Value):      def __init__(self, path):          self.path = path @@ -294,7 +299,7 @@ Offset = pp.MatchFirst(  class _Component(object):      """ -        A component of the specification of an HTTP message.  +        A component of the specification of an HTTP message.      """      __metaclass__ = abc.ABCMeta      @abc.abstractmethod @@ -316,11 +321,11 @@ class _Component(object):          """              Notifies the component to register itself with message r.          """ -        return None  +        return None      def string(self, settings=None):          """ -            A string representation of the object.  +            A string representation of the object.          """          return "".join(i[:] for i in self.values(settings or {})) @@ -422,8 +427,6 @@ class Path(_Component):              ] - -  class Method(_Component):      methods = [          "get", @@ -792,7 +795,6 @@ class Request(Message):          return resp -  class CraftedRequest(Request):      def __init__(self, settings, spec, tokens):          Request.__init__(self) diff --git a/test/test_language.py b/test/test_language.py index 749f1928..0d7c60da 100644 --- a/test/test_language.py +++ b/test/test_language.py @@ -123,7 +123,6 @@ class TestMisc:      def test_literalgenerator(self):          g = language.LiteralGenerator("one")          assert repr(g) -        assert g == "one"          assert g[:] == "one"          assert g[1] == "n" diff --git a/test/test_pathod.py b/test/test_pathod.py index 83f57727..3fe7e848 100644 --- a/test/test_pathod.py +++ b/test/test_pathod.py @@ -35,11 +35,12 @@ class TestNoWeb(tutils.DaemonTests):  class TestTimeout(tutils.DaemonTests): -    timeout = 0.1 +    timeout = 0.01      def test_noweb(self):          # FIXME: Add float values to spec language, reduce test timeout to          # increase test performance          assert self.get("200:p1,1").status_code == 200 +        print self.d.last_log()          assert self.d.last_log()["type"] == "timeout" | 
