Commits

Luke Plant committed e16c6a3

Fixed bug with emails being treated as case sensitive, which causes confusion.

  • Participants
  • Parent commits 72f0833

Comments (0)

Files changed (2)

File cciw/bookings/tests.py

         self.assertEqual(BookingAccount.objects.all().count(), 1)
         self.assertEqual(len(mail.outbox), 1)
 
+    def test_complete_form_existing_email_different_case(self):
+        BookingAccount.objects.create(email="booker@bookers.com")
+        self.assertEqual(BookingAccount.objects.all().count(), 1)
+        resp = self.client.post(self.url,
+                                {'email': 'BOOKER@bookers.com'})
+        self.assertEqual(BookingAccount.objects.all().count(), 1)
+        self.assertEqual(len(mail.outbox), 1)
+
     def test_skip_if_logged_in(self):
         # This assumes verification process works
         # Check redirect to step 3 - account details

File cciw/bookings/views.py

     def form_valid(self, form):
         email = form.cleaned_data['email']
         try:
-            account = BookingAccount.objects.get(email=email)
-        except BookingAccount.DoesNotExist:
+            account = BookingAccount.objects.filter(email__iexact=email)[0]
+        except IndexError:
             # Ensure we use NULLs, not empty strings, or we will not be able to
             # create more than one, as they will have same 'name and post_code'
             account = BookingAccount.objects.create(email=email,