[1493] | 1 | import urllib, re |
---|
| 2 | from cStringIO import StringIO |
---|
| 3 | from base import getToolByName, FunctionalTestCase, newSecurityManager |
---|
| 4 | from config import * |
---|
| 5 | |
---|
| 6 | class TestResponse(FunctionalTestCase): |
---|
| 7 | |
---|
| 8 | def afterSetUp(self): |
---|
| 9 | self.qi = self.portal.portal_quickinstaller |
---|
| 10 | self.qi.installProduct(PROJECT_NAME) |
---|
| 11 | self.sp = self.portal.portal_properties.seo_properties |
---|
| 12 | self.pu = self.portal.plone_utils |
---|
| 13 | self.basic_auth = 'portal_manager:secret' |
---|
| 14 | |
---|
| 15 | uf = self.app.acl_users |
---|
| 16 | uf.userFolderAddUser('portal_manager', 'secret', ['Manager'], []) |
---|
| 17 | user = uf.getUserById('portal_manager') |
---|
| 18 | if not hasattr(user, 'aq_base'): |
---|
| 19 | user = user.__of__(uf) |
---|
| 20 | newSecurityManager(None, user) |
---|
| 21 | |
---|
| 22 | '''Preparation for functional testing''' |
---|
| 23 | my_doc = self.portal.invokeFactory('Document', id='my_doc') |
---|
| 24 | my_doc = self.portal['my_doc'] |
---|
| 25 | self.canonurl = 'http://nohost/plone/test.html' |
---|
| 26 | self.sp.manage_changeProperties(**GLOBAL_CUSTOM_METATAGS) |
---|
| 27 | abs_path = "/%s" % my_doc.absolute_url(1) |
---|
| 28 | self.form_data = {'seo_description': 'it is description', 'seo_keywords_override:int': 1, 'seo_custommetatags_override:int': 1, |
---|
| 29 | 'seo_robots_override:int': 1, 'seo_robots': 'ALL', 'seo_description_override:int': 1, 'seo_canonical_override:int': 1, |
---|
| 30 | 'seo_keywords:list': 'keyword1', 'seo_html_comment': 'no comments', |
---|
| 31 | 'seo_title_override:int': 1, 'seo_title': 'hello world', 'seo_html_comment_override:int': 1, |
---|
| 32 | 'seo_distribution_override:int': 1, 'seo_distribution': 'Global', 'seo_canonical': self.canonurl, 'form.submitted:int': 1} |
---|
| 33 | st = '' |
---|
| 34 | for d in CUSTOM_METATAGS: |
---|
| 35 | st += '&seo_custommetatags.meta_name:records=%s&seo_custommetatags.meta_content:records=%s' % (d['meta_name'],d['meta_content']) |
---|
| 36 | self.publish(path=abs_path+'/@@seo-context-properties', basic=self.basic_auth, request_method='POST', stdin=StringIO(urllib.urlencode(self.form_data)+st)) |
---|
| 37 | #self.publish(abs_path+'/@@seo-context-properties?%s' % urllib.urlencode(self.form_data), self.basic_auth) |
---|
| 38 | |
---|
| 39 | wf_tool = self.portal.portal_workflow |
---|
| 40 | wf_tool.doActionFor(my_doc, 'publish') |
---|
| 41 | |
---|
| 42 | self.abs_path = abs_path |
---|
| 43 | self.my_doc = my_doc |
---|
| 44 | self.html = self.publish(abs_path, self.basic_auth).getBody() |
---|
| 45 | |
---|
| 46 | # now setup page with title equal to plone site's title |
---|
| 47 | my_doc2 = self.portal.invokeFactory('Document', id='my_doc2') |
---|
| 48 | my_doc2 = self.portal['my_doc2'] |
---|
| 49 | my_doc2.update(title=self.portal.Title()) |
---|
| 50 | wf_tool.doActionFor(my_doc2, 'publish') |
---|
| 51 | abs_path2 = "/%s" % my_doc2.absolute_url(1) |
---|
| 52 | self.html2 = self.publish(abs_path2, self.basic_auth).getBody() |
---|
| 53 | |
---|
| 54 | def testTitle(self): |
---|
| 55 | m = re.match('.*<title>\\s*hello world\\s*</title>', self.html, re.S|re.M) |
---|
| 56 | self.assert_(m, 'Title not set in') |
---|
| 57 | |
---|
| 58 | def testTitleDuplication(self): |
---|
| 59 | """If we are not overriding page title and current page title equals title of the plone site |
---|
| 60 | then there should be no concatenation of both titles. Only one should be displayed. |
---|
| 61 | """ |
---|
| 62 | m = re.match('.*<title>\\s*%s\\s*</title>' % self.portal.Title(), self.html2, re.S|re.M) |
---|
| 63 | self.assert_(m, 'Title is not set correctly, perhaps it is duplicated with plone site title') |
---|
| 64 | |
---|
| 65 | def testDescription(self): |
---|
| 66 | m = re.match('.*<meta name="description" content="it is description" />', self.html, re.S|re.M) |
---|
| 67 | if not m: |
---|
| 68 | m = re.match('.*<meta content="it is description" name="description" />', self.html, re.S|re.M) |
---|
| 69 | self.assert_(m, 'Description not set in') |
---|
| 70 | |
---|
| 71 | def testKeywords(self): |
---|
| 72 | m = re.match('.*<meta name="keywords" content="keyword1" />', self.html, re.S|re.M) |
---|
| 73 | if not m: |
---|
| 74 | m = re.match('.*<meta content="keyword1" name="keywords" />', self.html, re.S|re.M) |
---|
| 75 | self.assert_(m, 'Keywords not set in') |
---|
| 76 | |
---|
| 77 | def testRobots(self): |
---|
| 78 | m = re.match('.*<meta name="robots" content="ALL" />', self.html, re.S|re.M) |
---|
| 79 | if not m: |
---|
| 80 | m = re.match('.*<meta content="ALL" name="robots" />', self.html, re.S|re.M) |
---|
| 81 | self.assert_(m, 'Robots not set in') |
---|
| 82 | |
---|
| 83 | def testDistribution(self): |
---|
| 84 | m = re.match('.*<meta name="distribution" content="Global" />', self.html, re.S|re.M) |
---|
| 85 | if not m: |
---|
| 86 | m = re.match('.*<meta content="Global" name="distribution" />', self.html, re.S|re.M) |
---|
| 87 | self.assert_(m, 'Distribution not set in') |
---|
| 88 | |
---|
| 89 | def testHTMLComments(self): |
---|
| 90 | m = re.match('.*<!--\\s*no comments\\s*-->', self.html, re.S|re.M) |
---|
| 91 | self.assert_(m, 'Comments not set in') |
---|
| 92 | |
---|
| 93 | def testTagsOrder(self): |
---|
| 94 | mtop = self.sp.getProperty('metatags_order') |
---|
| 95 | metatags_order = [t.split(' ')[0] for t in mtop if len(t.split(' '))==2 and t.split(' ')[0] in VIEW_METATAGS] |
---|
| 96 | m = re.search('.*'.join(['<meta.*name="%s".*/>' %t for t in metatags_order]), self.html, re.S|re.M) |
---|
| 97 | self.assert_(m, "Meta tags order not supported.") |
---|
| 98 | |
---|
| 99 | mtop = list(mtop) |
---|
| 100 | mtop.reverse() |
---|
| 101 | metatags_order = [t.split(' ')[0] for t in mtop if len(t.split(' '))==2 and t.split(' ')[0] in VIEW_METATAGS] |
---|
| 102 | m = re.search('.*'.join(['<meta.*name="%s".*/>' %t for t in metatags_order]), self.html, re.S|re.M) |
---|
| 103 | self.assertFalse(m, "Meta tags order not supported.") |
---|
| 104 | |
---|
| 105 | self.sp.manage_changeProperties(**{'metatags_order':tuple(mtop)}) |
---|
| 106 | html = self.publish(self.abs_path, self.basic_auth).getBody() |
---|
| 107 | m = re.search('.*'.join(['<meta.*name="%s".*/>' %t for t in metatags_order]), self.html, re.S|re.M) |
---|
| 108 | self.assertFalse(m, "Meta tags order not supported.") |
---|
| 109 | |
---|
| 110 | m = re.search('.*'.join(['<meta.*name="%s".*/>' %t for t in metatags_order]), html, re.S|re.M) |
---|
| 111 | self.assert_(m, "Meta tags order not supported.") |
---|
| 112 | |
---|
| 113 | |
---|
| 114 | def testCustomMetaTags(self): |
---|
| 115 | for tag in CUSTOM_METATAGS: |
---|
| 116 | m = re.search('<meta name="%(meta_name)s" content="%(meta_content)s" />' % tag, self.html, re.S|re.M) |
---|
| 117 | if not m: |
---|
| 118 | m = re.search('<meta content="%(meta_content)s" name="%(meta_name)s" />' % tag, self.html, re.S|re.M) |
---|
| 119 | if tag['meta_content']: |
---|
| 120 | self.assert_(m, "Custom meta tag %s not applied." % tag['meta_name']) |
---|
| 121 | else: |
---|
| 122 | self.assert_(not m, "Meta tag %s has no content, but is present in the page." % tag['meta_name']) |
---|
| 123 | m = re.search('<meta name="metatag4" content="global_metatag4value" />' , self.html, re.S|re.M) |
---|
| 124 | if not m: |
---|
| 125 | m = re.search('<meta content="global_metatag4value" name="metatag4" />' , self.html, re.S|re.M) |
---|
| 126 | self.assert_(m, "Global custom meta tag %s not applied." % 'metatag4') |
---|
| 127 | |
---|
| 128 | def testDeleteCustomMetaTags(self): |
---|
| 129 | self.sp.manage_changeProperties(**{'default_custom_metatags':'metatag1|global_metatag1value'}) |
---|
| 130 | my_doc = self.my_doc |
---|
| 131 | self.form_data = {'seo_custommetatags': CUSTOM_METATAGS, 'seo_custommetatags_override:int': 0, 'form.submitted:int': 1} |
---|
| 132 | self.publish(path=self.abs_path+'/@@seo-context-properties', basic=self.basic_auth, request_method='POST', stdin=StringIO(urllib.urlencode(self.form_data))) |
---|
| 133 | html = self.publish(self.abs_path, self.basic_auth).getBody() |
---|
| 134 | m = re.search('<meta name="metatag4" content="global_metatag4value" />' , html, re.S|re.M) |
---|
| 135 | if not m: |
---|
| 136 | m = re.search('<meta content="global_metatag4value" name="metatag4" />' , html, re.S|re.M) |
---|
| 137 | self.assert_(not m, "Global custom meta tag %s is prosent in the page." % 'metatag4') |
---|
| 138 | m = re.search('<meta name="metatag1" content="global_metatag1value" />' , html, re.S|re.M) |
---|
| 139 | if not m: |
---|
| 140 | m = re.search('<meta content="global_metatag1value" name="metatag1" />' , html, re.S|re.M) |
---|
| 141 | self.assert_(m, "Global custom meta tag %s not applied." % 'metatag1') |
---|
| 142 | |
---|
| 143 | def testCanonical(self): |
---|
| 144 | m = re.match('.*<link rel="canonical" href="%s" />' % self.canonurl, self.html, re.S|re.M) |
---|
| 145 | self.assert_(m, self.canonurl) |
---|
| 146 | |
---|
| 147 | def testDefaultCanonical(self): |
---|
| 148 | """Default canonical url mast add document absolute_url |
---|
| 149 | """ |
---|
| 150 | # Delete custom canonical url |
---|
| 151 | my_doc = self.portal['my_doc'] |
---|
| 152 | my_doc._delProperty(id='qSEO_canonical') |
---|
| 153 | # Get document without customized canonical url |
---|
| 154 | abs_path = "/%s" % my_doc.absolute_url(1) |
---|
| 155 | self.html = self.publish(abs_path, self.basic_auth).getBody() |
---|
| 156 | |
---|
| 157 | my_url = my_doc.absolute_url() |
---|
| 158 | m = re.match('.*<link rel="canonical" href="%s" />' % my_url, self.html, re.S|re.M) |
---|
| 159 | self.assert_(m, my_url) |
---|
| 160 | |
---|
| 161 | def test_suite(): |
---|
| 162 | from unittest import TestSuite, makeSuite |
---|
| 163 | suite = TestSuite() |
---|
| 164 | suite.addTest(makeSuite(TestResponse)) |
---|
| 165 | return suite |
---|