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

com.amazonaws.services.fis.model.Experiment Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Fault Injection Simulator module holds the client classes that are used for communicating with AWS Fault Injection Simulator Service

There is a newer version: 1.12.778
Show newest version
/*
 * Copyright 2019-2024 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 com.amazonaws.services.fis.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* Describes an experiment. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class Experiment implements Serializable, Cloneable, StructuredPojo { /** *

* The ID of the experiment. *

*/ private String id; /** *

* The Amazon Resource Name (ARN) of the experiment. *

*/ private String arn; /** *

* The ID of the experiment template. *

*/ private String experimentTemplateId; /** *

* The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service actions * on your behalf. *

*/ private String roleArn; /** *

* The state of the experiment. *

*/ private ExperimentState state; /** *

* The targets for the experiment. *

*/ private java.util.Map targets; /** *

* The actions for the experiment. *

*/ private java.util.Map actions; /** *

* The stop conditions for the experiment. *

*/ private java.util.List stopConditions; /** *

* The time that the experiment was created. *

*/ private java.util.Date creationTime; /** *

* The time that the experiment started. *

*/ private java.util.Date startTime; /** *

* The time that the experiment ended. *

*/ private java.util.Date endTime; /** *

* The tags for the experiment. *

*/ private java.util.Map tags; /** *

* The configuration for experiment logging. *

*/ private ExperimentLogConfiguration logConfiguration; /** *

* The experiment options for the experiment. *

*/ private ExperimentOptions experimentOptions; /** *

* The count of target account configurations for the experiment. *

*/ private Long targetAccountConfigurationsCount; /** *

* The ID of the experiment. *

* * @param id * The ID of the experiment. */ public void setId(String id) { this.id = id; } /** *

* The ID of the experiment. *

* * @return The ID of the experiment. */ public String getId() { return this.id; } /** *

* The ID of the experiment. *

* * @param id * The ID of the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withId(String id) { setId(id); return this; } /** *

* The Amazon Resource Name (ARN) of the experiment. *

* * @param arn * The Amazon Resource Name (ARN) of the experiment. */ public void setArn(String arn) { this.arn = arn; } /** *

* The Amazon Resource Name (ARN) of the experiment. *

* * @return The Amazon Resource Name (ARN) of the experiment. */ public String getArn() { return this.arn; } /** *

* The Amazon Resource Name (ARN) of the experiment. *

* * @param arn * The Amazon Resource Name (ARN) of the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withArn(String arn) { setArn(arn); return this; } /** *

* The ID of the experiment template. *

* * @param experimentTemplateId * The ID of the experiment template. */ public void setExperimentTemplateId(String experimentTemplateId) { this.experimentTemplateId = experimentTemplateId; } /** *

* The ID of the experiment template. *

* * @return The ID of the experiment template. */ public String getExperimentTemplateId() { return this.experimentTemplateId; } /** *

* The ID of the experiment template. *

* * @param experimentTemplateId * The ID of the experiment template. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withExperimentTemplateId(String experimentTemplateId) { setExperimentTemplateId(experimentTemplateId); return this; } /** *

* The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service actions * on your behalf. *

* * @param roleArn * The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service * actions on your behalf. */ public void setRoleArn(String roleArn) { this.roleArn = roleArn; } /** *

* The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service actions * on your behalf. *

* * @return The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service * actions on your behalf. */ public String getRoleArn() { return this.roleArn; } /** *

* The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service actions * on your behalf. *

* * @param roleArn * The Amazon Resource Name (ARN) of an IAM role that grants the FIS service permission to perform service * actions on your behalf. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withRoleArn(String roleArn) { setRoleArn(roleArn); return this; } /** *

* The state of the experiment. *

* * @param state * The state of the experiment. */ public void setState(ExperimentState state) { this.state = state; } /** *

* The state of the experiment. *

* * @return The state of the experiment. */ public ExperimentState getState() { return this.state; } /** *

* The state of the experiment. *

* * @param state * The state of the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withState(ExperimentState state) { setState(state); return this; } /** *

* The targets for the experiment. *

* * @return The targets for the experiment. */ public java.util.Map getTargets() { return targets; } /** *

* The targets for the experiment. *

* * @param targets * The targets for the experiment. */ public void setTargets(java.util.Map targets) { this.targets = targets; } /** *

* The targets for the experiment. *

* * @param targets * The targets for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withTargets(java.util.Map targets) { setTargets(targets); return this; } /** * Add a single Targets entry * * @see Experiment#withTargets * @returns a reference to this object so that method calls can be chained together. */ public Experiment addTargetsEntry(String key, ExperimentTarget value) { if (null == this.targets) { this.targets = new java.util.HashMap(); } if (this.targets.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.targets.put(key, value); return this; } /** * Removes all the entries added into Targets. * * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment clearTargetsEntries() { this.targets = null; return this; } /** *

* The actions for the experiment. *

* * @return The actions for the experiment. */ public java.util.Map getActions() { return actions; } /** *

* The actions for the experiment. *

* * @param actions * The actions for the experiment. */ public void setActions(java.util.Map actions) { this.actions = actions; } /** *

* The actions for the experiment. *

* * @param actions * The actions for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withActions(java.util.Map actions) { setActions(actions); return this; } /** * Add a single Actions entry * * @see Experiment#withActions * @returns a reference to this object so that method calls can be chained together. */ public Experiment addActionsEntry(String key, ExperimentAction value) { if (null == this.actions) { this.actions = new java.util.HashMap(); } if (this.actions.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.actions.put(key, value); return this; } /** * Removes all the entries added into Actions. * * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment clearActionsEntries() { this.actions = null; return this; } /** *

* The stop conditions for the experiment. *

* * @return The stop conditions for the experiment. */ public java.util.List getStopConditions() { return stopConditions; } /** *

* The stop conditions for the experiment. *

* * @param stopConditions * The stop conditions for the experiment. */ public void setStopConditions(java.util.Collection stopConditions) { if (stopConditions == null) { this.stopConditions = null; return; } this.stopConditions = new java.util.ArrayList(stopConditions); } /** *

* The stop conditions for the experiment. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setStopConditions(java.util.Collection)} or {@link #withStopConditions(java.util.Collection)} if you want * to override the existing values. *

* * @param stopConditions * The stop conditions for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withStopConditions(ExperimentStopCondition... stopConditions) { if (this.stopConditions == null) { setStopConditions(new java.util.ArrayList(stopConditions.length)); } for (ExperimentStopCondition ele : stopConditions) { this.stopConditions.add(ele); } return this; } /** *

* The stop conditions for the experiment. *

* * @param stopConditions * The stop conditions for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withStopConditions(java.util.Collection stopConditions) { setStopConditions(stopConditions); return this; } /** *

* The time that the experiment was created. *

* * @param creationTime * The time that the experiment was created. */ public void setCreationTime(java.util.Date creationTime) { this.creationTime = creationTime; } /** *

* The time that the experiment was created. *

* * @return The time that the experiment was created. */ public java.util.Date getCreationTime() { return this.creationTime; } /** *

* The time that the experiment was created. *

* * @param creationTime * The time that the experiment was created. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withCreationTime(java.util.Date creationTime) { setCreationTime(creationTime); return this; } /** *

* The time that the experiment started. *

* * @param startTime * The time that the experiment started. */ public void setStartTime(java.util.Date startTime) { this.startTime = startTime; } /** *

* The time that the experiment started. *

* * @return The time that the experiment started. */ public java.util.Date getStartTime() { return this.startTime; } /** *

* The time that the experiment started. *

* * @param startTime * The time that the experiment started. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withStartTime(java.util.Date startTime) { setStartTime(startTime); return this; } /** *

* The time that the experiment ended. *

* * @param endTime * The time that the experiment ended. */ public void setEndTime(java.util.Date endTime) { this.endTime = endTime; } /** *

* The time that the experiment ended. *

* * @return The time that the experiment ended. */ public java.util.Date getEndTime() { return this.endTime; } /** *

* The time that the experiment ended. *

* * @param endTime * The time that the experiment ended. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withEndTime(java.util.Date endTime) { setEndTime(endTime); return this; } /** *

* The tags for the experiment. *

* * @return The tags for the experiment. */ public java.util.Map getTags() { return tags; } /** *

* The tags for the experiment. *

* * @param tags * The tags for the experiment. */ public void setTags(java.util.Map tags) { this.tags = tags; } /** *

* The tags for the experiment. *

* * @param tags * The tags for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withTags(java.util.Map tags) { setTags(tags); return this; } /** * Add a single Tags entry * * @see Experiment#withTags * @returns a reference to this object so that method calls can be chained together. */ public Experiment addTagsEntry(String key, String value) { if (null == this.tags) { this.tags = new java.util.HashMap(); } if (this.tags.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.tags.put(key, value); return this; } /** * Removes all the entries added into Tags. * * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment clearTagsEntries() { this.tags = null; return this; } /** *

* The configuration for experiment logging. *

* * @param logConfiguration * The configuration for experiment logging. */ public void setLogConfiguration(ExperimentLogConfiguration logConfiguration) { this.logConfiguration = logConfiguration; } /** *

* The configuration for experiment logging. *

* * @return The configuration for experiment logging. */ public ExperimentLogConfiguration getLogConfiguration() { return this.logConfiguration; } /** *

* The configuration for experiment logging. *

* * @param logConfiguration * The configuration for experiment logging. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withLogConfiguration(ExperimentLogConfiguration logConfiguration) { setLogConfiguration(logConfiguration); return this; } /** *

* The experiment options for the experiment. *

* * @param experimentOptions * The experiment options for the experiment. */ public void setExperimentOptions(ExperimentOptions experimentOptions) { this.experimentOptions = experimentOptions; } /** *

* The experiment options for the experiment. *

* * @return The experiment options for the experiment. */ public ExperimentOptions getExperimentOptions() { return this.experimentOptions; } /** *

* The experiment options for the experiment. *

* * @param experimentOptions * The experiment options for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withExperimentOptions(ExperimentOptions experimentOptions) { setExperimentOptions(experimentOptions); return this; } /** *

* The count of target account configurations for the experiment. *

* * @param targetAccountConfigurationsCount * The count of target account configurations for the experiment. */ public void setTargetAccountConfigurationsCount(Long targetAccountConfigurationsCount) { this.targetAccountConfigurationsCount = targetAccountConfigurationsCount; } /** *

* The count of target account configurations for the experiment. *

* * @return The count of target account configurations for the experiment. */ public Long getTargetAccountConfigurationsCount() { return this.targetAccountConfigurationsCount; } /** *

* The count of target account configurations for the experiment. *

* * @param targetAccountConfigurationsCount * The count of target account configurations for the experiment. * @return Returns a reference to this object so that method calls can be chained together. */ public Experiment withTargetAccountConfigurationsCount(Long targetAccountConfigurationsCount) { setTargetAccountConfigurationsCount(targetAccountConfigurationsCount); return this; } /** * 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. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getId() != null) sb.append("Id: ").append(getId()).append(","); if (getArn() != null) sb.append("Arn: ").append(getArn()).append(","); if (getExperimentTemplateId() != null) sb.append("ExperimentTemplateId: ").append(getExperimentTemplateId()).append(","); if (getRoleArn() != null) sb.append("RoleArn: ").append(getRoleArn()).append(","); if (getState() != null) sb.append("State: ").append(getState()).append(","); if (getTargets() != null) sb.append("Targets: ").append(getTargets()).append(","); if (getActions() != null) sb.append("Actions: ").append(getActions()).append(","); if (getStopConditions() != null) sb.append("StopConditions: ").append(getStopConditions()).append(","); if (getCreationTime() != null) sb.append("CreationTime: ").append(getCreationTime()).append(","); if (getStartTime() != null) sb.append("StartTime: ").append(getStartTime()).append(","); if (getEndTime() != null) sb.append("EndTime: ").append(getEndTime()).append(","); if (getTags() != null) sb.append("Tags: ").append(getTags()).append(","); if (getLogConfiguration() != null) sb.append("LogConfiguration: ").append(getLogConfiguration()).append(","); if (getExperimentOptions() != null) sb.append("ExperimentOptions: ").append(getExperimentOptions()).append(","); if (getTargetAccountConfigurationsCount() != null) sb.append("TargetAccountConfigurationsCount: ").append(getTargetAccountConfigurationsCount()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof Experiment == false) return false; Experiment other = (Experiment) obj; if (other.getId() == null ^ this.getId() == null) return false; if (other.getId() != null && other.getId().equals(this.getId()) == false) return false; if (other.getArn() == null ^ this.getArn() == null) return false; if (other.getArn() != null && other.getArn().equals(this.getArn()) == false) return false; if (other.getExperimentTemplateId() == null ^ this.getExperimentTemplateId() == null) return false; if (other.getExperimentTemplateId() != null && other.getExperimentTemplateId().equals(this.getExperimentTemplateId()) == false) return false; if (other.getRoleArn() == null ^ this.getRoleArn() == null) return false; if (other.getRoleArn() != null && other.getRoleArn().equals(this.getRoleArn()) == false) return false; if (other.getState() == null ^ this.getState() == null) return false; if (other.getState() != null && other.getState().equals(this.getState()) == false) return false; if (other.getTargets() == null ^ this.getTargets() == null) return false; if (other.getTargets() != null && other.getTargets().equals(this.getTargets()) == false) return false; if (other.getActions() == null ^ this.getActions() == null) return false; if (other.getActions() != null && other.getActions().equals(this.getActions()) == false) return false; if (other.getStopConditions() == null ^ this.getStopConditions() == null) return false; if (other.getStopConditions() != null && other.getStopConditions().equals(this.getStopConditions()) == false) return false; if (other.getCreationTime() == null ^ this.getCreationTime() == null) return false; if (other.getCreationTime() != null && other.getCreationTime().equals(this.getCreationTime()) == false) return false; if (other.getStartTime() == null ^ this.getStartTime() == null) return false; if (other.getStartTime() != null && other.getStartTime().equals(this.getStartTime()) == false) return false; if (other.getEndTime() == null ^ this.getEndTime() == null) return false; if (other.getEndTime() != null && other.getEndTime().equals(this.getEndTime()) == false) return false; if (other.getTags() == null ^ this.getTags() == null) return false; if (other.getTags() != null && other.getTags().equals(this.getTags()) == false) return false; if (other.getLogConfiguration() == null ^ this.getLogConfiguration() == null) return false; if (other.getLogConfiguration() != null && other.getLogConfiguration().equals(this.getLogConfiguration()) == false) return false; if (other.getExperimentOptions() == null ^ this.getExperimentOptions() == null) return false; if (other.getExperimentOptions() != null && other.getExperimentOptions().equals(this.getExperimentOptions()) == false) return false; if (other.getTargetAccountConfigurationsCount() == null ^ this.getTargetAccountConfigurationsCount() == null) return false; if (other.getTargetAccountConfigurationsCount() != null && other.getTargetAccountConfigurationsCount().equals(this.getTargetAccountConfigurationsCount()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getId() == null) ? 0 : getId().hashCode()); hashCode = prime * hashCode + ((getArn() == null) ? 0 : getArn().hashCode()); hashCode = prime * hashCode + ((getExperimentTemplateId() == null) ? 0 : getExperimentTemplateId().hashCode()); hashCode = prime * hashCode + ((getRoleArn() == null) ? 0 : getRoleArn().hashCode()); hashCode = prime * hashCode + ((getState() == null) ? 0 : getState().hashCode()); hashCode = prime * hashCode + ((getTargets() == null) ? 0 : getTargets().hashCode()); hashCode = prime * hashCode + ((getActions() == null) ? 0 : getActions().hashCode()); hashCode = prime * hashCode + ((getStopConditions() == null) ? 0 : getStopConditions().hashCode()); hashCode = prime * hashCode + ((getCreationTime() == null) ? 0 : getCreationTime().hashCode()); hashCode = prime * hashCode + ((getStartTime() == null) ? 0 : getStartTime().hashCode()); hashCode = prime * hashCode + ((getEndTime() == null) ? 0 : getEndTime().hashCode()); hashCode = prime * hashCode + ((getTags() == null) ? 0 : getTags().hashCode()); hashCode = prime * hashCode + ((getLogConfiguration() == null) ? 0 : getLogConfiguration().hashCode()); hashCode = prime * hashCode + ((getExperimentOptions() == null) ? 0 : getExperimentOptions().hashCode()); hashCode = prime * hashCode + ((getTargetAccountConfigurationsCount() == null) ? 0 : getTargetAccountConfigurationsCount().hashCode()); return hashCode; } @Override public Experiment clone() { try { return (Experiment) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.fis.model.transform.ExperimentMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy