org.springframework.batch.integration.partition.JmsIntegrationTests.java Source code

Java tutorial

Introduction

Here is the source code for org.springframework.batch.integration.partition.JmsIntegrationTests.java

Source

/*
 * Copyright 2006-2007 the original author or authors.
 * 
 * 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 org.springframework.batch.integration.partition;

import java.util.List;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.junit.Test;
import org.junit.runner.RunWith;

import org.springframework.batch.core.BatchStatus;
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobInstance;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.StepExecution;
import org.springframework.batch.core.explore.JobExplorer;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.annotation.DirtiesContext;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;

/**
 * @author Dave Syer
 * 
 */
@ContextConfiguration
@RunWith(SpringJUnit4ClassRunner.class)
@DirtiesContext
public class JmsIntegrationTests {

    private Log logger = LogFactory.getLog(getClass());

    @Autowired
    private JobLauncher jobLauncher;

    @Autowired
    private Job job;

    @Autowired
    private JobExplorer jobExplorer;

    @Test
    public void testSimpleProperties() throws Exception {
        assertNotNull(jobLauncher);
    }

    @Test
    public void testLaunchJob() throws Exception {
        int before = jobExplorer.getJobInstances(job.getName(), 0, 100).size();
        assertNotNull(jobLauncher.run(job, new JobParameters()));
        List<JobInstance> jobInstances = jobExplorer.getJobInstances(job.getName(), 0, 100);
        int after = jobInstances.size();
        assertEquals(1, after - before);
        JobExecution jobExecution = jobExplorer.getJobExecutions(jobInstances.get(jobInstances.size() - 1)).get(0);
        assertEquals(jobExecution.getExitStatus().getExitDescription(), BatchStatus.COMPLETED,
                jobExecution.getStatus());
        assertEquals(3, jobExecution.getStepExecutions().size());
        for (StepExecution stepExecution : jobExecution.getStepExecutions()) {
            // BATCH-1703: we are using a map dao so the step executions in the job execution are old and we need to
            // pull them back out of the repository...
            stepExecution = jobExplorer.getStepExecution(jobExecution.getId(), stepExecution.getId());
            logger.debug("" + stepExecution);
            assertEquals(BatchStatus.COMPLETED, stepExecution.getStatus());
        }
    }
}