Skip to content

Commit

Permalink
Fix latest posts pluing. Fix #112
Browse files Browse the repository at this point in the history
  • Loading branch information
yakky committed Apr 20, 2015
1 parent 50da520 commit 74c0ae6
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 3 deletions.
7 changes: 4 additions & 3 deletions djangocms_blog/models.py
Expand Up @@ -255,9 +255,10 @@ def copy_relations(self, oldinstance):

def get_posts(self, request):
posts = self.post_queryset(request)
tags = list(self.tags.all())
if tags:
posts = posts.filter(tags__in=tags)
if self.tags.exists():
posts = posts.filter(tags__in=list(self.tags.all()))
if self.categories.exists():
posts = posts.filter(categories__in=list(self.categories.all()))
return posts[:self.latest_posts]


Expand Down
20 changes: 20 additions & 0 deletions tests/test_plugins.py
Expand Up @@ -7,6 +7,7 @@
from taggit.models import Tag

from . import BaseTest
from djangocms_blog.models import BlogCategory


class PluginTest(BaseTest):
Expand All @@ -19,6 +20,7 @@ def test_plugin_latest(self):
post1.publish = True
post1.save()
ph = page1.placeholders.get(slot='content')

plugin = add_plugin(ph, 'BlogLatestEntriesPlugin', language='en')
tag = Tag.objects.get(slug='tag-1')
plugin.tags.add(tag)
Expand All @@ -31,6 +33,24 @@ def test_plugin_latest(self):
self.assertTrue(rendered.find('<article id="post-first-post"') > -1)
self.assertTrue(rendered.find(post1.get_absolute_url()) > -1)


category_2 = BlogCategory.objects.create(name=u'category 2')
category_2.set_current_language('it', initialize=True)
category_2.name = u'categoria 2'
category_2.save()
category_2.set_current_language('en')
post2.categories.add(category_2)
plugin = add_plugin(ph, 'BlogLatestEntriesPlugin', language='en')
plugin.categories.add(category_2)
request = self.get_page_request(page1, self.user, r'/en/blog/', lang_code='en', edit=True)
context = RequestContext(request, {})
rendered = plugin.render_plugin(context, ph)
self.assertTrue(rendered.find('cms_plugin-djangocms_blog-post-abstract-2') > -1)
self.assertTrue(rendered.find(reverse('djangocms_blog:posts-category', kwargs={'category': category_2.slug})) > -1)
self.assertTrue(rendered.find('<p>second post first line</p>') > -1)
self.assertTrue(rendered.find('<article id="post-second-post"') > -1)
self.assertTrue(rendered.find(post2.get_absolute_url()) > -1)

def test_plugin_authors(self):
page1, page2 = self.get_pages()
post1 = self._get_post(self.data['en'][0])
Expand Down

0 comments on commit 74c0ae6

Please sign in to comment.