mirror of
https://github.com/Grasscutters/mitmproxy.git
synced 2024-11-30 03:14:22 +00:00
08002282e8
allows '/' to be within a cookie name removes deprecated cookie getter/setter fixes #1118
126 lines
4.1 KiB
Python
126 lines
4.1 KiB
Python
from __future__ import absolute_import, print_function, division
|
|
|
|
import email
|
|
|
|
import six
|
|
import time
|
|
|
|
from netlib.http import Headers
|
|
from netlib.odict import ODict, ODictCaseless
|
|
from netlib.tutils import raises, tresp
|
|
from .test_message import _test_passthrough_attr, _test_decoded_attr
|
|
|
|
|
|
class TestResponseData(object):
|
|
def test_init(self):
|
|
with raises(ValueError if six.PY2 else TypeError):
|
|
tresp(headers="foobar")
|
|
|
|
assert isinstance(tresp(headers=None).headers, Headers)
|
|
|
|
|
|
class TestResponseCore(object):
|
|
"""
|
|
Tests for builtins and the attributes that are directly proxied from the data structure
|
|
"""
|
|
def test_repr(self):
|
|
response = tresp()
|
|
assert repr(response) == "Response(200 OK, unknown content type, 7B)"
|
|
response.content = None
|
|
assert repr(response) == "Response(200 OK, no content)"
|
|
|
|
def test_status_code(self):
|
|
_test_passthrough_attr(tresp(), "status_code")
|
|
|
|
def test_reason(self):
|
|
_test_decoded_attr(tresp(), "reason")
|
|
|
|
|
|
class TestResponseUtils(object):
|
|
"""
|
|
Tests for additional convenience methods.
|
|
"""
|
|
def test_get_cookies_none(self):
|
|
resp = tresp()
|
|
resp.headers = Headers()
|
|
assert not resp.cookies
|
|
|
|
def test_get_cookies_empty(self):
|
|
resp = tresp()
|
|
resp.headers = Headers(set_cookie="")
|
|
assert not resp.cookies
|
|
|
|
def test_get_cookies_simple(self):
|
|
resp = tresp()
|
|
resp.headers = Headers(set_cookie="cookiename=cookievalue")
|
|
result = resp.cookies
|
|
assert len(result) == 1
|
|
assert "cookiename" in result
|
|
assert result["cookiename"][0] == ["cookievalue", ODict()]
|
|
|
|
def test_get_cookies_with_parameters(self):
|
|
resp = tresp()
|
|
resp.headers = Headers(set_cookie="cookiename=cookievalue;domain=example.com;expires=Wed Oct 21 16:29:41 2015;path=/; HttpOnly")
|
|
result = resp.cookies
|
|
assert len(result) == 1
|
|
assert "cookiename" in result
|
|
assert result["cookiename"][0][0] == "cookievalue"
|
|
attrs = result["cookiename"][0][1]
|
|
assert len(attrs) == 4
|
|
assert attrs["domain"] == ["example.com"]
|
|
assert attrs["expires"] == ["Wed Oct 21 16:29:41 2015"]
|
|
assert attrs["path"] == ["/"]
|
|
assert attrs["httponly"] == [None]
|
|
|
|
def test_get_cookies_no_value(self):
|
|
resp = tresp()
|
|
resp.headers = Headers(set_cookie="cookiename=; Expires=Thu, 01-Jan-1970 00:00:01 GMT; path=/")
|
|
result = resp.cookies
|
|
assert len(result) == 1
|
|
assert "cookiename" in result
|
|
assert result["cookiename"][0][0] == ""
|
|
assert len(result["cookiename"][0][1]) == 2
|
|
|
|
def test_get_cookies_twocookies(self):
|
|
resp = tresp()
|
|
resp.headers = Headers([
|
|
[b"Set-Cookie", b"cookiename=cookievalue"],
|
|
[b"Set-Cookie", b"othercookie=othervalue"]
|
|
])
|
|
result = resp.cookies
|
|
assert len(result) == 2
|
|
assert "cookiename" in result
|
|
assert result["cookiename"][0] == ["cookievalue", ODict()]
|
|
assert "othercookie" in result
|
|
assert result["othercookie"][0] == ["othervalue", ODict()]
|
|
|
|
def test_set_cookies(self):
|
|
resp = tresp()
|
|
v = resp.cookies
|
|
v.add("foo", ["bar", ODictCaseless()])
|
|
resp.cookies = v
|
|
|
|
v = resp.cookies
|
|
assert len(v) == 1
|
|
assert v["foo"] == [["bar", ODictCaseless()]]
|
|
|
|
def test_refresh(self):
|
|
r = tresp()
|
|
n = time.time()
|
|
r.headers["date"] = email.utils.formatdate(n)
|
|
pre = r.headers["date"]
|
|
r.refresh(n)
|
|
assert pre == r.headers["date"]
|
|
r.refresh(n + 60)
|
|
|
|
d = email.utils.parsedate_tz(r.headers["date"])
|
|
d = email.utils.mktime_tz(d)
|
|
# Weird that this is not exact...
|
|
assert abs(60 - (d - n)) <= 1
|
|
|
|
cookie = "MOO=BAR; Expires=Tue, 08-Mar-2011 00:20:38 GMT; Path=foo.com; Secure"
|
|
r.headers["set-cookie"] = cookie
|
|
r.refresh()
|
|
# Cookie refreshing is tested in test_cookies, we just make sure that it's triggered here.
|
|
assert cookie != r.headers["set-cookie"]
|