## $Id: test_browser.py 11813 2014-09-24 06:36:19Z henrik $
##
## Copyright (C) 2013 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
##
"""
Test the applicant-related UI components.
"""
import os
import datetime
from zope.component import createObject, getUtility
from zope.catalog.interfaces import ICatalog
from zope.intid.interfaces import IIntIds
from kofacustom.skeleton.testing import FunctionalLayer
from waeup.kofa.applicants.tests.test_browser import ApplicantsFullSetup
from waeup.kofa.applicants.tests.test_batching import ApplicantImportExportSetup
from kofacustom.skeleton.applicants.export import CustomApplicantsExporter
from kofacustom.skeleton.applicants.batching import CustomApplicantProcessor

class CustomApplicantUITests(ApplicantsFullSetup):
    # Tests for uploading/browsing the passport image of appplicants

    layer = FunctionalLayer

class ApplicantsExporterTest(ApplicantImportExportSetup):

    layer = FunctionalLayer

    def setUp(self):
        super(ApplicantsExporterTest, self).setUp()
        self.outfile = os.path.join(self.workdir, 'myoutput.csv')
        self.cat = getUtility(ICatalog, name='applicants_catalog')
        self.intids = getUtility(IIntIds)
        return

    def setup_applicant(self, applicant):
        # set predictable values for `applicant`
        applicant.reg_number = u'123456'
        applicant.applicant_id = u'dp2011_654321'
        applicant.firstname = u'Anna'
        applicant.lastname = u'Tester'
        applicant.middlename = u'M.'
        applicant.nationality = u'NG'
        applicant.date_of_birth = datetime.date(1981, 2, 4)
        applicant.sex = 'f'
        applicant.email = 'anna@sample.com'
        applicant.phone = u'+234-123-12345'
        applicant.course1 = self.certificate
        applicant.course2 = self.certificate
        applicant.course_admitted = self.certificate
        applicant.notice = u'Some notice\nin lines.'
        applicant.screening_score = 98
        applicant.screening_venue = u'Exam Room'
        applicant.screening_date = u'Saturday, 16th June 2012 2:00:00 PM'
        applicant.password = 'any password'
        return applicant

    def test_export_reimport_all(self):
        # we can export all applicants in a portal
        # set values we can expect in export file
        self.applicant = self.setup_applicant(self.applicant)
        exporter = CustomApplicantsExporter()
        exporter.export_all(self.app, self.outfile)
        result = open(self.outfile, 'rb').read()
        self.assertMatches(result,
            'aggregate,applicant_id,application_date,application_number,'
            'course1,course2,course_admitted,date_of_birth,display_fullname,'
            'email,emp2_end,emp2_position,emp2_reason,emp2_start,emp_end,'
            'emp_position,emp_reason,emp_start,employer,employer2,'
            'firstname,history,hq_degree,hq_disc,hq_matric_no,hq_school,'
            'hq_session,hq_type,jamb_age,jamb_score,jamb_subjects,lastname,lga,'
            'locked,middlename,nationality,notice,nysc_lga,nysc_year,'
            'password,phone,pp_school,presently_inst,reg_number,'
            'result_uploaded,screening_date,screening_score,'
            'screening_venue,sex,special_application,'
            'state,student_id,suspended,container_code\r\n'
            ',dp2011_654321,,654321,CERT1,CERT1,CERT1,1981-02-04#,'
            'Anna M. Tester,anna@sample.com,,,,,,,,,,,Anna,'
            '[u\'2012-10-28 21:27:52 WAT - Application initialized by system\']'
            ',,,,,,,,,,Tester,,0,M.,NG,"Some notice\nin lines.",,,'
            'any password,+234-123-12345#,,,123456,,'
            '"Saturday, 16th June 2012 2:00:00 PM",98,Exam Room,f,,initialized,,'
            '0,dp2011\r\n')
        # We can import the same file if we ignore some columns.
        # Since the applicants_catalog hasn't been notified, the same
        # record with same reg_number can be imported twice.
        processor = CustomApplicantProcessor()
        result = processor.doImport(
            self.outfile,
            ['aggreagate','ignore_applicant_id','application_date',
            'ignore_application_number','course1','course2',
            'course_admitted','date_of_birth','ignore3','email','emp2_end',
            'emp2_position','emp2_reason','emp2_start','emp_end','emp_position',
            'emp_reason','emp_start','employer','employer2','firstname','ignore4',
            'hq_degree','hq_disc','hq_matric_no','hq_school','hq_session','hq_type',
            'jamb_age','jamb_score','jamb_subjects','lastname','lga','locked','middlename',
            'nationality','notice','nysc_lga',
            'nysc_year','password','phone','pp_school','presently_inst',
            'reg_number','result_uploaded',
            'screening_date','screening_score','screening_venue','sex',
            'special_application',
            'state','student_id','suspended','container_code'],
            mode='create')
        num_succ, num_fail, finished_path, failed_path = result
        #content = open(failed_path).read()
        self.assertEqual(num_succ,1)
        self.assertEqual(num_fail,0)
        # Now we ignore also the container_code and import the same file
        # in update mode which means that INigeriaApplicantUpdateByRegNo
        # is used for field conversion. applicant_id must be ignored
        # too since the previous import has notified the applicants_catalog
        # so that the portal 'knows' that reg_number is in use.
        processor = CustomApplicantProcessor()
        result = processor.doImport(
            self.outfile,
            ['aggregate','ignore_applicant_id','application_date',
            'ignore_application_number','course1','course2',
            'course_admitted','date_of_birth','ignore3','email','emp2_end',
            'emp2_position','emp2_reason','emp2_start','emp_end','emp_position',
            'emp_reason','emp_start','employer','employer2','firstname','ignore4',
            'hq_degree','hq_disc','hq_matric_no','hq_school','hq_session','hq_type',
            'jamb_age','jamb_score','jamb_subjects','lastname','lga','locked','middlename',
            'nationality','notice','nysc_lga',
            'nysc_year','password','phone','pp_school','presently_inst',
            'reg_number','result_uploaded','screening_date','screening_score',
            'screening_venue','sex','special_application',
            'state','student_id','suspended','ignore_container_code'],
            mode='update')
        num_succ, num_fail, finished_path, failed_path = result
        self.assertEqual(num_succ,1)
        self.assertEqual(num_fail,0)
        return
