From 5b15e0b6e9eb8fc83e1f570939e6ffb9e63048cc Mon Sep 17 00:00:00 2001 From: Fabian Braun Date: Sun, 12 Nov 2023 15:00:43 +0100 Subject: [PATCH 01/14] Remove `get_absolute_url()` from Alias --- djangocms_alias/cms_plugins.py | 21 ++++++++------- djangocms_alias/cms_toolbars.py | 5 ++-- djangocms_alias/forms.py | 5 +--- djangocms_alias/internal_search.py | 4 +-- djangocms_alias/models.py | 17 +----------- .../alias/delete_confirmation.html | 2 +- tests/test_admin.py | 9 ++++--- tests/test_cms_plugins.py | 7 ++--- tests/test_menu.py | 6 +++-- tests/test_models.py | 2 +- tests/test_views.py | 27 ++++++++++--------- tests/test_wizards.py | 6 +++-- 12 files changed, 51 insertions(+), 60 deletions(-) diff --git a/djangocms_alias/cms_plugins.py b/djangocms_alias/cms_plugins.py index 039547ee..6f80f6d2 100644 --- a/djangocms_alias/cms_plugins.py +++ b/djangocms_alias/cms_plugins.py @@ -1,5 +1,6 @@ from copy import copy +from cms.toolbar.utils import get_object_edit_url from django.utils.translation import ( get_language_from_request, gettext_lazy as _, @@ -41,20 +42,22 @@ def get_render_template(self, context, instance, placeholder): @classmethod def get_extra_plugin_menu_items(cls, request, plugin): if plugin.plugin_type == cls.__name__: - edit_endpoint = plugin.alias.get_absolute_url() + alias_content = plugin.alias.get_content() detach_endpoint = admin_reverse( DETACH_ALIAS_PLUGIN_URL_NAME, args=[plugin.pk], ) - plugin_menu_items = [ - PluginMenuItem( - _('Edit Alias'), - edit_endpoint, - action='sideframe', - attributes={'cms-icon': 'alias'}, - ), - ] + plugin_menu_items = [] + if alias_content: + plugin_menu_items.append( + PluginMenuItem( + _('Edit Alias'), + get_object_edit_url(alias_content), + action='', + attributes={'cms-icon': 'alias'}, + ), + ) if cls.can_detach( request.user, diff --git a/djangocms_alias/cms_toolbars.py b/djangocms_alias/cms_toolbars.py index faca20c5..275b7b60 100644 --- a/djangocms_alias/cms_toolbars.py +++ b/djangocms_alias/cms_toolbars.py @@ -1,6 +1,7 @@ import itertools from copy import copy +from cms.toolbar.utils import get_object_edit_url from django.urls import NoReverseMatch from django.utils.encoding import force_str from django.utils.http import urlencode @@ -20,7 +21,6 @@ from cms.toolbar_base import CMSToolbar from cms.toolbar_pool import toolbar_pool from cms.utils.i18n import ( - force_language, get_default_language, get_language_dict, get_language_tuple, @@ -193,8 +193,7 @@ def override_language_switcher(self): show_draft_content=True, ) if alias_content: - with force_language(code): - url = alias_content.get_absolute_url() + url = get_object_edit_url(alias_content, language=code) language_menu.add_link_item(name, url=url, active=self.current_lang == code) def change_language_menu(self): diff --git a/djangocms_alias/forms.py b/djangocms_alias/forms.py index a958d3ff..0741b1bb 100644 --- a/djangocms_alias/forms.py +++ b/djangocms_alias/forms.py @@ -153,14 +153,11 @@ def save(self): category=self.cleaned_data.get('category'), site=self.cleaned_data.get('site'), ) - alias_content = AliasContent.objects.create( + alias_content = AliasContent.objects.with_user(self.user).create( alias=alias, name=self.cleaned_data.get('name'), language=self.cleaned_data.get('language'), ) - if is_versioning_enabled(): - from djangocms_versioning.models import Version - Version.objects.create(content=alias_content, created_by=self.user) if self.cleaned_data.get('replace'): placeholder = self.cleaned_data.get('placeholder') plugin = self.cleaned_data.get('plugin') diff --git a/djangocms_alias/internal_search.py b/djangocms_alias/internal_search.py index acb0e5e3..d72b183d 100644 --- a/djangocms_alias/internal_search.py +++ b/djangocms_alias/internal_search.py @@ -1,7 +1,7 @@ from django.template import RequestContext from django.utils.translation import gettext_lazy as _ -from cms.toolbar.utils import get_toolbar_from_request +from cms.toolbar.utils import get_toolbar_from_request, get_object_preview_url from djangocms_internalsearch.base import BaseSearchConfig from djangocms_internalsearch.helpers import get_request, get_version_object @@ -79,7 +79,7 @@ def prepare_text(self, obj): return content def prepare_url(self, obj): - return obj.get_absolute_url() + return get_object_preview_url(obj) def prepare_category(self, obj): obj.alias.category.set_current_language(obj.language) diff --git a/djangocms_alias/models.py b/djangocms_alias/models.py index f6af0d63..a0b7e96d 100644 --- a/djangocms_alias/models.py +++ b/djangocms_alias/models.py @@ -13,7 +13,6 @@ from cms.models import CMSPlugin, Placeholder from cms.models.fields import PlaceholderRelationField from cms.models.managers import WithUserMixin -from cms.toolbar.utils import get_object_preview_url from cms.utils.plugins import copy_plugins_to_placeholder from cms.utils.urlutils import admin_reverse @@ -64,7 +63,7 @@ def __str__(self): # Be sure to be able to see the category name even if it's not in the current language return self.safe_translation_getter("name", any_language=True) - def get_absolute_url(self): + def get_edit_url(self): """Builds the url to the admin category change view""" return admin_reverse(CHANGE_CATEGORY_URL_NAME, args=[self.pk]) @@ -160,17 +159,6 @@ def get_name(self, language=None): return name - def get_absolute_url(self, language=None): - if is_versioning_enabled(): - from djangocms_versioning.helpers import ( - version_list_url_for_grouper, - ) - - return version_list_url_for_grouper(self) - content = self.get_content(language=language) - if content: - return content.get_absolute_url() - def get_content(self, language=None, show_draft_content=False): if not language: language = get_language() @@ -293,9 +281,6 @@ def placeholder(self): def get_placeholders(self): return [self.placeholder] - def get_absolute_url(self): - return get_object_preview_url(self) - def get_template(self): return 'djangocms_alias/alias_content.html' diff --git a/djangocms_alias/templates/admin/djangocms_alias/alias/delete_confirmation.html b/djangocms_alias/templates/admin/djangocms_alias/alias/delete_confirmation.html index ae4878ab..70c55eff 100644 --- a/djangocms_alias/templates/admin/djangocms_alias/alias/delete_confirmation.html +++ b/djangocms_alias/templates/admin/djangocms_alias/alias/delete_confirmation.html @@ -26,7 +26,7 @@ {% for item in object.objects_using %}
  • {{ item|verbose_name|capfirst|escape }}: - {{ item }} + {% if item.get_absolute_url %}{{ item }}{% else %}{{ item }}{% endif %}
  • {% endfor %} diff --git a/tests/test_admin.py b/tests/test_admin.py index 6b73d984..1e9ad91f 100644 --- a/tests/test_admin.py +++ b/tests/test_admin.py @@ -1,5 +1,6 @@ from unittest import skipUnless +from cms.toolbar.utils import get_object_edit_url, get_object_preview_url from django.contrib.auth.models import Permission from django.urls import reverse from django.utils.formats import localize @@ -223,7 +224,7 @@ def test_alias_content_manager_rendering_preview_add_url(self): response_content_decoded = response.content.decode() self.assertIn( - expected_en_content.get_absolute_url(), + get_object_preview_url(expected_en_content), response_content_decoded, ) self.assertNotIn( @@ -425,9 +426,9 @@ def test_aliascontent_list_view(self): self.assertNotContains(response, "Published") self.assertNotContains(response, "Draft") - aliascontent1_url = alias1.get_absolute_url() - aliascontent2_url = alias2.get_absolute_url() - aliascontent3_url = alias3.get_absolute_url() + aliascontent1_url = get_object_preview_url(alias1.get_content(show_draft_content=True)) + aliascontent2_url = get_object_preview_url(alias2.get_content(show_draft_content=True)) + aliascontent3_url = get_object_preview_url(alias3.get_content(show_draft_content=True)) # when versioning is not enabled, the django admin change form # is used which used links to the aliascontent_change view diff --git a/tests/test_cms_plugins.py b/tests/test_cms_plugins.py index af19b5d7..d231f504 100644 --- a/tests/test_cms_plugins.py +++ b/tests/test_cms_plugins.py @@ -3,6 +3,7 @@ from urllib.parse import urlparse from cms.api import add_plugin, create_title +from cms.toolbar.utils import get_object_edit_url from cms.utils import get_current_site from cms.utils.plugins import downcast_plugins from cms.utils.urlutils import admin_reverse @@ -51,8 +52,8 @@ def test_extra_plugin_items_for_alias_plugins(self): self.assertEqual(len(extra_items), 2) first, second = extra_items self.assertEqual(first.name, 'Edit Alias') - self.assertEqual(first.url, alias.get_absolute_url()) - self.assertEqual(first.action, 'sideframe') + self.assertEqual(first.url, get_object_edit_url(alias.get_content())) + self.assertEqual(first.action, '') self.assertEqual(second.name, 'Detach Alias') self.assertEqual(second.action, 'modal') @@ -96,7 +97,7 @@ def test_extra_plugin_items_with_versioning_checks(self): first = extra_items[0] # We cannot detach alias on undraft page self.assertEqual(first.name, 'Edit Alias') - self.assertEqual(first.url, alias.get_absolute_url()) + self.assertEqual(first.url, get_object_edit_url(alias.get_content())) def test_rendering_plugin_on_page(self): alias = self._create_alias(published=True) diff --git a/tests/test_menu.py b/tests/test_menu.py index 37f0d359..cd52513f 100644 --- a/tests/test_menu.py +++ b/tests/test_menu.py @@ -1,3 +1,5 @@ +from cms.toolbar.utils import get_object_edit_url + from djangocms_alias.utils import is_versioning_enabled from .base import BaseAliasPluginTestCase @@ -8,8 +10,8 @@ class AliasMenuTestCase(BaseAliasPluginTestCase): def test_alias_pages_have_no_menu_nodes(self): alias = self._create_alias() with self.login_user_context(self.superuser): - response = self.client.get(alias.get_absolute_url()) - if is_versioning_enabled(): + response = self.client.get(get_object_edit_url(alias.get_content())) + if is_versioning_enabled() and False: self.assertNotContains(response, ' From a026a8a67da8eb636431a0d1308a17bf98c27d02 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 12 Feb 2024 09:55:56 +0000 Subject: [PATCH 10/14] ci: auto fixes from pre-commit hooks for more information, see https://pre-commit.ci --- djangocms_alias/cms_plugins.py | 6 +++--- djangocms_alias/cms_toolbars.py | 4 +++- djangocms_alias/forms.py | 6 +++--- tests/test_admin.py | 12 +++++++++--- tests/test_cms_plugins.py | 6 +++--- tests/test_views.py | 20 +++++++++++++++----- 6 files changed, 36 insertions(+), 18 deletions(-) diff --git a/djangocms_alias/cms_plugins.py b/djangocms_alias/cms_plugins.py index 0149d984..19afddfc 100644 --- a/djangocms_alias/cms_plugins.py +++ b/djangocms_alias/cms_plugins.py @@ -52,10 +52,10 @@ def get_extra_plugin_menu_items(cls, request, plugin): if alias_content: plugin_menu_items.append( PluginMenuItem( - _('Edit Alias'), + _("Edit Alias"), get_object_edit_url(alias_content), - action='', - attributes={'cms-icon': 'alias'}, + action="", + attributes={"cms-icon": "alias"}, ), ) diff --git a/djangocms_alias/cms_toolbars.py b/djangocms_alias/cms_toolbars.py index c00413fd..773f3207 100644 --- a/djangocms_alias/cms_toolbars.py +++ b/djangocms_alias/cms_toolbars.py @@ -194,7 +194,9 @@ def override_language_switcher(self): ) if alias_content: url = get_object_edit_url(alias_content, language=code) - language_menu.add_link_item(name, url=url, active=self.current_lang == code) + language_menu.add_link_item( + name, url=url, active=self.current_lang == code + ) def change_language_menu(self): if self.toolbar.edit_mode_active and isinstance(self.toolbar.obj, AliasContent): diff --git a/djangocms_alias/forms.py b/djangocms_alias/forms.py index 8bd0f806..b246e572 100644 --- a/djangocms_alias/forms.py +++ b/djangocms_alias/forms.py @@ -158,9 +158,9 @@ def save(self): name=self.cleaned_data.get("name"), language=self.cleaned_data.get("language"), ) - if self.cleaned_data.get('replace'): - placeholder = self.cleaned_data.get('placeholder') - plugin = self.cleaned_data.get('plugin') + if self.cleaned_data.get("replace"): + placeholder = self.cleaned_data.get("placeholder") + plugin = self.cleaned_data.get("plugin") source_plugins = None else: placeholder, plugin = None, None diff --git a/tests/test_admin.py b/tests/test_admin.py index fea99c6b..77b7b594 100644 --- a/tests/test_admin.py +++ b/tests/test_admin.py @@ -451,9 +451,15 @@ def test_aliascontent_list_view(self): self.assertNotContains(response, "Published") self.assertNotContains(response, "Draft") - aliascontent1_url = get_object_preview_url(alias1.get_content(show_draft_content=True)) - aliascontent2_url = get_object_preview_url(alias2.get_content(show_draft_content=True)) - aliascontent3_url = get_object_preview_url(alias3.get_content(show_draft_content=True)) + aliascontent1_url = get_object_preview_url( + alias1.get_content(show_draft_content=True) + ) + aliascontent2_url = get_object_preview_url( + alias2.get_content(show_draft_content=True) + ) + aliascontent3_url = get_object_preview_url( + alias3.get_content(show_draft_content=True) + ) # when versioning is not enabled, the django admin change form # is used which used links to the aliascontent_change view diff --git a/tests/test_cms_plugins.py b/tests/test_cms_plugins.py index 1ccfe558..ceb65c94 100644 --- a/tests/test_cms_plugins.py +++ b/tests/test_cms_plugins.py @@ -54,9 +54,9 @@ def test_extra_plugin_items_for_alias_plugins(self): self.assertEqual(len(extra_items), 2) first, second = extra_items - self.assertEqual(first.name, 'Edit Alias') + self.assertEqual(first.name, "Edit Alias") self.assertEqual(first.url, get_object_edit_url(alias.get_content())) - self.assertEqual(first.action, '') + self.assertEqual(first.action, "") self.assertEqual(second.name, "Detach Alias") self.assertEqual(second.action, "modal") @@ -99,7 +99,7 @@ def test_extra_plugin_items_with_versioning_checks(self): self.assertEqual(len(extra_items), 1) first = extra_items[0] # We cannot detach alias on undraft page - self.assertEqual(first.name, 'Edit Alias') + self.assertEqual(first.name, "Edit Alias") self.assertEqual(first.url, get_object_edit_url(alias.get_content())) def test_rendering_plugin_on_page(self): diff --git a/tests/test_views.py b/tests/test_views.py index a7c4da30..0541a142 100644 --- a/tests/test_views.py +++ b/tests/test_views.py @@ -1552,7 +1552,9 @@ def test_view_multilanguage(self): if is_versioning_enabled(): # we need to call get_absolute_url on the AliasContent object when versioning is enabled, # otherwise we are taken to the version list url - detail_response = self.client.get(get_object_edit_url(alias.get_content(language="en"))) + detail_response = self.client.get( + get_object_edit_url(alias.get_content(language="en")) + ) else: detail_response = self.client.get(alias.get_absolute_url()) list_response = self.client.get( @@ -1570,9 +1572,13 @@ def test_view_multilanguage(self): if is_versioning_enabled(): # we need to call get_absolute_url on the AliasContent object when versioning is enabled, # otherwise we are taken to the version list url - detail_response = self.client.get(get_object_edit_url(alias_content_de)) + detail_response = self.client.get( + get_object_edit_url(alias_content_de) + ) else: - detail_response = self.client.get(get_object_edit_url(alias.get_content())) + detail_response = self.client.get( + get_object_edit_url(alias.get_content()) + ) list_response = self.client.get( admin_reverse(LIST_ALIAS_URL_NAME), ) @@ -1588,9 +1594,13 @@ def test_view_multilanguage(self): if is_versioning_enabled(): # we need to call get_absolute_url on the AliasContent object when versioning is enabled, # otherwise we are taken to the version list url - detail_response = self.client.get(get_object_edit_url(alias_content_fr)) + detail_response = self.client.get( + get_object_edit_url(alias_content_fr) + ) else: - detail_response = self.client.get(get_object_edit_url(alias.get_content())) + detail_response = self.client.get( + get_object_edit_url(alias.get_content()) + ) list_response = self.client.get( admin_reverse(LIST_ALIAS_URL_NAME), # noqa: E501 ) From af96faefcf62f9e8936a002566a25ebcfef5cc0f Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Tue, 5 Mar 2024 07:06:20 +0000 Subject: [PATCH 11/14] ci: auto fixes from pre-commit hooks for more information, see https://pre-commit.ci --- djangocms_alias/cms_toolbars.py | 4 +--- djangocms_alias/internal_search.py | 5 +---- tests/test_admin.py | 20 ++++---------------- tests/test_views.py | 25 ++++++------------------- tests/test_wizards.py | 3 --- 5 files changed, 12 insertions(+), 45 deletions(-) diff --git a/djangocms_alias/cms_toolbars.py b/djangocms_alias/cms_toolbars.py index dc8043bc..7d241470 100644 --- a/djangocms_alias/cms_toolbars.py +++ b/djangocms_alias/cms_toolbars.py @@ -186,9 +186,7 @@ def override_language_switcher(self): ) if alias_content: url = get_object_edit_url(alias_content, language=code) - language_menu.add_link_item( - name, url=url, active=self.current_lang == code - ) + language_menu.add_link_item(name, url=url, active=self.current_lang == code) def change_language_menu(self): if self.toolbar.edit_mode_active and isinstance(self.toolbar.obj, AliasContent): diff --git a/djangocms_alias/internal_search.py b/djangocms_alias/internal_search.py index 9fb516dc..30b02c15 100644 --- a/djangocms_alias/internal_search.py +++ b/djangocms_alias/internal_search.py @@ -1,9 +1,6 @@ -from cms.toolbar.utils import get_toolbar_from_request +from cms.toolbar.utils import get_object_preview_url, get_toolbar_from_request from django.template import RequestContext from django.utils.translation import gettext_lazy as _ - -from cms.toolbar.utils import get_object_preview_url, get_toolbar_from_request - from djangocms_internalsearch.base import BaseSearchConfig from djangocms_internalsearch.helpers import get_request, get_version_object from haystack import indexes diff --git a/tests/test_admin.py b/tests/test_admin.py index 8908e88b..3125990b 100644 --- a/tests/test_admin.py +++ b/tests/test_admin.py @@ -2,6 +2,7 @@ from bs4 import BeautifulSoup from cms.api import add_plugin +from cms.toolbar.utils import get_object_preview_url from cms.utils.i18n import force_language from cms.utils.urlutils import add_url_parameters, admin_reverse from django.contrib.auth.models import Permission @@ -9,13 +10,6 @@ from django.utils.formats import localize from django.utils.timezone import localtime -from cms.api import add_plugin -from cms.toolbar.utils import get_object_preview_url -from cms.utils.i18n import force_language -from cms.utils.urlutils import add_url_parameters, admin_reverse - -from bs4 import BeautifulSoup - from djangocms_alias.constants import ( CHANGE_ALIAS_URL_NAME, USAGE_ALIAS_URL_NAME, @@ -435,15 +429,9 @@ def test_aliascontent_list_view(self): self.assertNotContains(response, "Published") self.assertNotContains(response, "Draft") - aliascontent1_url = get_object_preview_url( - alias1.get_content(show_draft_content=True) - ) - aliascontent2_url = get_object_preview_url( - alias2.get_content(show_draft_content=True) - ) - aliascontent3_url = get_object_preview_url( - alias3.get_content(show_draft_content=True) - ) + aliascontent1_url = get_object_preview_url(alias1.get_content(show_draft_content=True)) + aliascontent2_url = get_object_preview_url(alias2.get_content(show_draft_content=True)) + aliascontent3_url = get_object_preview_url(alias3.get_content(show_draft_content=True)) # when versioning is not enabled, the django admin change form # is used which used links to the aliascontent_change view diff --git a/tests/test_views.py b/tests/test_views.py index aa287c24..e0c4e9f3 100644 --- a/tests/test_views.py +++ b/tests/test_views.py @@ -893,10 +893,7 @@ def test_alias_usage_view(self): ) self.assertRegex( str(response.content), - r'href="{}"[\w+]?>{}<\/a>'.format( - re.escape(get_object_preview_url(root_alias.get_content())), - str(alias), - ), + rf'href="{re.escape(get_object_preview_url(root_alias.get_content()))}"[\w+]?>{str(alias)}<\/a>', ) self.assertRegex( str(response.content), @@ -1530,9 +1527,7 @@ def test_view_multilanguage(self): if is_versioning_enabled(): # we need to call get_absolute_url on the AliasContent object when versioning is enabled, # otherwise we are taken to the version list url - detail_response = self.client.get( - get_object_edit_url(alias.get_content(language="en")) - ) + detail_response = self.client.get(get_object_edit_url(alias.get_content(language="en"))) else: detail_response = self.client.get(alias.get_absolute_url()) list_response = self.client.get( @@ -1550,13 +1545,9 @@ def test_view_multilanguage(self): if is_versioning_enabled(): # we need to call get_absolute_url on the AliasContent object when versioning is enabled, # otherwise we are taken to the version list url - detail_response = self.client.get( - get_object_edit_url(alias_content_de) - ) + detail_response = self.client.get(get_object_edit_url(alias_content_de)) else: - detail_response = self.client.get( - get_object_edit_url(alias.get_content()) - ) + detail_response = self.client.get(get_object_edit_url(alias.get_content())) list_response = self.client.get( admin_reverse(LIST_ALIAS_URL_NAME), ) @@ -1572,13 +1563,9 @@ def test_view_multilanguage(self): if is_versioning_enabled(): # we need to call get_absolute_url on the AliasContent object when versioning is enabled, # otherwise we are taken to the version list url - detail_response = self.client.get( - get_object_edit_url(alias_content_fr) - ) + detail_response = self.client.get(get_object_edit_url(alias_content_fr)) else: - detail_response = self.client.get( - get_object_edit_url(alias.get_content()) - ) + detail_response = self.client.get(get_object_edit_url(alias.get_content())) list_response = self.client.get( admin_reverse(LIST_ALIAS_URL_NAME), # noqa: E501 ) diff --git a/tests/test_wizards.py b/tests/test_wizards.py index a78e9767..cf692652 100644 --- a/tests/test_wizards.py +++ b/tests/test_wizards.py @@ -1,6 +1,3 @@ -from django.contrib.sites.models import Site -from django.utils import translation - from cms.toolbar.utils import get_object_edit_url from cms.utils import get_current_site from cms.wizards.forms import WizardStep2BaseForm, step2_form_factory From 23313b3e689075b23256b91b25207e56c9cfb4df Mon Sep 17 00:00:00 2001 From: Fabian Braun Date: Tue, 5 Mar 2024 08:07:28 +0100 Subject: [PATCH 12/14] Update djangocms_alias/templatetags/djangocms_alias_tags.py --- djangocms_alias/templatetags/djangocms_alias_tags.py | 1 - 1 file changed, 1 deletion(-) diff --git a/djangocms_alias/templatetags/djangocms_alias_tags.py b/djangocms_alias/templatetags/djangocms_alias_tags.py index 27fd754c..49f3d458 100644 --- a/djangocms_alias/templatetags/djangocms_alias_tags.py +++ b/djangocms_alias/templatetags/djangocms_alias_tags.py @@ -30,7 +30,6 @@ def get_alias_usage_view_url(alias, **kwargs): @register.filter() def admin_view_url(obj): - print(f"==> {obj=} {is_editable_model(obj.__class__)=}") if is_editable_model(obj.__class__): # Is obj frontend-editable? return get_object_preview_url(obj) From 3ee50d11d4046506a3f32798444fff74c75bfa7e Mon Sep 17 00:00:00 2001 From: Fabian Braun Date: Tue, 5 Mar 2024 08:24:12 +0100 Subject: [PATCH 13/14] Update tests to allow new redirect of edit object endpoint --- tests/test_menu.py | 2 +- tests/test_views.py | 26 +++++++++++++------------- 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/tests/test_menu.py b/tests/test_menu.py index a0bea416..ec811586 100644 --- a/tests/test_menu.py +++ b/tests/test_menu.py @@ -9,7 +9,7 @@ class AliasMenuTestCase(BaseAliasPluginTestCase): def test_alias_pages_have_no_menu_nodes(self): alias = self._create_alias() with self.login_user_context(self.superuser): - response = self.client.get(get_object_edit_url(alias.get_content())) + response = self.client.get(get_object_edit_url(alias.get_content()), follow=True) if is_versioning_enabled() and False: self.assertNotContains(response, '