[4.0.x] Fixed #33151 -- Fixed createsuperuser crash for many-to-many required fields in non-interactive mode.
Backport of df2d2bc95c
from main
This commit is contained in:
parent
fc325a1981
commit
f2a59630f4
|
@ -185,6 +185,10 @@ class Command(BaseCommand):
|
||||||
raise CommandError('You must use --%s with --noinput.' % field_name)
|
raise CommandError('You must use --%s with --noinput.' % field_name)
|
||||||
field = self.UserModel._meta.get_field(field_name)
|
field = self.UserModel._meta.get_field(field_name)
|
||||||
user_data[field_name] = field.clean(value, None)
|
user_data[field_name] = field.clean(value, None)
|
||||||
|
if field.many_to_many and isinstance(user_data[field_name], str):
|
||||||
|
user_data[field_name] = [
|
||||||
|
pk.strip() for pk in user_data[field_name].split(',')
|
||||||
|
]
|
||||||
|
|
||||||
self.UserModel._default_manager.db_manager(database).create_superuser(**user_data)
|
self.UserModel._default_manager.db_manager(database).create_superuser(**user_data)
|
||||||
if options['verbosity'] >= 1:
|
if options['verbosity'] >= 1:
|
||||||
|
|
|
@ -994,6 +994,25 @@ class CreatesuperuserManagementCommandTestCase(TestCase):
|
||||||
# Environment variables are ignored for non-required fields.
|
# Environment variables are ignored for non-required fields.
|
||||||
self.assertEqual(user.first_name, '')
|
self.assertEqual(user.first_name, '')
|
||||||
|
|
||||||
|
@override_settings(AUTH_USER_MODEL='auth_tests.CustomUserWithM2m')
|
||||||
|
def test_environment_variable_m2m_non_interactive(self):
|
||||||
|
new_io = StringIO()
|
||||||
|
org_id_1 = Organization.objects.create(name='Organization 1').pk
|
||||||
|
org_id_2 = Organization.objects.create(name='Organization 2').pk
|
||||||
|
with mock.patch.dict(os.environ, {
|
||||||
|
'DJANGO_SUPERUSER_ORGS': f'{org_id_1},{org_id_2}',
|
||||||
|
}):
|
||||||
|
call_command(
|
||||||
|
'createsuperuser',
|
||||||
|
interactive=False,
|
||||||
|
username='joe',
|
||||||
|
stdout=new_io,
|
||||||
|
)
|
||||||
|
command_output = new_io.getvalue().strip()
|
||||||
|
self.assertEqual(command_output, 'Superuser created successfully.')
|
||||||
|
user = CustomUserWithM2M._default_manager.get(username='joe')
|
||||||
|
self.assertEqual(user.orgs.count(), 2)
|
||||||
|
|
||||||
@mock.patch.dict(os.environ, {
|
@mock.patch.dict(os.environ, {
|
||||||
'DJANGO_SUPERUSER_USERNAME': 'test_superuser',
|
'DJANGO_SUPERUSER_USERNAME': 'test_superuser',
|
||||||
'DJANGO_SUPERUSER_EMAIL': 'joe@somewhere.org',
|
'DJANGO_SUPERUSER_EMAIL': 'joe@somewhere.org',
|
||||||
|
|
Loading…
Reference in New Issue