Merge lp://qastaging/~cjwatson/launchpad/safer-ajax-strings into lp://qastaging/launchpad

Proposed by Colin Watson
Status: Merged
Merged at revision: 17815
Proposed branch: lp://qastaging/~cjwatson/launchpad/safer-ajax-strings
Merge into: lp://qastaging/launchpad
Diff against target: 25 lines (+3/-2)
2 files modified
lib/lp/app/javascript/client.js (+2/-1)
lib/lp/app/javascript/tests/test_lp_client.js (+1/-1)
To merge this branch: bzr merge lp://qastaging/~cjwatson/launchpad/safer-ajax-strings
Reviewer Review Type Date Requested Status
William Grant code Approve
Roberto Alsina (community) Approve
Review via email: mp+274166@code.qastaging.launchpad.net

Commit message

Make the JS webservice client stringify string parameters rather than relying on lazr.restful's dodgy special casing.

Description of the change

lazr.restful has a special case in marshall_from_request that allows clients to get away without stringifying string parameters, but this is somewhat dodgy: for example, it crashes if a parameter consists only of whitespace, which is possible if you try to submit a vote on a merge proposal including a single space as the comment (https://oops.canonical.com/?oopsid=OOPS-bb42b8f55c6448f820a2539605e06ea3). Rather than relying on this, I think it's better to encode string parameters as JSON strings.

I left ws.op unencoded, as that seemed likely to result in test fallout, and that parameter will always be an identifier anyway.

To post a comment you must log in.
Revision history for this message
Roberto Alsina (ralsina) wrote :

Thanks Colin, here is my totally useless but very gratueful +1 :-)

review: Approve
Revision history for this message
William Grant (wgrant) wrote :

It is conceivable that this will fix https://bugs.launchpad.net/launchpad/+bug/581748.

Revision history for this message
William Grant (wgrant) wrote :

What a readable test.

review: Approve (code)

Preview Diff

[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
The diff is not available at this time. You can reload the page or download it.