source: main/waeup.kofa/trunk/src/waeup/kofa/mandates/tests.py @ 13959

Last change on this file since 13959 was 13959, checked in by Henrik Bettermann, 8 years ago

Count mandates on configuration page and provide 'Purge' button.

  • Property svn:keywords set to Id
File size: 8.1 KB
Line 
1## $Id: tests.py 13959 2016-06-21 04:46:56Z henrik $
2##
3## Copyright (C) 2012 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"""
19Tests for mandates.
20"""
21import tempfile
22import shutil
23import os
24from zope.testbrowser.testing import Browser
25from datetime import datetime, timedelta
26from zope.interface.verify import verifyClass, verifyObject
27from zope.component import createObject
28from zope.component.hooks import setSite, clearSite
29from waeup.kofa.app import University
30from waeup.kofa.interfaces import IUserAccount
31from waeup.kofa.mandates.interfaces import (
32    IMandatesContainer, IMandate)
33from waeup.kofa.mandates.container import MandatesContainer
34from waeup.kofa.mandates.mandate import PasswordMandate
35from waeup.kofa.testing import (FunctionalLayer, FunctionalTestCase)
36
37class MandatesContainerTestCase(FunctionalTestCase):
38
39    layer = FunctionalLayer
40
41    def test_interfaces(self):
42        # Make sure the correct interfaces are implemented.
43        self.assertTrue(
44            verifyClass(
45                IMandatesContainer, MandatesContainer)
46            )
47        self.assertTrue(
48            verifyObject(
49                IMandatesContainer, MandatesContainer())
50            )
51        self.assertTrue(
52            verifyClass(
53                IMandate, PasswordMandate)
54            )
55        self.assertTrue(
56            verifyObject(
57                IMandate, PasswordMandate())
58            )
59        return
60
61    def setUp(self):
62        super(MandatesContainerTestCase, self).setUp()
63
64        # Setup a sample site for each test
65        app = University()
66        self.dc_root = tempfile.mkdtemp()
67        app['datacenter'].setStoragePath(self.dc_root)
68
69        # Prepopulate the ZODB...
70        self.getRootFolder()['app'] = app
71        # we add the site immediately after creation to the
72        # ZODB. Catalogs and other local utilities are not setup
73        # before that step.
74        self.app = self.getRootFolder()['app']
75        # Set site here. Some of the following setup code might need
76        # to access grok.getSite() and should get our new app then
77        setSite(app)
78
79        self.browser = Browser()
80        self.browser.handleErrors = False
81
82    def tearDown(self):
83        super(MandatesContainerTestCase, self).tearDown()
84        clearSite()
85        shutil.rmtree(self.dc_root)
86
87    def test_set_student_password(self):
88        student = createObject('waeup.Student')
89        # Add and execute a mandate with missing parameters.
90        mandate = PasswordMandate()
91        self.app['mandates'].addMandate(mandate)
92        msg = mandate.execute()
93        self.assertEqual(msg, u'Wrong mandate parameters.')
94        # Add and execute an expired mandate.
95        mandate = PasswordMandate(days=0)
96        self.app['mandates'].addMandate(mandate)
97        msg = mandate.execute()
98        self.assertEqual(msg, u'Mandate expired.')
99        # Add and execute a perfect mandate
100        mandate = PasswordMandate()
101        mandate.params['user'] = student
102        mandate.params['password'] = 'mypwd1'
103        self.app['mandates'].addMandate(mandate)
104        msg = mandate.execute()
105        # Password has been set.
106        self.assertEqual(msg, 'Password has been successfully set. Login with your new password.')
107        self.assertTrue(IUserAccount(student).checkPassword('mypwd1'))
108        # All mandates have been removed.
109        self.assertEqual(len(self.app['mandates'].keys()), 0)
110        logfile = os.path.join(
111            self.app['datacenter'].storage, 'logs', 'main.log')
112        logcontent = open(logfile).read()
113        self.assertTrue('system - PasswordMandate used: K1000000' in logcontent)
114
115    def test_set_officer_password(self):
116        self.app['users'].addUser('bob', 'bobssecret')
117        officer = self.app['users']['bob']
118        mandate = PasswordMandate()
119        mandate.params['user'] = officer
120        mandate.params['password'] = 'mypwd1'
121        self.app['mandates'].addMandate(mandate)
122        msg = mandate.execute()
123        # Password has been set.
124        self.assertEqual(msg, 'Password has been successfully set. Login with your new password.')
125        self.assertTrue(IUserAccount(officer).checkPassword('mypwd1'))
126        logfile = os.path.join(
127            self.app['datacenter'].storage, 'logs', 'main.log')
128        logcontent = open(logfile).read()
129        self.assertTrue('system - PasswordMandate used: bob' in logcontent)
130
131    def test_set_applicant_password(self):
132        applicant = createObject('waeup.Applicant')
133        applicant.applicant_id = u'abc'
134        mandate = PasswordMandate()
135        mandate.params['user'] = applicant
136        mandate.params['password'] = 'mypwd1'
137        self.app['mandates'].addMandate(mandate)
138        msg = mandate.execute()
139        # Password has been set.
140        self.assertEqual(msg, 'Password has been successfully set. Login with your new password.')
141        self.assertTrue(IUserAccount(applicant).checkPassword('mypwd1'))
142        logfile = os.path.join(
143            self.app['datacenter'].storage, 'logs', 'main.log')
144        logcontent = open(logfile).read()
145        self.assertTrue('system - PasswordMandate used: abc' in logcontent)
146
147    def test_remove_expired(self):
148        # mandate1 is an old mandate which just expired.
149        mandate1 = PasswordMandate(days=0)
150        self.app['mandates'].addMandate(mandate1)
151        # mandate2 is a new mandate with default time delta.
152        mandate2 = PasswordMandate(mandate_id='23456')
153        self.app['mandates'].addMandate(mandate2)
154        self.assertEqual(len(self.app['mandates'].keys()), 2)
155        self.assertEqual(self.app['mandates'].count, (1, 1, 2))
156        num_deleted = self.app['mandates'].removeExpired()
157        self.assertEqual(num_deleted, 1)
158        # Only the new mandate remains in the container.
159        self.assertEqual(len(self.app['mandates'].keys()), 1)
160        self.assertEqual([i for i in self.app['mandates'].keys()], [u'23456'])
161
162    def test_purge_mandates(self):
163        # mandate1 is an old mandate which just expired.
164        mandate1 = PasswordMandate(days=0)
165        self.app['mandates'].addMandate(mandate1)
166        # mandate2 is a new mandate with default time delta.
167        mandate2 = PasswordMandate(mandate_id='23456')
168        self.app['mandates'].addMandate(mandate2)
169        self.browser.addHeader('Authorization', 'Basic mgr:mgrpw')
170        self.browser.open('http://localhost/app/configuration')
171        self.assertEqual(self.app['mandates'].count, (1, 1, 2))
172        self.assertTrue('<span>expired</span>' in self.browser.contents)
173        self.browser.getControl("Purge mandates").click()
174        self.assertTrue('1 mandate(s) were purged' in self.browser.contents)
175        self.assertEqual(self.app['mandates'].count, (1, 0, 1))
176        return
177
178    def test_browser(self):
179        student = createObject('waeup.Student')
180        self.app['students'].addStudent(student)
181        mandate = PasswordMandate()
182        mandate.params['user'] = student
183        mandate.params['password'] = 'mypwd1'
184        self.app['mandates'].addMandate(mandate)
185        self.browser.open('http://localhost/app/mandate?mandate_id=%s'
186            % mandate.mandate_id)
187        # Password has been set.
188        self.assertTrue('Password has been successfully set. Login with your new password.'
189            in self.browser.contents)
190        self.assertTrue(IUserAccount(student).checkPassword('mypwd1'))
191        # All mandates have been removed.
192        self.assertEqual(len(self.app['mandates'].keys()), 0)
193        # We redirect to login page not to the frontpage.
194        self.assertEqual(self.browser.url, 'http://localhost/app/login')
Note: See TracBrowser for help on using the repository browser.