[9011] | 1 | ## $Id: test_browser.py 16037 2020-03-13 10:55:28Z henrik $ |
---|
| 2 | ## |
---|
| 3 | ## Copyright (C) 2011 Uli Fouquet & Henrik Bettermann |
---|
| 4 | ## This program is free software; you can redistribute it and/or modify |
---|
| 5 | ## it under the terms of the GNU General Public License as published by |
---|
| 6 | ## the Free Software Foundation; either version 2 of the License, or |
---|
| 7 | ## (at your option) any later version. |
---|
| 8 | ## |
---|
| 9 | ## This program is distributed in the hope that it will be useful, |
---|
| 10 | ## but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
| 11 | ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
| 12 | ## GNU General Public License for more details. |
---|
| 13 | ## |
---|
| 14 | ## You should have received a copy of the GNU General Public License |
---|
| 15 | ## along with this program; if not, write to the Free Software |
---|
| 16 | ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
---|
| 17 | ## |
---|
| 18 | """ |
---|
| 19 | Test the student-related UI components. |
---|
| 20 | """ |
---|
| 21 | import shutil |
---|
| 22 | import tempfile |
---|
| 23 | import pytz |
---|
| 24 | from datetime import datetime, timedelta |
---|
| 25 | from StringIO import StringIO |
---|
| 26 | import os |
---|
| 27 | import grok |
---|
| 28 | from zope.event import notify |
---|
| 29 | from zope.component import createObject, queryUtility |
---|
| 30 | from zope.component.hooks import setSite, clearSite |
---|
| 31 | from zope.catalog.interfaces import ICatalog |
---|
| 32 | from zope.security.interfaces import Unauthorized |
---|
| 33 | from waeup.kofa.testing import FunctionalLayer, FunctionalTestCase |
---|
| 34 | |
---|
[9012] | 35 | from waeup.kofa.utils.browser import replaceStudentMessages |
---|
[9011] | 36 | from waeup.kofa.students.tests.test_browser import StudentsFullSetup |
---|
[9122] | 37 | from waeup.kofa.applicants.tests.test_browser import ApplicantsFullSetup |
---|
[9011] | 38 | |
---|
[9122] | 39 | class StudentUtilsUITests(StudentsFullSetup): |
---|
[9011] | 40 | |
---|
| 41 | layer = FunctionalLayer |
---|
| 42 | |
---|
[9012] | 43 | def test_replace_student_messages(self): |
---|
[9022] | 44 | self.assertTrue('Record created by system' in |
---|
[9012] | 45 | self.student.history.messages[0]) |
---|
| 46 | replaceStudentMessages('system', 'me') |
---|
[9022] | 47 | self.assertTrue('Record created by me' in |
---|
[9012] | 48 | self.student.history.messages[0]) |
---|
| 49 | |
---|
| 50 | def test_modify_all_student_history(self): |
---|
[9022] | 51 | self.assertTrue('Record created by system' in |
---|
[9012] | 52 | self.student.history.messages[0]) |
---|
| 53 | self.browser.addHeader('Authorization', 'Basic mgr:mgrpw') |
---|
| 54 | self.browser.open('http://localhost/app/modify_student_history') |
---|
| 55 | self.assertTrue( |
---|
| 56 | 'Syntax: /modify_student_history?old=[old string]&new=[new string]' |
---|
| 57 | in self.browser.contents) |
---|
| 58 | self.browser.open( |
---|
| 59 | 'http://localhost/app/modify_student_history?old=by system&new=by me') |
---|
| 60 | self.assertTrue('Finished' in self.browser.contents) |
---|
[9022] | 61 | self.assertTrue('Record created by me' in |
---|
[9012] | 62 | self.student.history.messages[0]) |
---|
| 63 | |
---|
[9127] | 64 | def test_remove_student_history_message(self): |
---|
| 65 | self.assertTrue('Record created by system' in |
---|
| 66 | self.student.history.messages[0]) |
---|
| 67 | self.assertEqual(len(self.student.history.messages),1) |
---|
| 68 | self.browser.addHeader('Authorization', 'Basic mgr:mgrpw') |
---|
| 69 | self.browser.open('http://localhost/app/remove_student_history_message') |
---|
| 70 | self.assertTrue( |
---|
| 71 | 'Syntax: /remove_student_history_message?student_id=[id]&number=[line number, starting with 0]' |
---|
| 72 | in self.browser.contents) |
---|
| 73 | self.browser.open( |
---|
| 74 | 'http://localhost/app/remove_student_history_message?student_id=%s&number=0' % self.student.student_id) |
---|
| 75 | self.assertTrue('Finished' in self.browser.contents) |
---|
| 76 | self.assertEqual(len(self.student.history.messages),0) |
---|
| 77 | logfile = os.path.join( |
---|
| 78 | self.app['datacenter'].storage, 'logs', 'main.log') |
---|
| 79 | logcontent = open(logfile).read() |
---|
| 80 | self.assertMatches( |
---|
| 81 | "...zope.mgr - line '<YYYY-MM-DD hh:mm:ss> UTC - " |
---|
| 82 | "Record created by system' removed in K1000000 history", |
---|
| 83 | logcontent) |
---|
| 84 | |
---|
[9011] | 85 | def test_reindex(self): |
---|
| 86 | self.browser.addHeader('Authorization', 'Basic mgr:mgrpw') |
---|
| 87 | self.browser.open('http://localhost/app/reindex') |
---|
| 88 | self.assertTrue('No catalog name provided' in self.browser.contents) |
---|
| 89 | self.browser.open('http://localhost/app/reindex?ctlg=xyz') |
---|
| 90 | self.assertTrue('xyz_catalog does not exist' in self.browser.contents) |
---|
| 91 | cat = queryUtility(ICatalog, name='students_catalog') |
---|
| 92 | results = cat.searchResults(student_id=(None, None)) |
---|
| 93 | self.assertEqual(len(results),1) |
---|
[16037] | 94 | self.browser.open('http://localhost/app/reindex?ctlg=students') |
---|
| 95 | self.assertTrue('1 students re-indexed' in self.browser.contents) |
---|
[9011] | 96 | cat.clear() |
---|
| 97 | results = cat.searchResults(student_id=(None, None)) |
---|
| 98 | self.assertEqual(len(results),0) |
---|
| 99 | self.browser.open('http://localhost/app/reindex?ctlg=students') |
---|
[16037] | 100 | # No docids found, the new reindex method does only reindex existing |
---|
| 101 | # catalog entries. |
---|
| 102 | self.assertTrue('0 students re-indexed' in self.browser.contents) |
---|
[9011] | 103 | results = cat.searchResults(student_id=(None, None)) |
---|
[16037] | 104 | self.assertEqual(len(results),0) |
---|
[9122] | 105 | |
---|
| 106 | class ApplicantUtilsUITests(ApplicantsFullSetup): |
---|
| 107 | |
---|
| 108 | layer = FunctionalLayer |
---|
| 109 | |
---|
| 110 | def test_modify_all_applicant_history(self): |
---|
| 111 | self.assertTrue('Application initialized by system' in |
---|
| 112 | self.applicant.history.messages[0]) |
---|
| 113 | self.browser.addHeader('Authorization', 'Basic mgr:mgrpw') |
---|
| 114 | self.browser.open('http://localhost/app/modify_applicant_history') |
---|
| 115 | self.assertTrue( |
---|
| 116 | 'Syntax: /modify_applicant_history?old=[old string]&new=[new string]' |
---|
| 117 | in self.browser.contents) |
---|
| 118 | self.browser.open( |
---|
| 119 | 'http://localhost/app/modify_applicant_history?old=by system&new=by me') |
---|
| 120 | self.assertTrue('Finished' in self.browser.contents) |
---|
| 121 | self.assertTrue('Application initialized by me' in |
---|
[9127] | 122 | self.applicant.history.messages[0]) |
---|
| 123 | |
---|
| 124 | def test_remove_applicant_history_message(self): |
---|
| 125 | self.assertTrue('Application initialized by system' in |
---|
| 126 | self.applicant.history.messages[0]) |
---|
| 127 | self.assertEqual(len(self.applicant.history.messages),1) |
---|
| 128 | self.browser.addHeader('Authorization', 'Basic mgr:mgrpw') |
---|
| 129 | self.browser.open('http://localhost/app/remove_applicant_history_message') |
---|
| 130 | self.assertTrue( |
---|
| 131 | 'Syntax: /remove_applicant_history_message?applicant_id=[id]&number=[line number, starting with 0]' |
---|
| 132 | in self.browser.contents) |
---|
| 133 | self.browser.open( |
---|
| 134 | 'http://localhost/app/remove_applicant_history_message?applicant_id=%s&number=0' % self.applicant.applicant_id) |
---|
| 135 | self.assertTrue('Finished' in self.browser.contents) |
---|
| 136 | self.assertEqual(len(self.applicant.history.messages),0) |
---|
| 137 | logfile = os.path.join( |
---|
| 138 | self.app['datacenter'].storage, 'logs', 'main.log') |
---|
| 139 | logcontent = open(logfile).read() |
---|
| 140 | self.assertMatches( |
---|
| 141 | "...zope.mgr - line '<YYYY-MM-DD hh:mm:ss> UTC - " |
---|
| 142 | "Application initialized by system' removed in %s history" |
---|
| 143 | % self.applicant.applicant_id, logcontent) |
---|