Add plugin tests
This commit is contained in:
parent
1acc78cb31
commit
be9c02a12b
2 changed files with 81 additions and 0 deletions
|
|
@ -7,6 +7,8 @@ try:
|
||||||
|
|
||||||
settings.configure(
|
settings.configure(
|
||||||
DEBUG=True,
|
DEBUG=True,
|
||||||
|
THUMBNAIL_DEBUG=True,
|
||||||
|
TEMPLATE_DEBUG=True,
|
||||||
USE_TZ=True,
|
USE_TZ=True,
|
||||||
DATABASES={
|
DATABASES={
|
||||||
'default': {
|
'default': {
|
||||||
|
|
@ -53,6 +55,7 @@ try:
|
||||||
'filer',
|
'filer',
|
||||||
'parler',
|
'parler',
|
||||||
'taggit',
|
'taggit',
|
||||||
|
'easy_thumbnails',
|
||||||
'djangocms_text_ckeditor',
|
'djangocms_text_ckeditor',
|
||||||
'cmsplugin_filer_image',
|
'cmsplugin_filer_image',
|
||||||
'django_select2',
|
'django_select2',
|
||||||
|
|
@ -98,6 +101,12 @@ try:
|
||||||
META_USE_OG_PROPERTIES=True,
|
META_USE_OG_PROPERTIES=True,
|
||||||
META_USE_TWITTER_PROPERTIES=True,
|
META_USE_TWITTER_PROPERTIES=True,
|
||||||
META_USE_GOOGLEPLUS_PROPERTIES=True,
|
META_USE_GOOGLEPLUS_PROPERTIES=True,
|
||||||
|
THUMBNAIL_PROCESSORS=(
|
||||||
|
'easy_thumbnails.processors.colorspace',
|
||||||
|
'easy_thumbnails.processors.autocrop',
|
||||||
|
'filer.thumbnail_processors.scale_and_crop_with_subject_location',
|
||||||
|
'easy_thumbnails.processors.filters',
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
from django_nose import NoseTestSuiteRunner
|
from django_nose import NoseTestSuiteRunner
|
||||||
|
|
|
||||||
72
tests/test_plugins.py
Normal file
72
tests/test_plugins.py
Normal file
|
|
@ -0,0 +1,72 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
import re
|
||||||
|
from cms.api import add_plugin
|
||||||
|
from django.core.urlresolvers import reverse
|
||||||
|
from django.template import RequestContext
|
||||||
|
from taggit.models import Tag
|
||||||
|
|
||||||
|
from . import BaseTest
|
||||||
|
|
||||||
|
|
||||||
|
class PluginTest(BaseTest):
|
||||||
|
|
||||||
|
def test_plugin_latest(self):
|
||||||
|
page1, page2 = self.get_pages()
|
||||||
|
post_1 = self._get_post(self.data['en'][0])
|
||||||
|
post_2 = self._get_post(self.data['en'][1])
|
||||||
|
post_1.tags.add('tag 1')
|
||||||
|
post_1.publish = True
|
||||||
|
post_1.save()
|
||||||
|
ph = page1.placeholders.get(slot='placeholder')
|
||||||
|
plugin = add_plugin(ph, 'BlogLatestEntriesPlugin', language='en')
|
||||||
|
tag = Tag.objects.get(slug='tag-1')
|
||||||
|
plugin.tags.add(tag)
|
||||||
|
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-1') > -1)
|
||||||
|
self.assertTrue(rendered.find(reverse('djangocms_blog:posts-tagged', kwargs={'tag': tag.slug})) > -1)
|
||||||
|
self.assertTrue(rendered.find('<p>first line</p>') > -1)
|
||||||
|
self.assertTrue(rendered.find('<article id="post-first-post"') > -1)
|
||||||
|
self.assertTrue(rendered.find(post_1.get_absolute_url()) > -1)
|
||||||
|
|
||||||
|
def test_plugin_authors(self):
|
||||||
|
page1, page2 = self.get_pages()
|
||||||
|
post_1 = self._get_post(self.data['en'][0])
|
||||||
|
post_2 = self._get_post(self.data['en'][1])
|
||||||
|
post_1.publish = True
|
||||||
|
post_1.save()
|
||||||
|
post_2.publish = True
|
||||||
|
post_2.save()
|
||||||
|
ph = page1.placeholders.get(slot='placeholder')
|
||||||
|
plugin = add_plugin(ph, 'BlogAuthorPostsPlugin', language='en')
|
||||||
|
plugin.authors.add(self.user)
|
||||||
|
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(reverse('djangocms_blog:posts-author', kwargs={'username': self.user.username})) > -1)
|
||||||
|
self.assertTrue(rendered.find('2 articles') > -1)
|
||||||
|
|
||||||
|
def test_plugin_tags(self):
|
||||||
|
page1, page2 = self.get_pages()
|
||||||
|
post_1 = self._get_post(self.data['en'][0])
|
||||||
|
post_2 = self._get_post(self.data['en'][1])
|
||||||
|
post_1.tags.add('tag 1', 'tag 2', 'test tag')
|
||||||
|
post_1.publish = True
|
||||||
|
post_1.save()
|
||||||
|
post_2.tags.add('test tag', 'another tag')
|
||||||
|
post_2.publish = True
|
||||||
|
post_2.save()
|
||||||
|
ph = page1.placeholders.get(slot='placeholder')
|
||||||
|
plugin = add_plugin(ph, 'BlogTagsPlugin', language='en')
|
||||||
|
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).replace("\n", "")
|
||||||
|
for tag in Tag.objects.all():
|
||||||
|
self.assertTrue(rendered.find(reverse('djangocms_blog:posts-tagged', kwargs={'tag': tag.slug})) > -1)
|
||||||
|
if tag.slug == 'test-tag':
|
||||||
|
rf = '\s+%s\s+<span>\(\s+%s articles' % (tag.name, 2)
|
||||||
|
else:
|
||||||
|
rf = '\s+%s\s+<span>\(\s+%s article' % (tag.name, 1)
|
||||||
|
rx = re.compile(rf)
|
||||||
|
self.assertEqual(len(rx.findall(rendered)), 1)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue