- Replace nav inline newsletter form with Subscribe CTA link per wireframe - Remove newsletter form from footer; add Connect section with social/RSS links - Fix honeypot inputs using hidden attribute (inline style blocked by CSP) - Add available_tags to HomePage.get_context for Explore Topics section - Add data-comment-form attribute to main comment form for reliable locating - Seed approved comment in E2E content for reply flow testing - Expand test_comments.py: moderation message, not-immediately-visible, missing fields, reply form visible, reply submission - Make COMMENT_RATE_LIMIT_PER_MINUTE configurable; set 100 in dev to prevent E2E test exhaustion; update rate limit unit test with override_settings - Update newsletter/home E2E tests to reflect nav form removal - Update unit test to assert no nav/footer newsletter forms Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
29 lines
825 B
Python
29 lines
825 B
Python
import pytest
|
|
from django.core.cache import cache
|
|
from django.test import override_settings
|
|
|
|
from apps.comments.forms import CommentForm
|
|
|
|
|
|
@pytest.mark.django_db
|
|
def test_comment_form_rejects_blank_body():
|
|
form = CommentForm(data={"author_name": "A", "author_email": "a@a.com", "body": " ", "article_id": 1})
|
|
assert not form.is_valid()
|
|
|
|
|
|
@pytest.mark.django_db
|
|
@override_settings(COMMENT_RATE_LIMIT_PER_MINUTE=3)
|
|
def test_comment_rate_limit(client, article_page):
|
|
cache.clear()
|
|
payload = {
|
|
"article_id": article_page.id,
|
|
"author_name": "T",
|
|
"author_email": "t@example.com",
|
|
"body": "Hi",
|
|
"honeypot": "",
|
|
}
|
|
for _ in range(3):
|
|
client.post("/comments/post/", payload)
|
|
resp = client.post("/comments/post/", payload)
|
|
assert resp.status_code == 429
|