67b7d4ce49
svn path=/plone.app.discussion/trunk/; revision=27261
85 lines
3.7 KiB
Python
85 lines
3.7 KiB
Python
import unittest
|
|
|
|
from datetime import datetime, timedelta
|
|
from DateTime import DateTime
|
|
|
|
from zope.component import createObject
|
|
|
|
from Products.PloneTestCase.ptc import PloneTestCase
|
|
from plone.app.discussion.tests.layer import DiscussionLayer
|
|
|
|
from plone.app.discussion.interfaces import IConversation
|
|
|
|
from plone.indexer import indexer
|
|
from plone.indexer.delegate import DelegatingIndexerFactory
|
|
|
|
from zope.component import provideAdapter
|
|
|
|
from plone.app.discussion import catalog
|
|
|
|
class IndexersTest(PloneTestCase):
|
|
|
|
layer = DiscussionLayer
|
|
|
|
def afterSetUp(self):
|
|
# First we need to create some content.
|
|
self.loginAsPortalOwner()
|
|
typetool = self.portal.portal_types
|
|
typetool.constructContent('Document', self.portal, 'doc1')
|
|
|
|
# Create a conversation. In this case we doesn't assign it to an
|
|
# object, as we just want to check the Conversation object API.
|
|
conversation = IConversation(self.portal.doc1)
|
|
|
|
# Pretend that we have traversed to the comment by aq wrapping it.
|
|
conversation = conversation.__of__(self.portal.doc1)
|
|
|
|
# Add a comment. Note: in real life, we always create comments via the factory
|
|
# to allow different factories to be swapped in
|
|
|
|
comment = createObject('plone.Comment')
|
|
comment.title = 'Comment 1'
|
|
comment.text = 'Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.'
|
|
comment.creator = "Jim"
|
|
comment.creation_date = datetime(2006, 9, 17, 14, 18, 12)
|
|
comment.modification_date = datetime(2008, 3, 12, 7, 32, 52)
|
|
|
|
new_id = conversation.addComment(comment)
|
|
|
|
self.comment_id = new_id
|
|
self.comment = comment
|
|
|
|
def test_title(self):
|
|
self.assertEquals(catalog.title(self.comment)(), 'Comment 1')
|
|
self.assert_(isinstance(catalog.title, DelegatingIndexerFactory))
|
|
|
|
def test_description(self):
|
|
# Create a 50 word comment and make sure the description returns
|
|
# only the first 25 words
|
|
self.assertEquals(catalog.description(self.comment)(), 'Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At...')
|
|
self.assert_(isinstance(catalog.description, DelegatingIndexerFactory))
|
|
|
|
def test_dates(self):
|
|
# Test if created, modified, effective etc. are set correctly
|
|
self.assertEquals(catalog.created(self.comment)(), DateTime(2006, 9, 17, 14, 18, 12))
|
|
self.assertEquals(catalog.modified(self.comment)(), DateTime(2008, 3, 12, 7, 32, 52))
|
|
|
|
def test_searchable_text(self):
|
|
# Test if searchable text is a concatenation of title and comment text
|
|
self.assertEquals(catalog.searchable_text(self.comment)(), ('Comment 1', 'Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.'))
|
|
self.assert_(isinstance(catalog.searchable_text, DelegatingIndexerFactory))
|
|
|
|
def test_creator(self):
|
|
self.assertEquals(catalog.creator(self.comment)(), ('Jim'))
|
|
|
|
def test_in_reply_to(self):
|
|
pass
|
|
|
|
def test_review_state(self):
|
|
pass
|
|
|
|
def test_object_provides(self):
|
|
pass
|
|
|
|
def test_suite():
|
|
return unittest.defaultTestLoader.loadTestsFromName(__name__) |