/** * Copyright 2011 Michael R. Lange <michael.r.lange@langmi.de>. * * Licensed 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 de.langmi.spring.batch.examples.readers.file.composite; import java.util.HashMap; import java.util.Map; import static org.junit.Assert.*; import org.junit.Test; import org.junit.runner.RunWith; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.batch.core.BatchStatus; import org.springframework.batch.core.JobExecution; import org.springframework.batch.core.JobParameter; import org.springframework.batch.core.JobParameters; import org.springframework.batch.core.StepExecution; import org.springframework.batch.test.JobLauncherTestUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; /** * JobConfigurationTest. * * @author Michael R. Lange <michael.r.lange@langmi.de> */ @ContextConfiguration({ "classpath*:spring/batch/job/readers/file/file-composite-job.xml", "classpath*:spring/batch/setup/**/*.xml"}) @RunWith(SpringJUnit4ClassRunner.class) public class CompositeFlatFileJobConfigurationTest { /** Logger. */ private final Logger LOG = LoggerFactory.getLogger(getClass()); /** Lines count from input file. */ private static final int COUNT = 20; /** JobLauncherTestUtils Bean. */ @Autowired private JobLauncherTestUtils jobLauncherTestUtils; /** Launch Test. */ @Test public void launchJob() throws Exception { // Job parameters Map<String, JobParameter> jobParametersMap = new HashMap<String, JobParameter>(); jobParametersMap.put("time", new JobParameter(System.currentTimeMillis())); jobParametersMap.put("input.file.1", new JobParameter("file:src/test/resources/input/file/composite/input1.txt")); jobParametersMap.put("input.file.2", new JobParameter("file:src/test/resources/input/file/composite/input2.txt")); jobParametersMap.put("output.file", new JobParameter("file:target/test-outputs/readers/file/composite/output.txt")); // launch the job JobExecution jobExecution = jobLauncherTestUtils.launchJob(new JobParameters(jobParametersMap)); // assert job run status assertEquals(BatchStatus.COMPLETED, jobExecution.getStatus()); // output step summaries for (StepExecution step : jobExecution.getStepExecutions()) { LOG.debug(step.getSummary()); assertEquals("Read Count mismatch, changed input?", COUNT, step.getReadCount()); } } }