Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Django 1.11 #3815

Merged
merged 57 commits into from
Sep 23, 2024
Merged
Show file tree
Hide file tree
Changes from 56 commits
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
a2d6337
Bump to django 1.11
hipek8 May 17, 2024
f597a8d
Fix test models
hipek8 May 17, 2024
5836cc5
Fix polymorphic queryset
hipek8 May 20, 2024
c813f86
Adjust drf version
hipek8 May 20, 2024
af19481
Fix CustomFieldValueAdminMaxinTestCase
matyldv May 21, 2024
7d9d4d8
Fix IPNetwork filtering
hipek8 May 21, 2024
64c8de1
Don't fail fast test matrix
hipek8 May 21, 2024
9320f11
Fix polymorphic queryset again
hipek8 May 22, 2024
b7fcf5c
fix PermissionsSelectWidget
awieckowski May 22, 2024
1ac94b6
fix test
awieckowski May 22, 2024
37c4050
Fix serializers
matyldv May 22, 2024
92353f3
Fix isort
matyldv May 23, 2024
2d8c67e
fix InlineM2MAdminMixin
awieckowski May 28, 2024
103cce9
Fix related_widget_wrapper
matyldv Jun 4, 2024
099119f
Merge Django 1.10 changes
matyldv Jun 4, 2024
5ba052d
Fix polymorphic querysets
hipek8 Jun 5, 2024
3c1dc6b
Merge branch 'bump-to-django-1.11' of github.com:allegro/ralph into b…
hipek8 Jun 5, 2024
889134d
Adjust polymorphic querysets and prefetches
hipek8 Jun 10, 2024
03a5c28
Fix flake
hipek8 Jun 10, 2024
22615ce
Don't run postgres. Fix flake
hipek8 Jun 10, 2024
051650b
Fix polymorphic for psql
hipek8 Jun 10, 2024
66aecc4
Optimize queries. Add tests
hipek8 Jun 10, 2024
a8b9c31
Optimize API and improve API tests
hipek8 Jun 10, 2024
d3772fb
merge django-1.10 and django-1.11 branches
hipek8 Jun 12, 2024
f797e8a
Fix flake. adjust query num
hipek8 Jun 14, 2024
20b165e
Fix custom fields
matyldv Jun 14, 2024
89bb1fa
Fix different quote types in different db engines
hipek8 Jun 14, 2024
61cf5aa
Merge branch 'bump-to-django-1.11' of github.com:allegro/ralph into b…
hipek8 Jun 14, 2024
9fa5db3
Fix isort
matyldv Jun 14, 2024
7dfd9b6
Fix flake
hipek8 Jun 14, 2024
53ff617
Fix missing f-string
hipek8 Jun 14, 2024
b75d633
Fix tests
matyldv Jun 14, 2024
5d3c323
merge django-1.0 into django-1.11
hipek8 Jul 3, 2024
9c98b53
Test API endpoints
hipek8 Jul 25, 2024
d88b13a
Test also json content
hipek8 Jul 26, 2024
ab3da5b
Merge branch 'ng' into bump-to-django-1.11
hipek8 Jul 31, 2024
ed5f7d8
Don't smoke test endpoints for django 1.11
hipek8 Jul 31, 2024
e6c4aeb
Merge branch 'ng' into bump-to-django-1.11
hipek8 Aug 2, 2024
3b78aa0
Merge branch 'ng' into bump-to-django-1.11
hipek8 Aug 5, 2024
92fa73d
Fix transitions form
matyldv Aug 6, 2024
601454e
Fix test_action_choices
matyldv Aug 6, 2024
f546c64
Merge branch 'bump-to-django-1.11' of github.com:allegro/ralph into b…
hipek8 Aug 8, 2024
c7f5326
Merge branch 'ng' into bump-to-django-1.11
hipek8 Aug 23, 2024
a0267e4
Bump django debug toolbar
hipek8 Aug 23, 2024
26782fc
Remove empty include
hipek8 Aug 26, 2024
bc82f6e
Fix default manager lookup
hipek8 Aug 27, 2024
f023212
Fix DC Visualization
matyldv Sep 6, 2024
68c0f20
Merge branch 'ng' into bump-to-django-1.11
hipek8 Sep 10, 2024
34d88e0
Merge branch 'bump-to-django-1.11' of github.com:allegro/ralph into b…
hipek8 Sep 10, 2024
976dd5d
Fix user permissions form
matyldv Sep 16, 2024
537c06c
Fix user permissions form - cleanup
matyldv Sep 16, 2024
468b9fd
Merge branch 'ng' of github.com:allegro/ralph into bump-to-django-1.11
matyldv Sep 18, 2024
057d3e2
Merge pull request #3846 from allegro/fix-missing-js
hipek8 Sep 19, 2024
9df7d13
Fix network terminators on save
hipek8 Sep 20, 2024
6d19c65
Merge pull request #3847 from allegro/django-1.11-fix-terminators
hipek8 Sep 23, 2024
db5e2de
Cleanup
matyldv Sep 23, 2024
581e4a5
Cleanup
matyldv Sep 23, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ jobs:
name: Missing migrations
runs-on: ubuntu-20.04
strategy:
fail-fast: false
matrix:
db-engine: ["psql", "mysql"]
env:
Expand Down Expand Up @@ -117,7 +118,7 @@ jobs:
run: pip3 install psycopg2-binary

# Runs a set of commands using the runners shell
- name: Check missings migrations
- name: Check missing migrations
run: "${GITHUB_WORKSPACE}/scripts/check_missing_migrations.sh"

settings_test:
Expand Down
8 changes: 4 additions & 4 deletions requirements/base.txt
Original file line number Diff line number Diff line change
@@ -1,21 +1,21 @@
-r openstack.txt
-r hermes.txt
Django==1.10.8
Django==1.11.8
dj.choices==0.11.0
django-extensions==1.7.5
django-filter==0.13.0
django-filter==1.0.4
django-import-export==1.2.0
django-money==0.12
py-moneyed==1.2
django-mptt==0.8.7
django-reversion==2.0
django-rq==2.0
django-sitetree==1.7.0
django-sitetree==1.13.0
django-taggit==0.22.2
django-taggit-serializer==0.1.7
django-threadlocals==0.8
django-cryptography==0.3
djangorestframework==3.4.0
djangorestframework==3.4.1
djangorestframework_xml==1.2.0
drf-nested-routers==0.11.1
Markdown<3.0 # headerid extension removed in 3.0 - see #3313 for details
Expand Down
2 changes: 1 addition & 1 deletion requirements/dev.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
-r test.txt
django-debug-toolbar==1.8
django-debug-toolbar==1.11
werkzeug==0.16.1
pudb
ipython
Expand Down
2 changes: 1 addition & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
[flake8]
exclude = migrations,tests,docs,settings*,*local.py
max-complexity = 15
max-line-length = 80
max-line-length = 100
2 changes: 1 addition & 1 deletion src/ralph/accounts/admin.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,9 @@
from django.contrib.auth.admin import GroupAdmin, UserAdmin
from django.contrib.auth.models import Group
from django.core.exceptions import PermissionDenied
from django.core.urlresolvers import reverse
from django.db.models import Q
from django.forms.models import model_to_dict
from django.urls import reverse
from django.utils.functional import cached_property
from django.utils.translation import ugettext_lazy as _
from reversion import revisions as reversion
Expand Down
2 changes: 1 addition & 1 deletion src/ralph/accounts/helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from urllib.parse import urlencode

from django.conf import settings
from django.core.urlresolvers import reverse
from django.urls import reverse

from ralph.access_cards.models import AccessCard
from ralph.admin.sites import ralph_site
Expand Down
4 changes: 2 additions & 2 deletions src/ralph/accounts/tests/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@
from django.conf import settings
from django.contrib.auth.hashers import check_password
from django.contrib.auth.models import Permission
from django.core.urlresolvers import reverse
from django.test import TestCase
from django.urls import reverse
from rest_framework import status

from ralph.accounts.ldap import manager_country_attribute_populate
Expand Down Expand Up @@ -203,7 +203,7 @@ def setUp(self):
settings.INVENTORY_TAG_USER,
self.date_tag,
]

def test_tag_asset(self):
self.assertTrue(self.login_as_user(self.user1))
response = self.client.post(
Expand Down
2 changes: 1 addition & 1 deletion src/ralph/accounts/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@

from django.conf import settings
from django.contrib import messages
from django.core.urlresolvers import reverse
from django.http import HttpResponseForbidden, HttpResponseRedirect
from django.shortcuts import get_object_or_404
from django.urls import reverse
from django.utils.translation import ugettext_lazy as _
from django.views.generic import View
from reversion import revisions as reversion
Expand Down
2 changes: 1 addition & 1 deletion src/ralph/admin/filters.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,10 @@
from django.contrib.admin.filters import FieldListFilter
from django.contrib.admin.options import IncorrectLookupParameters
from django.contrib.admin.utils import get_model_from_relation
from django.core.urlresolvers import reverse
from django.db import models
from django.db.models import Q
from django.forms.utils import flatatt
from django.urls import reverse
from django.utils.encoding import smart_text
from django.utils.formats import get_format
from django.utils.html import conditional_escape, mark_safe
Expand Down
2 changes: 1 addition & 1 deletion src/ralph/admin/helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@

from django.contrib.admin.utils import get_fields_from_path
from django.contrib.contenttypes.models import ContentType
from django.core.urlresolvers import reverse
from django.db.models.constants import LOOKUP_SEP
from django.db.models.expressions import Func
from django.urls import reverse


def get_admin_url(obj, action):
Expand Down
161 changes: 78 additions & 83 deletions src/ralph/admin/m2m.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,19 +53,16 @@ class AuthorAdmin(admin.ModelAdmin):
modelformset_factory
)
from django.utils.text import get_text_list
from django.utils.translation import ugettext_lazy as _
from django.utils.translation import gettext_lazy as _

from ralph.admin.mixins import (
RalphAdminForm,
RalphStackedInline,
RalphTabularInline
)
from ralph.admin.mixins import RalphAdminForm, RalphTabularInline


class BaseInlineM2MFormset(BaseInlineFormSet):
"""
Adjust Django's BaseInlineFormSet to cooperate with M2M relations
"""

def __init__(self, *args, **kwargs):
self._fk = self.fk
# m2m is assigned by m2minlineformset_factory
Expand All @@ -87,7 +84,7 @@ def save_new(self, form, commit=True):

@classmethod
def get_default_prefix(cls):
return cls.m2m.rel.get_accessor_name(model=cls.model).replace('+', '')
return cls.m2m.rel.get_accessor_name(model=cls.model).replace("+", "")

def save_existing_objects(self, commit=True):
"""
Expand Down Expand Up @@ -115,9 +112,7 @@ def save_existing_objects(self, commit=True):
getattr(obj, self.m2m.attname).remove(self.instance)
elif form.has_changed():
self.changed_objects.append((obj, form.changed_data))
saved_instances.append(
self.save_existing(form, obj, commit=commit)
)
saved_instances.append(self.save_existing(form, obj, commit=commit))
if not commit:
self.saved_forms.append(form)
return saved_instances
Expand All @@ -130,8 +125,11 @@ def get_m2m(parent_model, model):
# need to check on both sides (m2m field will be defined only in one of the
# models)
for rel in parent_model._meta.get_fields(include_hidden=True):
if rel.many_to_many and rel.auto_created and \
issubclass(rel.related_model, model):
if (
rel.many_to_many
and rel.auto_created
and issubclass(rel.related_model, model)
):
return rel.field

for rel in parent_model._meta.many_to_many:
Expand All @@ -148,21 +146,33 @@ def get_foreign_key_for_m2m(parent_model, m2m):
m2m: ManyToManyField relation instance
"""
for field in m2m.remote_field.through._meta.fields:
if (
isinstance(field, ForeignKey) and
issubclass(parent_model, field.rel.to)
if isinstance(field, ForeignKey) and issubclass(
parent_model, field.remote_field.model
):
return field


def m2minlineformset_factory(
parent_model, model, form=RalphAdminForm,
formset=BaseInlineM2MFormset, fk_name=None,
fields=None, exclude=None, extra=3, can_order=False,
can_delete=True, max_num=None, formfield_callback=None,
widgets=None, validate_max=False, localized_fields=None,
labels=None, help_texts=None, error_messages=None,
min_num=None, validate_min=False
parent_model,
model,
form=RalphAdminForm,
formset=BaseInlineM2MFormset,
fk_name=None,
fields=None,
exclude=None,
extra=3,
can_order=False,
can_delete=True,
max_num=None,
formfield_callback=None,
widgets=None,
validate_max=False,
localized_fields=None,
labels=None,
help_texts=None,
error_messages=None,
min_num=None,
validate_min=False,
):
"""
Creates m2m formset. This function is very similar to
Expand All @@ -173,23 +183,23 @@ def m2minlineformset_factory(
m2m = get_m2m(parent_model, model)
fk = get_foreign_key_for_m2m(parent_model, m2m)
kwargs = {
'form': form,
'formfield_callback': formfield_callback,
'formset': formset,
'extra': extra,
'can_delete': can_delete,
'can_order': can_order,
'fields': fields,
'exclude': exclude,
'min_num': min_num,
'max_num': max_num,
'widgets': widgets,
'validate_min': validate_min,
'validate_max': validate_max,
'localized_fields': localized_fields,
'labels': labels,
'help_texts': help_texts,
'error_messages': error_messages,
"form": form,
"formfield_callback": formfield_callback,
"formset": formset,
"extra": extra,
"can_delete": can_delete,
"can_order": can_order,
"fields": fields,
"exclude": exclude,
"min_num": min_num,
"max_num": max_num,
"widgets": widgets,
"validate_min": validate_min,
"validate_max": validate_max,
"localized_fields": localized_fields,
"labels": labels,
"help_texts": help_texts,
"error_messages": error_messages,
}
FormSet = modelformset_factory(model, **kwargs)
FormSet.m2m = m2m
Expand All @@ -207,47 +217,36 @@ def get_formset(self, request, obj=None, **kwargs):
The only difference here comparing to the original one is in the last
line.
"""
if 'fields' in kwargs:
fields = kwargs.pop('fields')
if "fields" in kwargs:
fields = kwargs.pop("fields")
else:
fields = flatten_fieldsets(self.get_fieldsets(request, obj))
if self.exclude is None:
exclude = []
else:
exclude = list(self.exclude)
excluded = self.get_exclude(request, obj)
exclude = [] if excluded is None else list(excluded)
exclude.extend(self.get_readonly_fields(request, obj))
if (
self.exclude is None and
hasattr(self.form, '_meta') and
self.form._meta.exclude
):
if excluded is None and hasattr(self.form, "_meta") and self.form._meta.exclude:
# Take the custom ModelForm's Meta.exclude into account only if the
# InlineModelAdmin doesn't define its own.
exclude.extend(self.form._meta.exclude)
# If exclude is an empty list we use None, since that's the actual
# default.
exclude = exclude or None
can_delete = (
self.can_delete and
self.has_delete_permission(request, obj)
)
can_delete = self.can_delete and self.has_delete_permission(request, obj)
defaults = {
"form": self.form,
"formset": self.formset,
"fk_name": self.fk_name,
"fields": fields,
"exclude": exclude,
"formfield_callback": partial(
self.formfield_for_dbfield, request=request
),
"formfield_callback": partial(self.formfield_for_dbfield, request=request),
"extra": self.get_extra(request, obj, **kwargs),
"min_num": self.get_min_num(request, obj, **kwargs),
"max_num": self.get_max_num(request, obj, **kwargs),
"can_delete": can_delete,
}

defaults.update(kwargs)
base_model_form = defaults['form']
base_model_form = defaults["form"]

class DeleteProtectedModelForm(base_model_form):
def hand_clean_DELETE(self):
Expand All @@ -266,50 +265,46 @@ def hand_clean_DELETE(self):
objs = []
for p in collector.protected:
objs.append(
# Translators: Model verbose name and instance
# representation, suitable to be an item in a
# list.
_('%(class_name)s %(instance)s') % {
'class_name': p._meta.verbose_name,
'instance': p}
# Translators: Model verbose name and instance representation,
# suitable to be an item in a list.
_("%(class_name)s %(instance)s")
% {"class_name": p._meta.verbose_name, "instance": p}
)
params = {
'class_name': self._meta.model._meta.verbose_name,
'instance': self.instance,
'related_objects': get_text_list(objs, _('and'))
"class_name": self._meta.model._meta.verbose_name,
"instance": self.instance,
"related_objects": get_text_list(objs, _("and")),
}
msg = _(
"Deleting %(class_name)s %(instance)s would require"
" deleting the following protected related objects:"
" %(related_objects)s"
"Deleting %(class_name)s %(instance)s would require "
"deleting the following protected related objects: "
"%(related_objects)s"
)
raise ValidationError(
msg, code='deleting_protected', params=params
msg, code="deleting_protected", params=params
)

def is_valid(self):
result = super(DeleteProtectedModelForm, self).is_valid()
self.hand_clean_DELETE()
return result

defaults['form'] = DeleteProtectedModelForm
defaults["form"] = DeleteProtectedModelForm

if (
defaults['fields'] is None and
not modelform_defines_fields(defaults['form'])
if defaults["fields"] is None and not modelform_defines_fields(
defaults["form"]
):
defaults['fields'] = forms.ALL_FIELDS
defaults["fields"] = forms.ALL_FIELDS

# THE ONLY DIFFERENCE HERE COMPARING TO ORIGINAL \/
# return m2minlineformset_factory instead of inlineformset_factory
return m2minlineformset_factory(
self.parent_model, self.model, **defaults
)

# dirty fix for through queryset being passed as self.model in init in some cases
if hasattr(self.model._meta, "auto_created") and self.model._meta.auto_created:
self.model = self.model._meta.auto_created

class RalphTabularM2MInline(InlineM2MAdminMixin, RalphTabularInline):
template = 'admin/edit_inline/tabular_m2m.html'
return m2minlineformset_factory(self.parent_model, self.model, **defaults)


class RalphStackedM2MInline(InlineM2MAdminMixin, RalphStackedInline):
pass
class RalphTabularM2MInline(InlineM2MAdminMixin, RalphTabularInline):
template = "admin/edit_inline/tabular_m2m.html"
Loading
Loading