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

azkaban.executor.ExecutionAttempt Maven / Gradle / Ivy

/*
 * Copyright 2014 LinkedIn Corp.
 *
 * 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 azkaban.executor;

import azkaban.utils.TypedMapWrapper;
import java.util.HashMap;
import java.util.Map;

public class ExecutionAttempt {

  public static final String ATTEMPT_PARAM = "attempt";
  public static final String STATUS_PARAM = "status";
  public static final String STARTTIME_PARAM = "startTime";
  public static final String ENDTIME_PARAM = "endTime";
  private final Status status;
  private int attempt = 0;
  private long startTime = -1;
  private long endTime = -1;

  public ExecutionAttempt(final int attempt, final ExecutableNode executable) {
    this.attempt = attempt;
    this.startTime = executable.getStartTime();
    this.endTime = executable.getEndTime();
    this.status = executable.getStatus();
  }

  public ExecutionAttempt(final int attempt, final long startTime, final long endTime,
      final Status status) {
    this.attempt = attempt;
    this.startTime = startTime;
    this.endTime = endTime;
    this.status = status;
  }

  public static ExecutionAttempt fromObject(final Object obj) {
    final Map map = (Map) obj;
    final TypedMapWrapper wrapper =
        new TypedMapWrapper<>(map);
    final int attempt = wrapper.getInt(ATTEMPT_PARAM);
    final long startTime = wrapper.getLong(STARTTIME_PARAM);
    final long endTime = wrapper.getLong(ENDTIME_PARAM);
    final Status status = Status.valueOf(wrapper.getString(STATUS_PARAM));

    return new ExecutionAttempt(attempt, startTime, endTime, status);
  }

  public long getStartTime() {
    return this.startTime;
  }

  public long getEndTime() {
    return this.endTime;
  }

  public Status getStatus() {
    return this.status;
  }

  public int getAttempt() {
    return this.attempt;
  }

  public Map toObject() {
    final HashMap attempts = new HashMap<>();
    attempts.put(ATTEMPT_PARAM, this.attempt);
    attempts.put(STARTTIME_PARAM, this.startTime);
    attempts.put(ENDTIME_PARAM, this.endTime);
    attempts.put(STATUS_PARAM, this.status.toString());
    return attempts;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy