All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.norconex.jef4.job.group.SyncJobGroup Maven / Gradle / Ivy

/* Copyright 2010-2014 Norconex Inc.
 *
 * 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 com.norconex.jef4.job.group;

import org.apache.log4j.LogManager;
import org.apache.log4j.Logger;

import com.norconex.jef4.job.IJob;
import com.norconex.jef4.job.JobException;
import com.norconex.jef4.suite.JobSuite;


/**
 * Job responsible for running a group of jobs synchronously.  Jobs are
 * executed in the order specified by the IJob[] array.
 * The progress of this
 * group reflects the average progress of all its jobs.  This job group
 * is considered completed and will only return when all its jobs are
 * done executing.  An exception in one job will stop the other jobs
 * in the group from executing.  Such an exception will
 * result in this group to fail.
 *
 * @author Pascal Essiembre
 */
@SuppressWarnings("nls")
public class SyncJobGroup extends AbstractJobGroup {

    /** Logger. */
    private static final Logger LOG =
            LogManager.getLogger(SyncJobGroup.class);

    public SyncJobGroup(
            final String name, final IJob... jobs) {
        super(name, jobs);
    }

    @Override
    public void executeGroup(JobSuite suite) {

        IJob[] jobs = getJobs();
        String failedJob = null;
        for (int i = 0; i < jobs.length; i++) {
            if (LOG.isDebugEnabled()) {
                LOG.debug("Synchronous group \"" + getId() + "\" "
                        + "about to run synchronous job \""
                        + jobs[i].getId() + "\".");
            }
            if (!suite.runJob(jobs[i])) {
                LOG.error("\"" + jobs[i].getId() + "\" failed.");
                failedJob = jobs[i].getId();
                break;
            }
            if (LOG.isDebugEnabled()) {
                LOG.debug("\"" + jobs[i].getId() + "\" succeeded.");
            }
        }
        if (failedJob != null) {
            throw new JobException(
                    "\"" + failedJob + "\" failed in sync group " + getId());
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy