Skip to content

Commit

Permalink
🐛[maykinmedia/open-api-framework#39] make user emails unique
Browse files Browse the repository at this point in the history
  • Loading branch information
Coperh committed Jul 2, 2024
1 parent 3a2bc22 commit f5342fa
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Generated by Django 4.2.11 on 2024-07-02 14:48

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
("accounts", "0001_initial"),
]

operations = [
migrations.AddConstraint(
model_name="user",
constraint=models.UniqueConstraint(
condition=models.Q(("email", ""), _negated=True),
fields=("email",),
name="filled_email_unique",
),
),
]
6 changes: 6 additions & 0 deletions src/objecttypes/accounts/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
from django.db import models
from django.utils import timezone
from django.utils.translation import gettext_lazy as _
from django.db.models import Q

from .managers import UserManager

Expand Down Expand Up @@ -46,6 +47,11 @@ class User(AbstractBaseUser, PermissionsMixin):
class Meta:
verbose_name = _("user")
verbose_name_plural = _("users")
constraints = [
models.UniqueConstraint(
fields=["email"], condition=~Q(email=""), name="filled_email_unique"
)
]

def get_full_name(self):
"""
Expand Down
13 changes: 13 additions & 0 deletions src/objecttypes/accounts/tests/test_user_manager.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
from django.test import TestCase
from django.db import IntegrityError

from ..models import User

Expand All @@ -20,3 +21,15 @@ def test_create_user(self):
self.assertFalse(user.is_superuser)
self.assertFalse(user.is_staff)
self.assertFalse(user.has_usable_password())

def test_create_users_with_same_email(self):
User.objects.create(username="AAA", email="[email protected]", password="aaa!")

with self.assertRaises(IntegrityError):
User.objects.create(username="BBB", email="[email protected]", password="bbb!")

def test_create_user_with_blank_emails(self):
User.objects.create(username="AAA", email="", password="aaa!")
User.objects.create(username="BBB", email="", password="bbb!")

self.assertEqual(User.objects.count(), 2)

0 comments on commit f5342fa

Please sign in to comment.