Browse Source

Warn if default password is not changed, resolve #857

pull/1989/head
Hironsan 2 years ago
parent
commit
2b84f8eeac
2 changed files with 88 additions and 8 deletions
  1. 24
      backend/api/management/commands/create_admin.py
  2. 72
      backend/api/tests/test_commands.py

24
backend/api/management/commands/create_admin.py

@ -13,9 +13,17 @@ class Command(createsuperuser.Command):
password = options.get("password") password = options.get("password")
username = options.get("username") username = options.get("username")
if password and not username:
if not username:
self.stderr.write("Error: Blank username isn't allowed.")
raise CommandError("--username is required if specifying --password") raise CommandError("--username is required if specifying --password")
if not password:
self.stderr.write("Error: Blank password isn't allowed.")
raise CommandError("--password is required")
if password == "password":
self.stdout.write(self.style.WARNING("Warning: You should change the default password."))
try: try:
super().handle(*args, **options) super().handle(*args, **options)
except Exception as err: except Exception as err:
@ -24,10 +32,10 @@ class Command(createsuperuser.Command):
else: else:
raise raise
if password:
database = options.get("database")
db = self.UserModel._default_manager.db_manager(database)
user = db.get(username=username)
user.set_password(password)
self.stderr.write(f"Setting password for User {username}.")
user.save()
database = options.get("database")
db = self.UserModel._default_manager.db_manager(database)
user = db.get(username=username)
user.set_password(password)
message = f"Setting password for User {username}."
self.stdout.write(self.style.SUCCESS(message))
user.save()

72
backend/api/tests/test_commands.py

@ -0,0 +1,72 @@
from unittest.mock import MagicMock
from django.contrib.auth import get_user_model
from django.core.management import CommandError
from django.test import TestCase
from api.management.commands.create_admin import Command
class TestCreateAdminCommand(TestCase):
def test_can_create_user(self):
mock_out = MagicMock()
command = Command(stdout=mock_out)
command.handle(
username="user",
password="whoami",
email="example@doccano.com",
database="default",
interactive=False,
verbosity=0,
)
self.assertEqual(get_user_model().objects.count(), 1)
mock_out.write.assert_called_once_with("Setting password for User user.\n")
def test_raise_error_if_username_is_not_given(self):
mock_err = MagicMock()
command = Command(stderr=mock_err)
with self.assertRaises(CommandError):
command.handle(
password="whoami", email="example@doccano.com", database="default", interactive=False, verbosity=0
)
mock_err.write.assert_called_once_with("Error: Blank username isn't allowed.\n")
def test_raise_error_if_password_is_not_given(self):
mock_err = MagicMock()
command = Command(stderr=mock_err)
with self.assertRaises(CommandError):
command.handle(
username="user", email="example@doccano.com", database="default", interactive=False, verbosity=0
)
mock_err.write.assert_called_once_with("Error: Blank password isn't allowed.\n")
def test_warn_default_password(self):
mock_out = MagicMock()
command = Command(stdout=mock_out)
command.handle(
username="user",
password="password",
email="example@doccano.com",
database="default",
interactive=False,
verbosity=0,
)
self.assertEqual(get_user_model().objects.count(), 1)
self.assertEqual(mock_out.write.call_count, 2)
mock_out.write.assert_any_call("Warning: You should change the default password.\n")
mock_out.write.assert_any_call("Setting password for User user.\n")
def test_warn_duplicate_username(self):
get_user_model().objects.create(username="admin", password="pass")
mock_err = MagicMock()
command = Command(stderr=mock_err)
command.handle(
username="admin",
password="whoami",
email="example@doccano.com",
database="default",
interactive=False,
verbosity=0,
)
self.assertEqual(get_user_model().objects.count(), 1)
mock_err.write.assert_called_once_with("User admin already exists.\n")
Loading…
Cancel
Save