mirror of https://github.com/django/django.git
Fixed #14351 -- Modified the requests test case to avoid an timing problem in the test.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@13922 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
d80d2e8103
commit
1637fefcb0
|
@ -48,9 +48,20 @@ http://www.example.com/path/with:colons
|
||||||
|
|
||||||
# Test cookie datetime expiration logic
|
# Test cookie datetime expiration logic
|
||||||
>>> from datetime import datetime, timedelta
|
>>> from datetime import datetime, timedelta
|
||||||
|
>>> import time
|
||||||
>>> delta = timedelta(seconds=10)
|
>>> delta = timedelta(seconds=10)
|
||||||
>>> response = HttpResponse()
|
>>> response = HttpResponse()
|
||||||
>>> response.set_cookie('datetime', expires=datetime.utcnow()+delta)
|
>>> expires = datetime.utcnow() + delta
|
||||||
|
|
||||||
|
# There is a timing weakness in this test; The
|
||||||
|
# expected result for max-age requires that there be
|
||||||
|
# a very slight difference between the evaluated expiration
|
||||||
|
# time, and the time evaluated in set_cookie(). If this
|
||||||
|
# difference doesn't exist, the cookie time will be
|
||||||
|
# 1 second larger. To avoid the problem, put in a quick sleep,
|
||||||
|
# which guarantees that there will be a time difference.
|
||||||
|
>>> time.sleep(0.001)
|
||||||
|
>>> response.set_cookie('datetime', expires=expires)
|
||||||
>>> datetime_cookie = response.cookies['datetime']
|
>>> datetime_cookie = response.cookies['datetime']
|
||||||
>>> datetime_cookie['max-age']
|
>>> datetime_cookie['max-age']
|
||||||
10
|
10
|
||||||
|
|
Loading…
Reference in New Issue