| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| package org.apache.fineract.integrationtests.bulkimport.importhandler.savings; |
| |
| import com.jayway.restassured.builder.RequestSpecBuilder; |
| import com.jayway.restassured.builder.ResponseSpecBuilder; |
| import com.jayway.restassured.http.ContentType; |
| import com.jayway.restassured.specification.RequestSpecification; |
| import com.jayway.restassured.specification.ResponseSpecification; |
| import org.apache.fineract.infrastructure.bulkimport.constants.LoanConstants; |
| import org.apache.fineract.infrastructure.bulkimport.constants.SavingsConstants; |
| import org.apache.fineract.infrastructure.bulkimport.constants.TemplatePopulateImportConstants; |
| import org.apache.fineract.integrationtests.common.ClientHelper; |
| import org.apache.fineract.integrationtests.common.GroupHelper; |
| import org.apache.fineract.integrationtests.common.OfficeHelper; |
| import org.apache.fineract.integrationtests.common.Utils; |
| import org.apache.fineract.integrationtests.common.loans.LoanTransactionHelper; |
| import org.apache.fineract.integrationtests.common.organisation.StaffHelper; |
| import org.apache.fineract.integrationtests.common.savings.SavingsAccountHelper; |
| import org.apache.fineract.integrationtests.common.savings.SavingsProductHelper; |
| import org.apache.fineract.template.domain.Template; |
| import org.apache.poi.hssf.usermodel.HSSFWorkbook; |
| import org.apache.poi.ss.usermodel.Row; |
| import org.apache.poi.ss.usermodel.Sheet; |
| import org.apache.poi.ss.usermodel.Workbook; |
| import org.junit.Assert; |
| import org.junit.Before; |
| import org.junit.Test; |
| |
| import javax.ws.rs.core.HttpHeaders; |
| import javax.ws.rs.core.MediaType; |
| import java.io.*; |
| import java.text.ParseException; |
| import java.text.SimpleDateFormat; |
| import java.util.Date; |
| |
| public class SavingsImportHandlerTest { |
| private ResponseSpecification responseSpec; |
| private RequestSpecification requestSpec; |
| |
| @Before |
| public void setup() { |
| Utils.initializeRESTAssured(); |
| this.requestSpec = new RequestSpecBuilder().setContentType(ContentType.JSON).build(); |
| this.requestSpec.header("Authorization", "Basic " + Utils.loginIntoServerAndGetBase64EncodedAuthenticationKey()); |
| this.responseSpec = new ResponseSpecBuilder().expectStatusCode(200).build(); |
| } |
| |
| @Test |
| public void testSavingsImport() throws InterruptedException, IOException, ParseException { |
| |
| requestSpec.header(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON); |
| //in order to populate helper sheets |
| OfficeHelper officeHelper=new OfficeHelper(requestSpec,responseSpec); |
| Integer outcome_office_creation=officeHelper.createOffice("02 May 2000"); |
| Assert.assertNotNull("Could not create office" ,outcome_office_creation); |
| |
| //in order to populate helper sheets |
| ClientHelper clientHelper=new ClientHelper(requestSpec,responseSpec); |
| Integer outcome_client_creation=clientHelper.createClient(requestSpec,responseSpec); |
| Assert.assertNotNull("Could not create client" ,outcome_client_creation); |
| |
| //in order to populate helper sheets |
| GroupHelper groupHelper=new GroupHelper(requestSpec,responseSpec); |
| Integer outcome_group_creation=groupHelper.createGroup(requestSpec,responseSpec,true); |
| Assert.assertNotNull("Could not create group" ,outcome_group_creation); |
| |
| //in order to populate helper sheets |
| StaffHelper staffHelper=new StaffHelper(); |
| Integer outcome_staff_creation =staffHelper.createStaff(requestSpec,responseSpec); |
| Assert.assertNotNull("Could not create staff",outcome_staff_creation); |
| |
| SavingsProductHelper savingsProductHelper=new SavingsProductHelper(); |
| String jsonSavingsProduct=savingsProductHelper.build(); |
| Integer outcome_sp_creaction=savingsProductHelper.createSavingsProduct(jsonSavingsProduct,requestSpec,responseSpec); |
| Assert.assertNotNull("Could not create Savings product",outcome_sp_creaction); |
| |
| SavingsAccountHelper savingsAccountHelper=new SavingsAccountHelper(requestSpec,responseSpec); |
| Workbook workbook=savingsAccountHelper.getSavingsWorkbook("dd MMMM yyyy"); |
| |
| //insert dummy data into Savings sheet |
| Sheet savingsSheet = workbook.getSheet(TemplatePopulateImportConstants.SAVINGS_ACCOUNTS_SHEET_NAME); |
| Row firstSavingsRow=savingsSheet.getRow(1); |
| Sheet officeSheet=workbook.getSheet(TemplatePopulateImportConstants.OFFICE_SHEET_NAME); |
| firstSavingsRow.createCell(SavingsConstants.OFFICE_NAME_COL).setCellValue(officeSheet.getRow(1).getCell(1).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.SAVINGS_TYPE_COL).setCellValue("Individual"); |
| firstSavingsRow.createCell(SavingsConstants.CLIENT_NAME_COL).setCellValue(savingsSheet.getRow(1).getCell(SavingsConstants.LOOKUP_CLIENT_NAME_COL).getStringCellValue()); |
| Sheet savingsProductSheet=workbook.getSheet(TemplatePopulateImportConstants.PRODUCT_SHEET_NAME); |
| firstSavingsRow.createCell(SavingsConstants.PRODUCT_COL).setCellValue(savingsProductSheet.getRow(1).getCell(1).getStringCellValue()); |
| Sheet staffSheet=workbook.getSheet(TemplatePopulateImportConstants.STAFF_SHEET_NAME); |
| firstSavingsRow.createCell(SavingsConstants.FIELD_OFFICER_NAME_COL).setCellValue(staffSheet.getRow(1).getCell(1).getStringCellValue()); |
| SimpleDateFormat simpleDateFormat=new SimpleDateFormat("dd MMMM yyyy"); |
| Date date=simpleDateFormat.parse("13 May 2017"); |
| firstSavingsRow.createCell(SavingsConstants.SUBMITTED_ON_DATE_COL).setCellValue(date); |
| firstSavingsRow.createCell(SavingsConstants.APPROVED_DATE_COL).setCellValue(date); |
| firstSavingsRow.createCell(SavingsConstants.ACTIVATION_DATE_COL).setCellValue(date); |
| firstSavingsRow.createCell(SavingsConstants.CURRENCY_COL).setCellValue(savingsProductSheet.getRow(1).getCell(10).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.DECIMAL_PLACES_COL).setCellValue(savingsProductSheet.getRow(1).getCell(11).getNumericCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.IN_MULTIPLES_OF_COL).setCellValue(savingsProductSheet.getRow(1).getCell(12).getNumericCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.NOMINAL_ANNUAL_INTEREST_RATE_COL).setCellValue(savingsProductSheet.getRow(1).getCell(2).getNumericCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.INTEREST_COMPOUNDING_PERIOD_COL).setCellValue(savingsProductSheet.getRow(1).getCell(3).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.INTEREST_POSTING_PERIOD_COL).setCellValue(savingsProductSheet.getRow(1).getCell(4).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.INTEREST_CALCULATION_COL).setCellValue(savingsProductSheet.getRow(1).getCell(5).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.INTEREST_CALCULATION_DAYS_IN_YEAR_COL).setCellValue(savingsProductSheet.getRow(1).getCell(6).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.MIN_OPENING_BALANCE_COL).setCellValue(savingsProductSheet.getRow(1).getCell(7).getNumericCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.LOCKIN_PERIOD_COL).setCellValue(savingsProductSheet.getRow(1).getCell(8).getNumericCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.LOCKIN_PERIOD_FREQUENCY_COL).setCellValue(savingsProductSheet.getRow(1).getCell(9).getStringCellValue()); |
| firstSavingsRow.createCell(SavingsConstants.APPLY_WITHDRAWAL_FEE_FOR_TRANSFERS).setCellValue("False"); |
| firstSavingsRow.createCell(SavingsConstants.ALLOW_OVER_DRAFT_COL).setCellValue("False"); |
| firstSavingsRow.createCell(SavingsConstants.OVER_DRAFT_LIMIT_COL).setCellValue(savingsProductSheet.getRow(1).getCell(15).getNumericCellValue()); |
| |
| File directory=new File(System.getProperty("user.home")+"\\Fineract\\bulkimport\\integration_tests\\importhandler\\savings") ; |
| if (!directory.exists()) |
| directory.mkdirs(); |
| File file= new File(directory+"\\Savings.xls"); |
| OutputStream outputStream=new FileOutputStream(file); |
| workbook.write(outputStream); |
| outputStream.close(); |
| |
| String importDocumentId=savingsAccountHelper.importSavingsTemplate(file); |
| file.delete(); |
| Assert.assertNotNull(importDocumentId); |
| |
| //Wait for the creation of output excel |
| Thread.sleep(3000); |
| |
| //check status column of output excel |
| String location=savingsAccountHelper.getOutputTemplateLocation(importDocumentId); |
| FileInputStream fileInputStream = new FileInputStream(location); |
| Workbook Outputworkbook=new HSSFWorkbook(fileInputStream); |
| Sheet OutputSavingsSheet = Outputworkbook.getSheet(TemplatePopulateImportConstants.SAVINGS_ACCOUNTS_SHEET_NAME); |
| Row row= OutputSavingsSheet.getRow(1); |
| Assert.assertEquals("Imported",row.getCell(SavingsConstants.STATUS_COL).getStringCellValue()); |
| } |
| } |