source: main/waeup.uniben/trunk/src/waeup/uniben/students/tests/test_browser.py @ 9036

Last change on this file since 9036 was 9006, checked in by Henrik Bettermann, 13 years ago

Add special school fee regulations for staff members and foreign students.

  • Property svn:keywords set to Id
File size: 14.6 KB
Line 
1## $Id: test_browser.py 9006 2012-07-16 07:36:13Z 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##
18import os
19import shutil
20import tempfile
21from StringIO import StringIO
22from hurry.workflow.interfaces import IWorkflowState
23from zope.component.hooks import setSite, clearSite
24from zope.component import getUtility, createObject
25from zope.interface import verify
26from waeup.kofa.app import University
27from waeup.kofa.students.tests.test_browser import StudentsFullSetup
28from waeup.kofa.testing import FunctionalTestCase
29from waeup.kofa.interfaces import (
30    IExtFileStore, IFileStoreNameChooser)
31from waeup.kofa.students.interfaces import IStudentsUtils
32from waeup.uniben.testing import FunctionalLayer
33
34
35class StudentProcessorTest(FunctionalTestCase):
36    """Perform some batching tests.
37    """
38
39    layer = FunctionalLayer
40
41    def setUp(self):
42        super(StudentProcessorTest, self).setUp()
43        # Setup a sample site for each test
44        app = University()
45        self.dc_root = tempfile.mkdtemp()
46        app['datacenter'].setStoragePath(self.dc_root)
47
48        # Prepopulate the ZODB...
49        self.getRootFolder()['app'] = app
50        # we add the site immediately after creation to the
51        # ZODB. Catalogs and other local utilities are not setup
52        # before that step.
53        self.app = self.getRootFolder()['app']
54        # Set site here. Some of the following setup code might need
55        # to access grok.getSite() and should get our new app then
56        setSite(app)
57
58
59    def tearDown(self):
60        super(StudentProcessorTest, self).tearDown()
61        shutil.rmtree(self.workdir)
62        shutil.rmtree(self.dc_root)
63        clearSite()
64        return
65
66class StudentUITests(StudentsFullSetup):
67    """Tests for customized student class views and pages
68    """
69
70    layer = FunctionalLayer
71
72    def test_manage_payments(self):
73        # Add missing configuration data
74        self.app['configuration']['2004'].gown_fee = 150.0
75        self.app['configuration']['2004'].transfer_fee = 90.0
76        #self.app['configuration']['2004'].clearance_fee = 120.0
77        self.app['configuration']['2004'].booking_fee = 150.0
78        self.app['configuration']['2004'].maint_fee = 180.0
79
80        # Managers can add online payment tickets
81        self.browser.addHeader('Authorization', 'Basic mgr:mgrpw')
82        self.browser.open(self.payments_path)
83        self.browser.getControl("Add online payment ticket").click()
84        self.browser.getControl("Create ticket").click()
85        self.assertMatches('...Amount could not be determined...',
86                           self.browser.contents)
87        IWorkflowState(self.student).setState('cleared')
88        self.student.nationality = u'NG'
89        self.browser.open(self.payments_path + '/addop')
90        self.browser.getControl("Create ticket").click()
91        self.assertMatches('...ticket created...',
92                           self.browser.contents)
93        ctrl = self.browser.getControl(name='val_id')
94        value = ctrl.options[0]
95        self.browser.getLink(value).click()
96        self.assertMatches('...Amount Authorized...',
97                           self.browser.contents)
98        # Managers can open payment slip
99        self.browser.getLink("Download payment slip").click()
100        self.assertEqual(self.browser.headers['Status'], '200 Ok')
101        self.assertEqual(self.browser.headers['Content-Type'], 'application/pdf')
102        # Set ticket paid
103        ticket = self.student['payments'].items()[0][1]
104        ticket.p_state = 'paid'
105        self.browser.open(self.payments_path + '/addop')
106        self.browser.getControl("Create ticket").click()
107        self.assertMatches('...This type of payment has already been made...',
108                           self.browser.contents)
109        # Remove all payments so that we can add a school fee payment again
110        keys = [i for i in self.student['payments'].keys()]
111        for payment in keys:
112            del self.student['payments'][payment]
113        self.browser.open(self.payments_path + '/addop')
114        self.browser.getControl("Create ticket").click()
115        self.assertMatches('...ticket created...',
116                           self.browser.contents)
117        self.browser.open(self.payments_path + '/addop')
118        self.browser.getControl(name="form.p_category").value = ['gown']
119        self.browser.getControl("Create ticket").click()
120        self.assertMatches('...ticket created...',
121                           self.browser.contents)
122        self.browser.open(self.payments_path + '/addop')
123        self.browser.getControl(name="form.p_category").value = ['transfer']
124        self.browser.getControl("Create ticket").click()
125        self.assertMatches('...ticket created...',
126                           self.browser.contents)
127        self.browser.open(self.payments_path + '/addop')
128        self.browser.getControl(
129            name="form.p_category").value = ['bed_allocation']
130        self.browser.getControl("Create ticket").click()
131        self.assertMatches('...ticket created...',
132                           self.browser.contents)
133        self.browser.open(self.payments_path + '/addop')
134        self.browser.getControl(
135            name="form.p_category").value = ['hostel_maintenance']
136        self.browser.getControl("Create ticket").click()
137        self.assertMatches('...ticket created...',
138                           self.browser.contents)
139        self.browser.open(self.payments_path + '/addop')
140        self.browser.getControl(name="form.p_category").value = ['clearance']
141        self.browser.getControl("Create ticket").click()
142        self.assertMatches('...ticket created...',
143                           self.browser.contents)
144        self.browser.open(self.payments_path + '/addop')
145        self.browser.getControl(name="form.p_category").value = ['schoolfee']
146        self.browser.getControl("Create ticket").click()
147        self.assertMatches('...ticket created...',
148                           self.browser.contents)
149        # In state returning we can add a new school fee ticket since
150        # p_session and p_level is different
151        IWorkflowState(self.student).setState('returning')
152        self.browser.open(self.payments_path + '/addop')
153        self.browser.getControl(name="form.p_category").value = ['schoolfee']
154        self.browser.getControl("Create ticket").click()
155        self.assertMatches('...Session configuration object is not...',
156                           self.browser.contents)
157        # Uups, we forgot to add a session configuration for next session
158        configuration = createObject('waeup.SessionConfiguration')
159        configuration.academic_session = 2005
160        self.app['configuration'].addSessionConfiguration(configuration)
161        self.browser.open(self.payments_path + '/addop')
162        self.browser.getControl(name="form.p_category").value = ['schoolfee']
163        self.browser.getControl("Create ticket").click()
164        self.assertMatches('...ticket created...',
165                           self.browser.contents)
166        # In state admitted school fee can't be determined
167        IWorkflowState(self.student).setState('admitted')
168        self.browser.open(self.payments_path + '/addop')
169        self.browser.getControl(name="form.p_category").value = ['schoolfee']
170        self.browser.getControl("Create ticket").click()
171        self.assertMatches('...Amount could not be determined...',
172                           self.browser.contents)
173
174        # If the session configuration doesn't exist an error message will
175        # be shown. No other requirement is being checked.
176        del self.app['configuration']['2004']
177        self.browser.open(self.payments_path)
178        self.browser.getControl("Add online payment ticket").click()
179        self.browser.getControl("Create ticket").click()
180        self.assertMatches('...Session configuration object is not...',
181                           self.browser.contents)
182
183    def test_get_returning_data(self):
184        # Student is in level 100, session 2004 with verdict A
185        utils = getUtility(IStudentsUtils)
186        self.assertEqual(utils.getReturningData(self.student),(2005, 200))
187        self.student['studycourse'].current_verdict = 'C'
188        self.assertEqual(utils.getReturningData(self.student),(2005, 110))
189        self.student['studycourse'].current_verdict = 'D'
190        self.assertEqual(utils.getReturningData(self.student),(2005, 100))
191        return
192
193    def test_set_returning_data(self):
194        # Student is in level 100, session 2004 with verdict A
195        utils = getUtility(IStudentsUtils)
196
197        utils.setReturningData(self.student)
198        self.assertEqual(self.student['studycourse'].current_session, 2005)
199        self.assertEqual(self.student['studycourse'].current_level, 200)
200
201        self.student['studycourse'].current_session = 2004
202        self.student['studycourse'].current_level = 100
203        self.student['studycourse'].current_verdict = 'C'
204        utils.setReturningData(self.student)
205        self.assertEqual(self.student['studycourse'].current_session, 2005)
206        self.assertEqual(self.student['studycourse'].current_level, 110)
207
208        self.student['studycourse'].current_session = 2004
209        self.student['studycourse'].current_level = 100
210        self.student['studycourse'].current_verdict = 'D'
211        utils.setReturningData(self.student)
212        self.assertEqual(self.student['studycourse'].current_session, 2005)
213        self.assertEqual(self.student['studycourse'].current_level, 100)
214        return
215
216    def test_set_payment_details(self):
217        self.app['configuration']['2004'].gown_fee = 150.0
218        self.app['configuration']['2004'].transfer_fee = 90.0
219        self.app['configuration']['2004'].booking_fee = 150.0
220        self.app['configuration']['2004'].maint_fee = 180.0
221        utils = getUtility(IStudentsUtils)
222
223        configuration = createObject('waeup.SessionConfiguration')
224        configuration.academic_session = 2005
225        self.app['configuration'].addSessionConfiguration(configuration)
226
227        error, payment = utils.setPaymentDetails('schoolfee',self.student)
228        self.assertEqual(payment, None)
229        self.assertEqual(error, u'Amount could not be determined.')
230
231        IWorkflowState(self.student).setState('cleared')
232        self.student.nationality = u'NG'
233        error, payment = utils.setPaymentDetails('schoolfee',self.student)
234        self.assertEqual(payment.p_level, 100)
235        self.assertEqual(payment.p_session, 2004)
236        self.assertEqual(payment.amount_auth, 40000.0)
237        self.assertEqual(payment.p_item, u'CERT1')
238        self.assertEqual(error, None)
239
240        # Add penalty fee ...
241        # ... for cleared
242        self.app['configuration']['2004'].penalty_ug = 99.0
243        # ... for returning
244        self.app['configuration']['2005'].penalty_ug = 88.0
245        error, payment = utils.setPaymentDetails('schoolfee',self.student)
246        self.assertEqual(payment.amount_auth, 40099.0)
247
248        IWorkflowState(self.student).setState('returning')
249        error, payment = utils.setPaymentDetails('schoolfee',self.student)
250        self.assertEqual(payment.p_level, 200)
251        self.assertEqual(payment.p_session, 2005)
252        self.assertEqual(payment.amount_auth, 20088.0)
253        self.assertEqual(payment.p_item, u'CERT1')
254        self.assertEqual(error, None)
255
256        self.student.is_staff = True
257        error, payment = utils.setPaymentDetails('schoolfee',self.student)
258        self.assertEqual(payment.p_level, 200)
259        self.assertEqual(payment.p_session, 2005)
260        self.assertEqual(payment.amount_auth, 10088.0)
261        self.assertEqual(payment.p_item, u'CERT1')
262        self.assertEqual(error, None)
263
264        IWorkflowState(self.student).setState('cleared')
265        self.student.is_staff = False
266        self.student.nationality = u'DE'
267        self.certificate.school_fee_3 = 60000.0
268        error, payment = utils.setPaymentDetails('schoolfee',self.student)
269        self.assertEqual(payment.p_level, 100)
270        self.assertEqual(payment.p_session, 2004)
271        self.assertEqual(payment.amount_auth, 60099.0)
272        self.assertEqual(payment.p_item, u'CERT1')
273        self.assertEqual(error, None)
274
275        IWorkflowState(self.student).setState('returning')
276        self.student.is_staff = False
277        self.student.nationality = u'DE'
278        self.certificate.school_fee_4 = 20000.0
279        error, payment = utils.setPaymentDetails('schoolfee',self.student)
280        self.assertEqual(payment.p_level, 200)
281        self.assertEqual(payment.p_session, 2005)
282        self.assertEqual(payment.amount_auth, 20088.0)
283        self.assertEqual(payment.p_item, u'CERT1')
284        self.assertEqual(error, None)
285
286        error, payment = utils.setPaymentDetails('clearance',self.student)
287        self.assertEqual(payment.p_level, 100)
288        self.assertEqual(payment.p_session, 2004)
289        self.assertEqual(payment.amount_auth, 34250.0)
290        self.assertEqual(payment.p_item, u'CERT1')
291        self.assertEqual(error, None)
292
293        error, payment = utils.setPaymentDetails('gown',self.student)
294        self.assertEqual(payment.p_level, 100)
295        self.assertEqual(payment.p_session, 2004)
296        self.assertEqual(payment.amount_auth, 150.0)
297        self.assertEqual(payment.p_item, u'')
298        self.assertEqual(error, None)
299
300        error, payment = utils.setPaymentDetails('hostel_maintenance',self.student)
301        self.assertEqual(payment.p_level, 100)
302        self.assertEqual(payment.p_session, 2004)
303        self.assertEqual(payment.amount_auth, 180.0)
304        self.assertEqual(payment.p_item, u'')
305        self.assertEqual(error, None)
306
307        error, payment = utils.setPaymentDetails('bed_allocation',self.student)
308        self.assertEqual(payment.p_level, 100)
309        self.assertEqual(payment.p_session, 2004)
310        self.assertEqual(payment.amount_auth, 150.0)
311        self.assertEqual(payment.p_item, u'')
312        self.assertEqual(error, None)
313
314        error, payment = utils.setPaymentDetails('transfer',self.student)
315        self.assertEqual(payment.p_level, 100)
316        self.assertEqual(payment.p_session, 2004)
317        self.assertEqual(payment.amount_auth, 90.0)
318        self.assertEqual(payment.p_item, u'')
319        self.assertEqual(error, None)
320        return
Note: See TracBrowser for help on using the repository browser.