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

fix: Amélioration de la commande 'create_content_pages' #1545

Merged
merged 3 commits into from
Dec 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ shell_on_postgres_container:
populate_db:
pg_restore -d marche --if-exists --clean --no-owner --no-privileges lemarche/perimeters/management/commands/data/perimeters_20220104.sql
ls -d lemarche/fixtures/django/* | xargs django-admin loaddata
djan-admin create_content_pages
django-admin create_content_pages

populate_db_container:
docker compose exec -ti app bash -c "ls -d lemarche/fixtures/django/* | xargs django-admin loaddata"
Expand Down
17 changes: 10 additions & 7 deletions lemarche/cms/management/commands/create_content_pages.py
Original file line number Diff line number Diff line change
@@ -1,17 +1,23 @@
import json

from django.core.management.base import BaseCommand
from wagtail.models import Site
from wagtail.models import Page

from content_manager.models import ContentPage


class Command(BaseCommand):
help = """
Creates a series of content pages.
Créé une série de pages de type ContentPage.
"""

def handle(self, *args, **kwargs):
try:
home_page = Page.objects.get(title="Accueil")
except Page.DoesNotExist:
self.stdout.write(self.style.ERROR("La page 'Accueil' n'existe pas."))
return

try:
with open("lemarche/fixtures/cms_content_pages.json") as f:
pages_data = json.load(f)
Expand All @@ -28,8 +34,6 @@ def handle(self, *args, **kwargs):
)
return

home_page = Site.objects.filter(is_default_site=True).first().root_page

for page_data in pages_data:
slug = page_data["slug"]
title = page_data["title"]
Expand All @@ -41,15 +45,14 @@ def create_content_page(self, slug: str, title: str, body: list, parent_page: Co
"""
Creates a page for the site.
"""

# Don't replace or duplicate an already existing page
already_exists = ContentPage.objects.filter(slug=slug).first()
if already_exists:
self.stdout.write(f"The {slug} page seem to already exist with id {already_exists.id}")
self.stdout.write(f"La page /{slug}/ semble déjà exister avec l'id {already_exists.id}")
return already_exists

new_page = parent_page.add_child(instance=ContentPage(title=title, body=body, slug=slug, show_in_menus=True))

self.stdout.write(self.style.SUCCESS(f"Page {slug} created with id {new_page.id}"))
self.stdout.write(self.style.SUCCESS(f"Page /{slug}/ créée avec l'id {new_page.id}"))

return new_page
52 changes: 41 additions & 11 deletions lemarche/cms/tests/test_commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,37 +2,67 @@

from django.core.management import call_command
from django.test import Client, TestCase
from wagtail.models import Site
from wagtail.models import Page, Site

from content_manager.models import ContentPage


class CreateContentPagesCommandTests(TestCase):
class CreateContentPagesCommandTest(TestCase):
def setUp(self):
self.root_page = Page.get_root_nodes().first()
self.home_page = Page(title="Accueil")
self.root_page.add_child(instance=self.home_page)
self.home_page.save_revision().publish()

# We change root_page of default site
Site.objects.filter(hostname="localhost", is_default_site=True).update(root_page=self.home_page)

def test_parent_page_setup(self):
"""Test the parent page for the home page is correctly set up"""
self.assertIsNotNone(self.root_page, "La page racine n'a pas été trouvée.")
self.assertIsNotNone(self.home_page, "La page parente 'Accueil' n'a pas été trouvée.")
self.assertTrue(self.home_page.live, "La page parente 'Accueil' n'est pas publiée.")
self.assertIn(
self.home_page, self.root_page.get_children(), "La page 'Accueil' n'est pas un enfant direct de la racine."
)

response = self.client.get(self.home_page.get_url())
self.assertEqual(
response.status_code,
200,
f"La page d'accueil n'est pas accessible (status: {response.status_code}).",
)

def test_create_content_pages_with_json(self):
client = Client()
"""Test the content pages are correctly created from the JSON file"""
with open("lemarche/fixtures/cms_content_pages.json") as f:
pages_data = json.load(f)

call_command("create_content_pages")

# Check that the pages were created
for page_data in pages_data:
slug = page_data["slug"]
self.assertTrue(
ContentPage.objects.filter(slug=slug).exists(), msg=f"La page avec le slug '{slug}' n'a pas été créée."

try:
page = ContentPage.objects.get(slug=slug)
except ContentPage.DoesNotExist:
self.fail(f"La page avec le slug '{slug}' n'a pas été trouvée.")

self.assertEqual(
page.get_parent(), self.home_page, f"La page '{slug}' n'est pas reliée à la page 'Accueil'."
)

response = client.get(f"/{slug}/")
client = Client()
response = client.get(page.get_url())
self.assertEqual(
response.status_code,
200,
msg=f"La page avec le slug '{slug}' n'est pas accessible (status: {response.status_code}).",
f"La page avec le slug '{slug}' n'est pas accessible (status: {response.status_code}).",
)

def test_prevent_duplicate_page_creation(self):
"""Ensure the command does not create duplicate pages"""
home_page = Site.objects.get(is_default_site=True).root_page
home_page.add_child(instance=ContentPage(slug="mentions-legales", title="Mentions légales"))
"""Test the command does not create duplicate pages"""
self.home_page.add_child(instance=ContentPage(slug="mentions-legales", title="Mentions légales"))

call_command("create_content_pages")

Expand Down
Loading