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

Last change on this file since 9176 was 9157, checked in by Henrik Bettermann, 12 years ago

Not current session but the previous session selected must coincide with entry session.

  • Property svn:keywords set to Id
File size: 15.7 KB
Line 
1## $Id: test_browser.py 9157 2012-09-05 06:01:47Z 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        self.student.nationality = u'NG'
224
225        configuration = createObject('waeup.SessionConfiguration')
226        configuration.academic_session = 2005
227        self.app['configuration'].addSessionConfiguration(configuration)
228
229        error, payment = utils.setPaymentDetails('schoolfee',
230            self.student, None, None)
231        self.assertEqual(payment, None)
232        self.assertTrue(u'Amount could not be determined.' in error)
233
234        # Previous session payment; fresh and returning
235        # are distinguished by their entry_level
236        error, payment = utils.setPaymentDetails('schoolfee',
237            self.student, 2004, 300)
238        self.assertEqual(payment.amount_auth, 40000.0)
239        self.assertEqual(payment.p_session, 2004)
240        self.assertEqual(payment.p_level, 300)
241        self.assertFalse(payment.p_current)
242        error, payment = utils.setPaymentDetails('schoolfee',
243            self.student, 2005, 300)
244        self.assertEqual(payment.amount_auth, 20000.0)
245        self.assertEqual(payment.p_session, 2005)
246        self.assertEqual(payment.p_level, 300)
247        self.assertFalse(payment.p_current)
248
249        # Current payment; fresh and returning
250        # are distinguished by their state
251        IWorkflowState(self.student).setState('cleared')
252        error, payment = utils.setPaymentDetails('schoolfee',
253            self.student, None, None)
254        self.assertEqual(payment.p_level, 100)
255        self.assertEqual(payment.p_session, 2004)
256        self.assertEqual(payment.amount_auth, 40000.0)
257        self.assertEqual(payment.p_item, u'CERT1')
258        self.assertEqual(error, None)
259        self.assertTrue(payment.p_current)
260
261        # Add penalty fee ...
262        # ... for cleared
263        self.app['configuration']['2004'].penalty_ug = 99.0
264        # ... for returning
265        self.app['configuration']['2005'].penalty_ug = 88.0
266        error, payment = utils.setPaymentDetails('schoolfee',
267            self.student, None, None)
268        self.assertEqual(payment.amount_auth, 40099.0)
269
270        IWorkflowState(self.student).setState('returning')
271        error, payment = utils.setPaymentDetails('schoolfee',
272            self.student, None, None)
273        self.assertEqual(payment.p_level, 200)
274        self.assertEqual(payment.p_session, 2005)
275        self.assertEqual(payment.amount_auth, 20088.0)
276        self.assertEqual(payment.p_item, u'CERT1')
277        self.assertEqual(error, None)
278
279        self.student.is_staff = True
280        error, payment = utils.setPaymentDetails('schoolfee',
281            self.student, None, None)
282        self.assertEqual(payment.p_level, 200)
283        self.assertEqual(payment.p_session, 2005)
284        self.assertEqual(payment.amount_auth, 10088.0)
285        self.assertEqual(payment.p_item, u'CERT1')
286        self.assertEqual(error, None)
287
288        IWorkflowState(self.student).setState('cleared')
289        self.student.is_staff = False
290        self.student.nationality = u'DE'
291        self.certificate.school_fee_3 = 60000.0
292        error, payment = utils.setPaymentDetails(
293            'schoolfee', self.student, None, None)
294        self.assertEqual(payment.p_level, 100)
295        self.assertEqual(payment.p_session, 2004)
296        self.assertEqual(payment.amount_auth, 60099.0)
297        self.assertEqual(payment.p_item, u'CERT1')
298        self.assertEqual(error, None)
299
300        IWorkflowState(self.student).setState('returning')
301        self.student.is_staff = False
302        self.student.nationality = u'DE'
303        self.certificate.school_fee_4 = 20000.0
304        error, payment = utils.setPaymentDetails(
305            'schoolfee', self.student, None, None)
306        self.assertEqual(payment.p_level, 200)
307        self.assertEqual(payment.p_session, 2005)
308        self.assertEqual(payment.amount_auth, 20088.0)
309        self.assertEqual(payment.p_item, u'CERT1')
310        self.assertEqual(error, None)
311
312        error, payment = utils.setPaymentDetails('clearance',
313            self.student, None, None)
314        self.assertEqual(payment.p_level, 100)
315        self.assertEqual(payment.p_session, 2004)
316        self.assertEqual(payment.amount_auth, 34250.0)
317        self.assertEqual(payment.p_item, u'CERT1')
318        self.assertEqual(error, None)
319
320        error, payment = utils.setPaymentDetails('gown',
321            self.student, None, None)
322        self.assertEqual(payment.p_level, 100)
323        self.assertEqual(payment.p_session, 2004)
324        self.assertEqual(payment.amount_auth, 150.0)
325        self.assertEqual(payment.p_item, u'')
326        self.assertEqual(error, None)
327
328        error, payment = utils.setPaymentDetails('hostel_maintenance',
329            self.student, None, None)
330        self.assertEqual(payment.p_level, 100)
331        self.assertEqual(payment.p_session, 2004)
332        self.assertEqual(payment.amount_auth, 180.0)
333        self.assertEqual(payment.p_item, u'')
334        self.assertEqual(error, None)
335
336        error, payment = utils.setPaymentDetails('bed_allocation',
337            self.student, None, None)
338        self.assertEqual(payment.p_level, 100)
339        self.assertEqual(payment.p_session, 2004)
340        self.assertEqual(payment.amount_auth, 150.0)
341        self.assertEqual(payment.p_item, u'')
342        self.assertEqual(error, None)
343
344        error, payment = utils.setPaymentDetails('transfer',
345            self.student, None, None)
346        self.assertEqual(payment.p_level, 100)
347        self.assertEqual(payment.p_session, 2004)
348        self.assertEqual(payment.amount_auth, 90.0)
349        self.assertEqual(payment.p_item, u'')
350        self.assertEqual(error, None)
351        return
Note: See TracBrowser for help on using the repository browser.