diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/pathod/test_language_base.py | 11 | ||||
-rw-r--r-- | test/pathod/test_language_http.py | 4 |
2 files changed, 10 insertions, 5 deletions
diff --git a/test/pathod/test_language_base.py b/test/pathod/test_language_base.py index bb1e864b..7c7d8cf9 100644 --- a/test/pathod/test_language_base.py +++ b/test/pathod/test_language_base.py @@ -55,8 +55,15 @@ class TestTokValueLiteral: v = base.TokValueLiteral("f\x00oo") assert v.spec() == repr(v) == r"'f\x00oo'" - v = base.TokValueLiteral("\"") - assert v.spec() == repr(v) == '\'"\'' + v = base.TokValueLiteral('"') + assert v.spec() == repr(v) == """ '"' """.strip() + + # While pyparsing has a escChar argument for QuotedString, + # escChar only performs scapes single-character escapes and does not work for e.g. r"\x02". + # Thus, we cannot use that option, which means we cannot have single quotes in strings. + # To fix this, we represent single quotes as r"\x07". + v = base.TokValueLiteral("'") + assert v.spec() == r"'\x27'" def roundtrip(self, spec): e = base.TokValueLiteral.expr() diff --git a/test/pathod/test_language_http.py b/test/pathod/test_language_http.py index 20809fcf..0ef1e109 100644 --- a/test/pathod/test_language_http.py +++ b/test/pathod/test_language_http.py @@ -340,9 +340,7 @@ def test_nested_response(): def test_nested_response_freeze(): e = http.NestedResponse( base.TokValueLiteral( - "200:b'foo':i10,'\\x27'".encode( - "string_escape" - ) + r"200:b\'foo\':i10,\'\\x27\'" ) ) assert e.freeze({}) |