## $Id: tests.py 9811 2012-12-18 17:25:36Z henrik $
##
## Copyright (C) 2011 Uli Fouquet & Henrik Bettermann
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by
## the Free Software Foundation; either version 2 of the License, or
## (at your option) any later version.
##
## This program is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
## GNU General Public License for more details.
##
## You should have received a copy of the GNU General Public License
## along with this program; if not, write to the Free Software
## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
##
import os
import grok
from hurry.workflow.interfaces import IWorkflowState
from zope.component import createObject, getUtility
from zope.catalog.interfaces import ICatalog
from zope.event import notify
from waeup.kofa.university.faculty import Faculty
from waeup.kofa.university.department import Department
from waeup.kofa.students.tests.test_browser import StudentsFullSetup
from waeup.kofa.applicants.tests.test_browser import ApplicantsFullSetup
from waeup.kofa.configuration import SessionConfiguration
from waeup.kwarapoly.testing import FunctionalLayer
# Also run tests that send requests to external servers?
# If you enable this, please make sure the external services
# do exist really and are not bothered by being spammed by a test programme.
EXTERNAL_TESTS = False
def external_test(func):
if not EXTERNAL_TESTS:
myself = __file__
if myself.endswith('.pyc'):
myself = myself[:-2]
print "WARNING: external tests are skipped!"
print "WARNING: edit %s to enable them." % myself
return
return func
class InterswitchTestsStudents(StudentsFullSetup):
"""Tests for the Interswitch payment gateway.
"""
layer = FunctionalLayer
def setUp(self):
super(InterswitchTestsStudents, self).setUp()
# Create at least one Kwarapoly faculty
self.app['faculties']['CPGS'] = Faculty(code='CPGS')
self.app['faculties']['CPGS']['dep1'] = Department(code='dep1')
self.certificate2 = createObject('waeup.Certificate')
self.certificate2.code = u'CERT2'
self.certificate2.application_category = 'basic'
self.certificate2.study_mode = 'nd_ft'
self.certificate2.start_level = 100
self.certificate2.end_level = 300
self.app['faculties']['CPGS']['dep1'].certificates.addCertificate(
self.certificate2)
# Set study course attributes of test student
self.student['studycourse'].certificate = self.certificate2
self.student['studycourse'].current_session = 2004
self.student['studycourse'].entry_session = 2004
self.student['studycourse'].current_verdict = 'A'
self.student['studycourse'].current_level = 100
# Set local lga
self.student.lga = u'kwara_asa'
# Update the catalog
notify(grok.ObjectModifiedEvent(self.student))
self.browser.addHeader('Authorization', 'Basic mgr:mgrpw')
self.browser.open(self.payments_path)
IWorkflowState(self.student).setState('cleared')
self.browser.open(self.payments_path + '/addop')
self.browser.getControl(name="form.p_category").value = ['schoolfee']
self.browser.getControl("Create ticket").click()
self.assertMatches('...ticket created...',
self.browser.contents)
ctrl = self.browser.getControl(name='val_id')
self.value = ctrl.options[0]
self.browser.getLink(self.value).click()
self.assertMatches('...Amount Authorized...',
self.browser.contents)
self.assertMatches(
'...36600.0...',
self.browser.contents)
self.payment_url = self.browser.url
# def callback_url(self, payment_url, resp, apprAmt):
# return payment_url + (
# '/isw_callback?echo=' +
# '&resp=%s' +
# '&desc=Something went wrong' +
# '&txnRef=p1331792385335' +
# '&payRef=' + '&retRef=' +
# '&cardNum=0' +
# '&apprAmt=%s' +
# '&url=http://xyz') % (resp, apprAmt)
def test_interswitch_form(self):
# Manager can access InterswitchForm
self.assertEqual(self.student['payments'][self.value].provider_amt, 0.0)
self.assertEqual(self.student['payments'][self.value].gateway_amt, 0.0)
self.assertEqual(self.student['payments'][self.value].thirdparty_amt, 0.0)
self.browser.getLink("CollegePAY", index=0).click()
# Split amounts have been set.
self.assertEqual(self.student['payments'][self.value].provider_amt, 1200.0)
self.assertEqual(self.student['payments'][self.value].gateway_amt, 300.0)
self.assertEqual(self.student['payments'][self.value].thirdparty_amt, 1800.0)
self.assertMatches('...Total Amount Authorized:...',
self.browser.contents)
self.assertTrue(
'' in
self.browser.contents)
self.assertTrue(
'item_name="School Fee" item_amt="3330000" bank_id="120" acct_num="1771180233"' in
self.browser.contents)
self.assertTrue(
'item_name="Dalash" item_amt="180000" bank_id="117" acct_num="1013196791"' in
self.browser.contents)
self.assertTrue(
'item_name="BT Education" item_amt="120000" bank_id="117" acct_num="1010764827"' in
self.browser.contents)
# Let's do the same for maintenance fee payment
self.browser.open(self.payments_path)
self.browser.open(self.payments_path + '/addop')
self.browser.getControl(
name="form.p_category").value = ['hostel_maintenance']
self.browser.getControl("Create ticket").click()
self.assertMatches('...You have not yet booked accommodation...',
self.browser.contents)
# Students have to book bed first
self.browser.open(self.acco_path)
IWorkflowState(self.student).setState('admitted')
self.browser.getLink("Book accommodation").click()
self.assertFalse('Activation Code:' in self.browser.contents)
self.browser.getControl("Create bed ticket").click()
# Bed is randomly selected but, since there is only
# one bed for this student, we know that ...
self.assertMatches('...Hall 1, Block A, Room 101, Bed A...',
self.browser.contents)
self.assertMatches('...ticket created...',
self.browser.contents)
self.browser.open(self.payments_path + '/addop')
self.browser.getControl(
name="form.p_category").value = ['hostel_maintenance']
self.browser.getControl("Create ticket").click()
self.assertMatches('...ticket created...',
self.browser.contents)
ctrl = self.browser.getControl(name='val_id')
value = ctrl.options[1]
self.browser.getLink(value).click()
self.assertMatches('...Amount Authorized...',
self.browser.contents)
# Maint fee is taken from the session configuration object
self.assertMatches(
'...987.0...',
self.browser.contents)
self.payment_url = self.browser.url
# Manager can access InterswitchForm
self.browser.getLink("CollegePAY", index=0).click()
# Split amounts have been set.
self.assertEqual(self.student['payments'][value].provider_amt, 0.0)
self.assertEqual(self.student['payments'][value].thirdparty_amt, 0.0)
self.assertEqual(self.student['payments'][value].gateway_amt, 300.0)
# The total amount to be processed by Interswitch
# has been reduced by the Interswitch fee of 150 Nairas
self.assertMatches('...Total Amount Authorized:...',
self.browser.contents)
self.assertMatches(
'......',
self.browser.contents)
self.assertMatches(
'......',
self.browser.contents)
self.assertMatches(
'...item_name="Hostel Maintenance Fee" item_amt="68700" bank_id="31" acct_num="0039050937"...',
self.browser.contents)
# Create carryover ticket
self.browser.open(self.payments_path + '/addop')
self.browser.getControl(name="form.p_category").value = ['carryover1']
self.browser.getControl("Create ticket").click()
ctrl = self.browser.getControl(name='val_id')
value = ctrl.options[2]
self.browser.getLink(value).click()
self.assertMatches(
'...6000.0...',
self.browser.contents)
# Manager can access InterswitchForm
self.browser.getLink("CollegePAY", index=0).click()
# Split amounts have been set.
self.assertEqual(self.student['payments'][self.value].provider_amt, 1200.0)
self.assertEqual(self.student['payments'][self.value].gateway_amt, 300.0)
self.assertEqual(self.student['payments'][self.value].thirdparty_amt, 1800.0)
self.assertMatches('......',
self.browser.contents)
self.assertMatches('...Total Amount Authorized:...',
self.browser.contents)
self.assertMatches(
'......',
self.browser.contents)
self.assertMatches(
'...item_name="School Fee" item_amt="270000" bank_id="120" acct_num="1771180233"...',
self.browser.contents)
self.assertMatches(
'...item_name="Dalash" item_amt="180000" bank_id="117" acct_num="1013196791"...',
self.browser.contents)
self.assertMatches(
'...item_name="BT Education" item_amt="120000" bank_id="117" acct_num="1010764827"...',
self.browser.contents)
@external_test
def test_webservice(self):
# First we have open InterswitchPageStudent to set provider_amt
# and gateway_amt
self.browser.open(self.payment_url + '/goto_interswitch')
# Now we can call the webservice
self.browser.open(self.payment_url + '/request_webservice')
self.assertMatches('...Unsuccessful callback...',
self.browser.contents)
# The payment is now in state failed ...
self.assertMatches('...Failed...',
self.browser.contents)
# ... and the catalog has been updated
cat = getUtility(ICatalog, name='payments_catalog')
results = list(
cat.searchResults(p_state=('failed', 'failed')))
self.assertEqual(len(results), 1)
self.assertEqual(results[0].p_state, 'failed')
# Let's replace the p_id with a valid p_id of the Kwarapoly
# live system. This is definitely not an appropriate
# solution for testing, but we have no choice since
# Interswitch doesn't provide any interface
# for testing.
payment = self.student['payments'][self.value]
payment.p_id = 'p3543612043224'
self.browser.open(self.payment_url + '/request_webservice')
self.assertMatches('...Callback amount does not match...',
self.browser.contents)
# The payment is now in state failed ...
self.assertMatches('...Failed...',
self.browser.contents)
# Let's replace the amount autorized with the amount of the
# live system payment
payment.amount_auth = payment.r_amount_approved
self.browser.open(self.payment_url + '/request_webservice')
self.assertMatches('...Successful payment...',
self.browser.contents)
# The payment is now in state paid ...
self.assertMatches('...Paid...',
self.browser.contents)
# ... and the catalog has been updated
cat = getUtility(ICatalog, name='payments_catalog')
results = list(
cat.searchResults(p_state=('paid', 'paid')))
self.assertEqual(len(results), 1)
self.assertEqual(results[0].p_state, 'paid')
# Approval is logged in students.log ...
logfile = os.path.join(
self.app['datacenter'].storage, 'logs', 'students.log')
logcontent = open(logfile).read()
self.assertTrue(
'zope.mgr - '
'waeup.kwarapoly.interswitch.browser.InterswitchPaymentRequestWebservicePageStudent - '
'W1000000 - successful schoolfee payment: p3543612043224\n'
in logcontent)
# ... and in payments.log
logfile = os.path.join(
self.app['datacenter'].storage, 'logs', 'payments.log')
logcontent = open(logfile).read()
self.assertTrue(
'"zope.mgr",W1000000,p3543612043224,schoolfee,'
'52100.0,00,1200.0,300.0,1800.0,,,\n'
in logcontent)