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

software.amazon.awssdk.services.devicefarm.model.Problem Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Device Farm module holds the client classes that are used for communicating with AWS Device Farm

There is a newer version: 2.29.39
Show newest version
/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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 software.amazon.awssdk.services.devicefarm.model;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* Represents a specific warning or failure. *

*/ @Generated("software.amazon.awssdk:codegen") public final class Problem implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField RUN_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .getter(getter(Problem::run)).setter(setter(Builder::run)).constructor(ProblemDetail::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("run").build()).build(); private static final SdkField JOB_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .getter(getter(Problem::job)).setter(setter(Builder::job)).constructor(ProblemDetail::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("job").build()).build(); private static final SdkField SUITE_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .getter(getter(Problem::suite)).setter(setter(Builder::suite)).constructor(ProblemDetail::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("suite").build()).build(); private static final SdkField TEST_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .getter(getter(Problem::test)).setter(setter(Builder::test)).constructor(ProblemDetail::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("test").build()).build(); private static final SdkField DEVICE_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .getter(getter(Problem::device)).setter(setter(Builder::device)).constructor(Device::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("device").build()).build(); private static final SdkField RESULT_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(Problem::resultAsString)).setter(setter(Builder::result)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("result").build()).build(); private static final SdkField MESSAGE_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(Problem::message)).setter(setter(Builder::message)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("message").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(RUN_FIELD, JOB_FIELD, SUITE_FIELD, TEST_FIELD, DEVICE_FIELD, RESULT_FIELD, MESSAGE_FIELD)); private static final long serialVersionUID = 1L; private final ProblemDetail run; private final ProblemDetail job; private final ProblemDetail suite; private final ProblemDetail test; private final Device device; private final String result; private final String message; private Problem(BuilderImpl builder) { this.run = builder.run; this.job = builder.job; this.suite = builder.suite; this.test = builder.test; this.device = builder.device; this.result = builder.result; this.message = builder.message; } /** *

* Information about the associated run. *

* * @return Information about the associated run. */ public ProblemDetail run() { return run; } /** *

* Information about the associated job. *

* * @return Information about the associated job. */ public ProblemDetail job() { return job; } /** *

* Information about the associated suite. *

* * @return Information about the associated suite. */ public ProblemDetail suite() { return suite; } /** *

* Information about the associated test. *

* * @return Information about the associated test. */ public ProblemDetail test() { return test; } /** *

* Information about the associated device. *

* * @return Information about the associated device. */ public Device device() { return device; } /** *

* The problem's result. *

*

* Allowed values include: *

*
    *
  • *

    * PENDING *

    *
  • *
  • *

    * PASSED *

    *
  • *
  • *

    * WARNED *

    *
  • *
  • *

    * FAILED *

    *
  • *
  • *

    * SKIPPED *

    *
  • *
  • *

    * ERRORED *

    *
  • *
  • *

    * STOPPED *

    *
  • *
*

* If the service returns an enum value that is not available in the current SDK version, {@link #result} will * return {@link ExecutionResult#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #resultAsString}. *

* * @return The problem's result.

*

* Allowed values include: *

*
    *
  • *

    * PENDING *

    *
  • *
  • *

    * PASSED *

    *
  • *
  • *

    * WARNED *

    *
  • *
  • *

    * FAILED *

    *
  • *
  • *

    * SKIPPED *

    *
  • *
  • *

    * ERRORED *

    *
  • *
  • *

    * STOPPED *

    *
  • * @see ExecutionResult */ public ExecutionResult result() { return ExecutionResult.fromValue(result); } /** *

    * The problem's result. *

    *

    * Allowed values include: *

    *
      *
    • *

      * PENDING *

      *
    • *
    • *

      * PASSED *

      *
    • *
    • *

      * WARNED *

      *
    • *
    • *

      * FAILED *

      *
    • *
    • *

      * SKIPPED *

      *
    • *
    • *

      * ERRORED *

      *
    • *
    • *

      * STOPPED *

      *
    • *
    *

    * If the service returns an enum value that is not available in the current SDK version, {@link #result} will * return {@link ExecutionResult#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #resultAsString}. *

    * * @return The problem's result.

    *

    * Allowed values include: *

    *
      *
    • *

      * PENDING *

      *
    • *
    • *

      * PASSED *

      *
    • *
    • *

      * WARNED *

      *
    • *
    • *

      * FAILED *

      *
    • *
    • *

      * SKIPPED *

      *
    • *
    • *

      * ERRORED *

      *
    • *
    • *

      * STOPPED *

      *
    • * @see ExecutionResult */ public String resultAsString() { return result; } /** *

      * A message about the problem's result. *

      * * @return A message about the problem's result. */ public String message() { return message; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(run()); hashCode = 31 * hashCode + Objects.hashCode(job()); hashCode = 31 * hashCode + Objects.hashCode(suite()); hashCode = 31 * hashCode + Objects.hashCode(test()); hashCode = 31 * hashCode + Objects.hashCode(device()); hashCode = 31 * hashCode + Objects.hashCode(resultAsString()); hashCode = 31 * hashCode + Objects.hashCode(message()); return hashCode; } @Override public boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof Problem)) { return false; } Problem other = (Problem) obj; return Objects.equals(run(), other.run()) && Objects.equals(job(), other.job()) && Objects.equals(suite(), other.suite()) && Objects.equals(test(), other.test()) && Objects.equals(device(), other.device()) && Objects.equals(resultAsString(), other.resultAsString()) && Objects.equals(message(), other.message()); } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. */ @Override public String toString() { return ToString.builder("Problem").add("Run", run()).add("Job", job()).add("Suite", suite()).add("Test", test()) .add("Device", device()).add("Result", resultAsString()).add("Message", message()).build(); } public Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "run": return Optional.ofNullable(clazz.cast(run())); case "job": return Optional.ofNullable(clazz.cast(job())); case "suite": return Optional.ofNullable(clazz.cast(suite())); case "test": return Optional.ofNullable(clazz.cast(test())); case "device": return Optional.ofNullable(clazz.cast(device())); case "result": return Optional.ofNullable(clazz.cast(resultAsString())); case "message": return Optional.ofNullable(clazz.cast(message())); default: return Optional.empty(); } } @Override public List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((Problem) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

      * Information about the associated run. *

      * * @param run * Information about the associated run. * @return Returns a reference to this object so that method calls can be chained together. */ Builder run(ProblemDetail run); /** *

      * Information about the associated run. *

      * This is a convenience that creates an instance of the {@link ProblemDetail.Builder} avoiding the need to * create one manually via {@link ProblemDetail#builder()}. * * When the {@link Consumer} completes, {@link ProblemDetail.Builder#build()} is called immediately and its * result is passed to {@link #run(ProblemDetail)}. * * @param run * a consumer that will call methods on {@link ProblemDetail.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #run(ProblemDetail) */ default Builder run(Consumer run) { return run(ProblemDetail.builder().applyMutation(run).build()); } /** *

      * Information about the associated job. *

      * * @param job * Information about the associated job. * @return Returns a reference to this object so that method calls can be chained together. */ Builder job(ProblemDetail job); /** *

      * Information about the associated job. *

      * This is a convenience that creates an instance of the {@link ProblemDetail.Builder} avoiding the need to * create one manually via {@link ProblemDetail#builder()}. * * When the {@link Consumer} completes, {@link ProblemDetail.Builder#build()} is called immediately and its * result is passed to {@link #job(ProblemDetail)}. * * @param job * a consumer that will call methods on {@link ProblemDetail.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #job(ProblemDetail) */ default Builder job(Consumer job) { return job(ProblemDetail.builder().applyMutation(job).build()); } /** *

      * Information about the associated suite. *

      * * @param suite * Information about the associated suite. * @return Returns a reference to this object so that method calls can be chained together. */ Builder suite(ProblemDetail suite); /** *

      * Information about the associated suite. *

      * This is a convenience that creates an instance of the {@link ProblemDetail.Builder} avoiding the need to * create one manually via {@link ProblemDetail#builder()}. * * When the {@link Consumer} completes, {@link ProblemDetail.Builder#build()} is called immediately and its * result is passed to {@link #suite(ProblemDetail)}. * * @param suite * a consumer that will call methods on {@link ProblemDetail.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #suite(ProblemDetail) */ default Builder suite(Consumer suite) { return suite(ProblemDetail.builder().applyMutation(suite).build()); } /** *

      * Information about the associated test. *

      * * @param test * Information about the associated test. * @return Returns a reference to this object so that method calls can be chained together. */ Builder test(ProblemDetail test); /** *

      * Information about the associated test. *

      * This is a convenience that creates an instance of the {@link ProblemDetail.Builder} avoiding the need to * create one manually via {@link ProblemDetail#builder()}. * * When the {@link Consumer} completes, {@link ProblemDetail.Builder#build()} is called immediately and its * result is passed to {@link #test(ProblemDetail)}. * * @param test * a consumer that will call methods on {@link ProblemDetail.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #test(ProblemDetail) */ default Builder test(Consumer test) { return test(ProblemDetail.builder().applyMutation(test).build()); } /** *

      * Information about the associated device. *

      * * @param device * Information about the associated device. * @return Returns a reference to this object so that method calls can be chained together. */ Builder device(Device device); /** *

      * Information about the associated device. *

      * This is a convenience that creates an instance of the {@link Device.Builder} avoiding the need to create one * manually via {@link Device#builder()}. * * When the {@link Consumer} completes, {@link Device.Builder#build()} is called immediately and its result is * passed to {@link #device(Device)}. * * @param device * a consumer that will call methods on {@link Device.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #device(Device) */ default Builder device(Consumer device) { return device(Device.builder().applyMutation(device).build()); } /** *

      * The problem's result. *

      *

      * Allowed values include: *

      *
        *
      • *

        * PENDING *

        *
      • *
      • *

        * PASSED *

        *
      • *
      • *

        * WARNED *

        *
      • *
      • *

        * FAILED *

        *
      • *
      • *

        * SKIPPED *

        *
      • *
      • *

        * ERRORED *

        *
      • *
      • *

        * STOPPED *

        *
      • *
      * * @param result * The problem's result.

      *

      * Allowed values include: *

      *
        *
      • *

        * PENDING *

        *
      • *
      • *

        * PASSED *

        *
      • *
      • *

        * WARNED *

        *
      • *
      • *

        * FAILED *

        *
      • *
      • *

        * SKIPPED *

        *
      • *
      • *

        * ERRORED *

        *
      • *
      • *

        * STOPPED *

        *
      • * @see ExecutionResult * @return Returns a reference to this object so that method calls can be chained together. * @see ExecutionResult */ Builder result(String result); /** *

        * The problem's result. *

        *

        * Allowed values include: *

        *
          *
        • *

          * PENDING *

          *
        • *
        • *

          * PASSED *

          *
        • *
        • *

          * WARNED *

          *
        • *
        • *

          * FAILED *

          *
        • *
        • *

          * SKIPPED *

          *
        • *
        • *

          * ERRORED *

          *
        • *
        • *

          * STOPPED *

          *
        • *
        * * @param result * The problem's result.

        *

        * Allowed values include: *

        *
          *
        • *

          * PENDING *

          *
        • *
        • *

          * PASSED *

          *
        • *
        • *

          * WARNED *

          *
        • *
        • *

          * FAILED *

          *
        • *
        • *

          * SKIPPED *

          *
        • *
        • *

          * ERRORED *

          *
        • *
        • *

          * STOPPED *

          *
        • * @see ExecutionResult * @return Returns a reference to this object so that method calls can be chained together. * @see ExecutionResult */ Builder result(ExecutionResult result); /** *

          * A message about the problem's result. *

          * * @param message * A message about the problem's result. * @return Returns a reference to this object so that method calls can be chained together. */ Builder message(String message); } static final class BuilderImpl implements Builder { private ProblemDetail run; private ProblemDetail job; private ProblemDetail suite; private ProblemDetail test; private Device device; private String result; private String message; private BuilderImpl() { } private BuilderImpl(Problem model) { run(model.run); job(model.job); suite(model.suite); test(model.test); device(model.device); result(model.result); message(model.message); } public final ProblemDetail.Builder getRun() { return run != null ? run.toBuilder() : null; } @Override public final Builder run(ProblemDetail run) { this.run = run; return this; } public final void setRun(ProblemDetail.BuilderImpl run) { this.run = run != null ? run.build() : null; } public final ProblemDetail.Builder getJob() { return job != null ? job.toBuilder() : null; } @Override public final Builder job(ProblemDetail job) { this.job = job; return this; } public final void setJob(ProblemDetail.BuilderImpl job) { this.job = job != null ? job.build() : null; } public final ProblemDetail.Builder getSuite() { return suite != null ? suite.toBuilder() : null; } @Override public final Builder suite(ProblemDetail suite) { this.suite = suite; return this; } public final void setSuite(ProblemDetail.BuilderImpl suite) { this.suite = suite != null ? suite.build() : null; } public final ProblemDetail.Builder getTest() { return test != null ? test.toBuilder() : null; } @Override public final Builder test(ProblemDetail test) { this.test = test; return this; } public final void setTest(ProblemDetail.BuilderImpl test) { this.test = test != null ? test.build() : null; } public final Device.Builder getDevice() { return device != null ? device.toBuilder() : null; } @Override public final Builder device(Device device) { this.device = device; return this; } public final void setDevice(Device.BuilderImpl device) { this.device = device != null ? device.build() : null; } public final String getResult() { return result; } @Override public final Builder result(String result) { this.result = result; return this; } @Override public final Builder result(ExecutionResult result) { this.result(result == null ? null : result.toString()); return this; } public final void setResult(String result) { this.result = result; } public final String getMessage() { return message; } @Override public final Builder message(String message) { this.message = message; return this; } public final void setMessage(String message) { this.message = message; } @Override public Problem build() { return new Problem(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy