python3: remove sort try on already sorted profile fields (#40502)

This commit is contained in:
Nicolas Roche 2020-03-07 18:29:34 +01:00
parent 9225efdb96
commit cc0677c7e9
2 changed files with 57 additions and 1 deletions

View File

@ -330,7 +330,6 @@ class Authentic(FileBaseSettingsLoader):
fields = hobo_json.get('profile', {}).get('fields')
if fields:
fields.sort(key=lambda x: x.get('order'))
fields = [x for x in fields if not x['disabled']]
tenant_settings.A2_PROFILE_FIELDS = [x['name'] for x in fields]
tenant_settings.A2_REQUIRED_FIELDS = [

View File

@ -0,0 +1,57 @@
import json
import os
import pytest
from django.conf import UserSettingsHolder
from hobo.deploy.utils import get_hobo_json
from hobo.environment.models import Authentic
from hobo.multitenant.settings_loaders import Authentic as AuthenticLoader
from hobo.profile.models import AttributeDefinition
pytestmark = pytest.mark.django_db
def test_authentic_update_settings_from_path(tmpdir):
a = Authentic(title='bar', slug='bar', base_url='http://bar.example.net')
a.save()
env = get_hobo_json()
fields = env['profile']['fields']
assert [x['name'] for x in fields] == [
u'title', u'first_name', u'last_name', u'email', u'address',u'zipcode',
u'city', u'country', u'birthdate', u'phone', u'mobile']
# swap title and mobile fields
title = AttributeDefinition.objects.get(name='title')
mobile = AttributeDefinition.objects.get(name='mobile')
(title.order, mobile.order) = (mobile.order, title.order)
title.save()
mobile.save()
env = get_hobo_json()
fields = env['profile']['fields']
assert [x['name'] for x in fields] == [
u'mobile', u'first_name', u'last_name', u'email', u'address',u'zipcode',
u'city', u'country', u'birthdate', u'phone', u'title']
assert [x['name'] for x in fields if x['disabled']] == [u'country', u'birthdate']
profile_fields = [x['name'] for x in fields if not x['disabled']]
assert profile_fields == [
u'mobile', u'first_name', u'last_name', u'email',
u'address', u'zipcode', u'city', u'phone', u'title']
# serialize hobo.json
path = os.path.join(str(tmpdir), 'hobo.json')
json.dump(env, open(path, 'w'))
# call settings loaders
tenant_settings = UserSettingsHolder({})
assert not getattr(tenant_settings, 'A2_PROFILE_FIELDS', False)
assert not getattr(tenant_settings, 'A2_REQUIRED_FIELDS', False)
assert not getattr(tenant_settings, 'A2_REGISTRATION_FIELDS', False)
loader = AuthenticLoader()
loader.update_settings_from_path(tenant_settings, path)
assert tenant_settings.A2_PROFILE_FIELDS == profile_fields
assert tenant_settings.A2_REQUIRED_FIELDS == [u'first_name', u'last_name', u'email']
assert tenant_settings.A2_REGISTRATION_FIELDS == [u'first_name', u'last_name']