/*
* Copyright (c) 2013 Red Hat, Inc. and/or its affiliates.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Cheng Fang - Initial API and implementation
*/
package org.jberet.testapps.postconstruct;
import java.util.Date;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import javax.batch.api.BatchProperty;
import javax.batch.api.listener.StepListener;
import javax.batch.operations.BatchRuntimeException;
import javax.batch.runtime.BatchStatus;
import javax.inject.Inject;
import javax.inject.Named;
import org.jberet.runtime.AbstractStepExecution;
import org.jberet.runtime.context.StepContextImpl;
import org.jberet.testapps.common.PostConstructPreDestroyBase;
@Named
public class StepListener1 extends PostConstructPreDestroyBase implements StepListener {
@Inject
@BatchProperty(name = "os.name")
private String osName;
@Override
public void beforeStep() throws Exception {
addToJobExitStatus("StepListener1.beforeStep");
}
@Override
public void afterStep() throws Exception {
addToJobExitStatus("StepListener1.afterStep");
final StepContextImpl stepContextImpl = (StepContextImpl) this.stepContext;
final AbstractStepExecution stepExecution = stepContextImpl.getStepExecution();
final BatchStatus batchStatus = this.stepContext.getBatchStatus();
final Date endTime = stepExecution.getEndTime();
System.out.printf("%nStepListener1.afterStep, batchStatus=%s, endTime=%s%n%n", batchStatus, endTime);
if (batchStatus != BatchStatus.COMPLETED) {
throw new BatchRuntimeException("Expecting BatchStatus.COMPLETED in StepListener1.afterStep(), but got " + batchStatus);
}
if (endTime == null) {
throw new BatchRuntimeException("Expecting a valid end time in StepListener1.afterStep(), but got " + endTime);
}
}
@PostConstruct
public void ps() {
System.out.printf("StepListener1 PostConstruct of %s%n", this);
if (osName == null) {
throw new BatchRuntimeException("osNmae field has not been initialized when checking from PostConstruct method.");
}
addToJobExitStatus("StepListener1.ps");
}
@PreDestroy
public void pd() {
System.out.printf("StepListener1 PreDestroy of %s%n", this);
addToJobExitStatus("StepListener1.pd");
}
}