Skip to content

Commit

Permalink
Fix bug 1312027: Include confirm query params in success redirect
Browse files Browse the repository at this point in the history
  • Loading branch information
pmac committed Nov 1, 2016
1 parent 1d04bbd commit 4b7fe26
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 2 deletions.
15 changes: 14 additions & 1 deletion bedrock/newsletter/tests/test_views.py
Expand Up @@ -443,7 +443,20 @@ def test_normal(self):
confirm.return_value = {'status': 'ok'}
rsp = self.client.get(self.url)
self.assertEqual(302, rsp.status_code)
self.assertTrue(rsp['Location'].endswith("%s?confirm=1" % reverse('newsletter.existing.token', kwargs={'token': self.token})))
self.assertTrue(rsp['Location'].endswith("%s?confirm=1" %
reverse('newsletter.existing.token',
kwargs={'token': self.token})))

def test_normal_with_query_params(self):
"""Confirm works with a valid token"""
with patch('basket.confirm') as confirm:
confirm.return_value = {'status': 'ok'}
rsp = self.client.get(self.url + '?utm_tracking=oh+definitely+yes&utm_source=malibu')
self.assertEqual(302, rsp.status_code)
self.assertTrue(rsp['Location'].endswith("%s?confirm=1&utm_tracking=oh+definitely+yes&"
"utm_source=malibu" %
reverse('newsletter.existing.token',
kwargs={'token': self.token})))

def test_basket_down(self):
"""If basket is down, we report the appropriate error"""
Expand Down
8 changes: 7 additions & 1 deletion bedrock/newsletter/views.py
Expand Up @@ -218,7 +218,13 @@ def confirm(request, token):
# Assume rate limit error means user already confirmed and clicked confirm
# link twice in quick succession
if success or rate_limit_error:
return HttpResponseRedirect("%s?confirm=1" % reverse('newsletter.existing.token', kwargs={'token': token}))
qparams = ['confirm=1']
qs = request.META.get('QUERY_STRING', '')
if qs:
qparams.append(qs)
return HttpResponseRedirect("%s?%s" % (reverse('newsletter.existing.token',
kwargs={'token': token}),
'&'.join(qparams)))
else:
return l10n_utils.render(
request,
Expand Down

0 comments on commit 4b7fe26

Please sign in to comment.