aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_language_http2.py
diff options
context:
space:
mode:
authorThomas Kriechbaumer <thomas@kriechbaumer.name>2015-06-22 12:42:39 +0200
committerThomas Kriechbaumer <thomas@kriechbaumer.name>2015-06-25 14:59:22 +0200
commit46255e6e9cfca6ee5b32d287be7d2a0eb8d73c20 (patch)
treedf38da5b168a994705f16bced7dfc3d3843111e7 /test/test_language_http2.py
parent09d76e1758378d0d8604bdce61a1480584c3c72a (diff)
downloadmitmproxy-46255e6e9cfca6ee5b32d287be7d2a0eb8d73c20.tar.gz
mitmproxy-46255e6e9cfca6ee5b32d287be7d2a0eb8d73c20.tar.bz2
mitmproxy-46255e6e9cfca6ee5b32d287be7d2a0eb8d73c20.zip
http2: implement more language features
Diffstat (limited to 'test/test_language_http2.py')
-rw-r--r--test/test_language_http2.py52
1 files changed, 47 insertions, 5 deletions
diff --git a/test/test_language_http2.py b/test/test_language_http2.py
index a78c2bee..b25ad43c 100644
--- a/test/test_language_http2.py
+++ b/test/test_language_http2.py
@@ -90,6 +90,39 @@ class TestRequest:
default_settings(),
)
+ def test_raw_content_length(self):
+ r = parse_request('GET:/:r')
+ assert len(r.headers) == 0
+
+ r = parse_request('GET:/:r:b"foobar"')
+ assert len(r.headers) == 0
+
+ r = parse_request('GET:/')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-length", "0")
+
+ r = parse_request('GET:/:b"foobar"')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-length", "6")
+
+ r = parse_request('GET:/:b"foobar":h"content-length"="42"')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-length", "42")
+
+ r = parse_request('GET:/:r:b"foobar":h"content-length"="42"')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-length", "42")
+
+ def test_content_type(self):
+ r = parse_request('GET:/:r:c"foobar"')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-type", "foobar")
+
+ def test_user_agent(self):
+ r = parse_request('GET:/:r:ua')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("user-agent", netlib.http_uastrings.get_by_shortcut('a')[2])
+
def test_render_with_headers(self):
s = cStringIO.StringIO()
r = parse_request('GET:/foo:h"foo"="bar"')
@@ -129,18 +162,27 @@ class TestResponse:
def test_err(self):
tutils.raises(language.ParseException, parse_response, 'GET:/')
- def test_simple(self):
- r = parse_response('200')
- assert r.code.string() == "200"
+ def test_raw_content_length(self):
+ r = parse_response('200:r')
assert len(r.headers) == 0
- r = parse_response('200:h"foo"="bar"')
+ r = parse_response('200')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-length", "0")
+
+ def test_content_type(self):
+ r = parse_response('200:r:c"foobar"')
+ assert len(r.headers) == 1
+ assert r.headers[0].values(default_settings()) == ("content-type", "foobar")
+
+ def test_simple(self):
+ r = parse_response('200:r:h"foo"="bar"')
assert r.code.string() == "200"
assert len(r.headers) == 1
assert r.headers[0].values(default_settings()) == ("foo", "bar")
assert r.body is None
- r = parse_response('200:h"foo"="bar":bfoobar:h"bla"="fasel"')
+ r = parse_response('200:r:h"foo"="bar":bfoobar:h"bla"="fasel"')
assert r.code.string() == "200"
assert len(r.headers) == 2
assert r.headers[0].values(default_settings()) == ("foo", "bar")