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

io.cdap.cdap.app.verification.VerifyResult Maven / Gradle / Ivy

There is a newer version: 6.10.1
Show newest version
/*
 * Copyright © 2014 Cask Data, 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 io.cdap.cdap.app.verification;

import io.cdap.cdap.error.Errors;

/**
 * This class defines the result of {@link Verifier#verify(Object)}.
 */
public final class VerifyResult {
  /**
   * Status of verification.
   */
  public enum Status {
    SUCCESS,
    FAILED
  }

  ;

  /**
   * Stores status of verification.
   */
  private final Status status;

  /**
   * Descriptive message in case of failure.
   */
  private final String message;

  /**
   * Constructor.
   *
   * @param status  of the {@link Verifier#verify(Object)}
   * @param message description in case of failure.
   */
  public VerifyResult(Status status, String message) {
    this.message = message;
    this.status = status;
  }

  /**
   * @return Status of message.
   */
  public Status getStatus() {
    return status;
  }

  public boolean isSuccess() {
    return status == Status.SUCCESS;
  }

  /**
   * @return Descriptive message in case of failure.
   */
  public String getMessage() {
    return message;
  }

  /**
   * Helper static method for creating successfull {@link VerifyResult}.
   *
   * @return An instance of {@link VerifyResult} which is successful.
   */
  public static VerifyResult success() {
    return new VerifyResult(Status.SUCCESS, "OK");
  }

  /**
   * Helper static method for creating failure {@link VerifyResult} with
   * a descriptive message.
   *
   * @return An instance of {@link VerifyResult} which has failed with descriptive message.
   */
  public static VerifyResult failure(Errors error, Object... objects) {
    return new VerifyResult(Status.FAILED, error.getMessage(objects));
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy