-
Notifications
You must be signed in to change notification settings - Fork 111
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Invalid testapp.cookies after testapp.set_cookie() #171
Comments
Its not invalid. cookies are escaped. See Line 234 in 3a47668
|
testapp.cookies.get shoud return unescaped value. |
I don't think so. .get() return the stored value. If the app return an escaped cookie it should be stored like this. |
OK. So, how to get unescaped value of cookie? BTW. I think calling escape_cookie_value() in webtest is redundant because cookiejar escapes cookie value if needed. |
There is not way to do that AFAIK. You can try to add an As I remember we always escape cookies because it's easier. Not sure it's really true. Btw, why do you need this ? Your webapp don't take care of escaped cookies ? |
No, webapp handles escaped cookies correctly. Problem is in unittest's code: |
Is there any chances this issue gets resolved or documented at this point? |
Just adding quotes to the cookie is not valid according to the RFC, there are specific requirements for what may or may not be stored in a cookie. WebOb itself has a whole bunch of cookie handling, why not re-use parts of that? Especially the serialization bits that will currently warn, but in the future will raise if you attempt to set an invalid cookie? See from here on down: https://github.com/Pylons/webob/blob/master/src/webob/cookies.py#L338 |
It sure is a good idea to use webob helpers. Not sure it'll be an easy task |
Here is some code using webob to parse the cookies in a cookiejar into a dict. This is what I'd expect from webob.cookies import Cookie
def parse_cookiejar(jar):
cookie = Cookie(' '.join(c.name + '=' + c.value for c in jar))
return {
m.name.decode('latin1'): m.value.decode('latin1')
for m in cookie.values()
}
cookies = parse_cookiejar(testapp.cookiejar) |
A quick PR could just add from webob.cookies import Cookie
def get_cookie(self, name, default=None):
cookie = Cookie(' '.join(
'%s=%s' % (c.name, c.value)
for c in self.cookiejar
if c.name == name
))
return next(
(m.value.decode('latin-1') for m in cookie.values()),
default,
) |
@gawel could I get some insight on an approach you'd be comfortable with so that I can make a PR? Would you prefer a get_cookie api or would you be open to fixing the |
I'm open to everything. I remember that this code is old (maybe written at the webtest sprint.. 10 years ago ? :D ) The best approach is probably to replace everything you can by using webob's api. I have no problem to break backward compats. This is why semver is for. And maybe it can be a good opportunity to remove py2 compat too. |
Dictionary testapp.cookies has invalid value after call testapp.set_cookie():
The text was updated successfully, but these errors were encountered: