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

com.amazonaws.services.devicefarm.model.ScheduleRunConfiguration 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: 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.devicefarm.model;

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

/**
 * 

* Represents the settings for a run. Includes things like location, radio states, auxiliary apps, and network profiles. *

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

* The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to external * data for Android or the app's sandbox for iOS. *

*/ private String extraDataPackageArn; /** *

* Reserved for internal use. *

*/ private String networkProfileArn; /** *

* Information about the locale that is used for the run. *

*/ private String locale; /** *

* Information about the location that is used for the run. *

*/ private Location location; /** *

* An array of ARNs for your VPC endpoint configurations. *

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

* Input CustomerArtifactPaths object for the scheduled run configuration. *

*/ private CustomerArtifactPaths customerArtifactPaths; /** *

* Information about the radio states for the run. *

*/ private Radios radios; /** *

* A list of upload ARNs for app packages to be installed with your app. *

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

* Specifies the billing method for a test run: metered or unmetered. If the parameter is * not specified, the default value is metered. *

* *

* If you have purchased unmetered device slots, you must set this parameter to unmetered to make use * of them. Otherwise, your run counts against your metered time. *

*
*/ private String billingMethod; /** *

* The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to external * data for Android or the app's sandbox for iOS. *

* * @param extraDataPackageArn * The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to * external data for Android or the app's sandbox for iOS. */ public void setExtraDataPackageArn(String extraDataPackageArn) { this.extraDataPackageArn = extraDataPackageArn; } /** *

* The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to external * data for Android or the app's sandbox for iOS. *

* * @return The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to * external data for Android or the app's sandbox for iOS. */ public String getExtraDataPackageArn() { return this.extraDataPackageArn; } /** *

* The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to external * data for Android or the app's sandbox for iOS. *

* * @param extraDataPackageArn * The ARN of the extra data for the run. The extra data is a .zip file that AWS Device Farm extracts to * external data for Android or the app's sandbox for iOS. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withExtraDataPackageArn(String extraDataPackageArn) { setExtraDataPackageArn(extraDataPackageArn); return this; } /** *

* Reserved for internal use. *

* * @param networkProfileArn * Reserved for internal use. */ public void setNetworkProfileArn(String networkProfileArn) { this.networkProfileArn = networkProfileArn; } /** *

* Reserved for internal use. *

* * @return Reserved for internal use. */ public String getNetworkProfileArn() { return this.networkProfileArn; } /** *

* Reserved for internal use. *

* * @param networkProfileArn * Reserved for internal use. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withNetworkProfileArn(String networkProfileArn) { setNetworkProfileArn(networkProfileArn); return this; } /** *

* Information about the locale that is used for the run. *

* * @param locale * Information about the locale that is used for the run. */ public void setLocale(String locale) { this.locale = locale; } /** *

* Information about the locale that is used for the run. *

* * @return Information about the locale that is used for the run. */ public String getLocale() { return this.locale; } /** *

* Information about the locale that is used for the run. *

* * @param locale * Information about the locale that is used for the run. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withLocale(String locale) { setLocale(locale); return this; } /** *

* Information about the location that is used for the run. *

* * @param location * Information about the location that is used for the run. */ public void setLocation(Location location) { this.location = location; } /** *

* Information about the location that is used for the run. *

* * @return Information about the location that is used for the run. */ public Location getLocation() { return this.location; } /** *

* Information about the location that is used for the run. *

* * @param location * Information about the location that is used for the run. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withLocation(Location location) { setLocation(location); return this; } /** *

* An array of ARNs for your VPC endpoint configurations. *

* * @return An array of ARNs for your VPC endpoint configurations. */ public java.util.List getVpceConfigurationArns() { return vpceConfigurationArns; } /** *

* An array of ARNs for your VPC endpoint configurations. *

* * @param vpceConfigurationArns * An array of ARNs for your VPC endpoint configurations. */ public void setVpceConfigurationArns(java.util.Collection vpceConfigurationArns) { if (vpceConfigurationArns == null) { this.vpceConfigurationArns = null; return; } this.vpceConfigurationArns = new java.util.ArrayList(vpceConfigurationArns); } /** *

* An array of ARNs for your VPC endpoint configurations. *

*

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

* * @param vpceConfigurationArns * An array of ARNs for your VPC endpoint configurations. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withVpceConfigurationArns(String... vpceConfigurationArns) { if (this.vpceConfigurationArns == null) { setVpceConfigurationArns(new java.util.ArrayList(vpceConfigurationArns.length)); } for (String ele : vpceConfigurationArns) { this.vpceConfigurationArns.add(ele); } return this; } /** *

* An array of ARNs for your VPC endpoint configurations. *

* * @param vpceConfigurationArns * An array of ARNs for your VPC endpoint configurations. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withVpceConfigurationArns(java.util.Collection vpceConfigurationArns) { setVpceConfigurationArns(vpceConfigurationArns); return this; } /** *

* Input CustomerArtifactPaths object for the scheduled run configuration. *

* * @param customerArtifactPaths * Input CustomerArtifactPaths object for the scheduled run configuration. */ public void setCustomerArtifactPaths(CustomerArtifactPaths customerArtifactPaths) { this.customerArtifactPaths = customerArtifactPaths; } /** *

* Input CustomerArtifactPaths object for the scheduled run configuration. *

* * @return Input CustomerArtifactPaths object for the scheduled run configuration. */ public CustomerArtifactPaths getCustomerArtifactPaths() { return this.customerArtifactPaths; } /** *

* Input CustomerArtifactPaths object for the scheduled run configuration. *

* * @param customerArtifactPaths * Input CustomerArtifactPaths object for the scheduled run configuration. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withCustomerArtifactPaths(CustomerArtifactPaths customerArtifactPaths) { setCustomerArtifactPaths(customerArtifactPaths); return this; } /** *

* Information about the radio states for the run. *

* * @param radios * Information about the radio states for the run. */ public void setRadios(Radios radios) { this.radios = radios; } /** *

* Information about the radio states for the run. *

* * @return Information about the radio states for the run. */ public Radios getRadios() { return this.radios; } /** *

* Information about the radio states for the run. *

* * @param radios * Information about the radio states for the run. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withRadios(Radios radios) { setRadios(radios); return this; } /** *

* A list of upload ARNs for app packages to be installed with your app. *

* * @return A list of upload ARNs for app packages to be installed with your app. */ public java.util.List getAuxiliaryApps() { return auxiliaryApps; } /** *

* A list of upload ARNs for app packages to be installed with your app. *

* * @param auxiliaryApps * A list of upload ARNs for app packages to be installed with your app. */ public void setAuxiliaryApps(java.util.Collection auxiliaryApps) { if (auxiliaryApps == null) { this.auxiliaryApps = null; return; } this.auxiliaryApps = new java.util.ArrayList(auxiliaryApps); } /** *

* A list of upload ARNs for app packages to be installed with your app. *

*

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

* * @param auxiliaryApps * A list of upload ARNs for app packages to be installed with your app. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withAuxiliaryApps(String... auxiliaryApps) { if (this.auxiliaryApps == null) { setAuxiliaryApps(new java.util.ArrayList(auxiliaryApps.length)); } for (String ele : auxiliaryApps) { this.auxiliaryApps.add(ele); } return this; } /** *

* A list of upload ARNs for app packages to be installed with your app. *

* * @param auxiliaryApps * A list of upload ARNs for app packages to be installed with your app. * @return Returns a reference to this object so that method calls can be chained together. */ public ScheduleRunConfiguration withAuxiliaryApps(java.util.Collection auxiliaryApps) { setAuxiliaryApps(auxiliaryApps); return this; } /** *

* Specifies the billing method for a test run: metered or unmetered. If the parameter is * not specified, the default value is metered. *

* *

* If you have purchased unmetered device slots, you must set this parameter to unmetered to make use * of them. Otherwise, your run counts against your metered time. *

*
* * @param billingMethod * Specifies the billing method for a test run: metered or unmetered. If the * parameter is not specified, the default value is metered.

*

* If you have purchased unmetered device slots, you must set this parameter to unmetered to * make use of them. Otherwise, your run counts against your metered time. *

* @see BillingMethod */ public void setBillingMethod(String billingMethod) { this.billingMethod = billingMethod; } /** *

* Specifies the billing method for a test run: metered or unmetered. If the parameter is * not specified, the default value is metered. *

* *

* If you have purchased unmetered device slots, you must set this parameter to unmetered to make use * of them. Otherwise, your run counts against your metered time. *

*
* * @return Specifies the billing method for a test run: metered or unmetered. If the * parameter is not specified, the default value is metered.

*

* If you have purchased unmetered device slots, you must set this parameter to unmetered to * make use of them. Otherwise, your run counts against your metered time. *

* @see BillingMethod */ public String getBillingMethod() { return this.billingMethod; } /** *

* Specifies the billing method for a test run: metered or unmetered. If the parameter is * not specified, the default value is metered. *

* *

* If you have purchased unmetered device slots, you must set this parameter to unmetered to make use * of them. Otherwise, your run counts against your metered time. *

*
* * @param billingMethod * Specifies the billing method for a test run: metered or unmetered. If the * parameter is not specified, the default value is metered.

*

* If you have purchased unmetered device slots, you must set this parameter to unmetered to * make use of them. Otherwise, your run counts against your metered time. *

* @return Returns a reference to this object so that method calls can be chained together. * @see BillingMethod */ public ScheduleRunConfiguration withBillingMethod(String billingMethod) { setBillingMethod(billingMethod); return this; } /** *

* Specifies the billing method for a test run: metered or unmetered. If the parameter is * not specified, the default value is metered. *

* *

* If you have purchased unmetered device slots, you must set this parameter to unmetered to make use * of them. Otherwise, your run counts against your metered time. *

*
* * @param billingMethod * Specifies the billing method for a test run: metered or unmetered. If the * parameter is not specified, the default value is metered.

*

* If you have purchased unmetered device slots, you must set this parameter to unmetered to * make use of them. Otherwise, your run counts against your metered time. *

* @see BillingMethod */ public void setBillingMethod(BillingMethod billingMethod) { withBillingMethod(billingMethod); } /** *

* Specifies the billing method for a test run: metered or unmetered. If the parameter is * not specified, the default value is metered. *

* *

* If you have purchased unmetered device slots, you must set this parameter to unmetered to make use * of them. Otherwise, your run counts against your metered time. *

*
* * @param billingMethod * Specifies the billing method for a test run: metered or unmetered. If the * parameter is not specified, the default value is metered.

*

* If you have purchased unmetered device slots, you must set this parameter to unmetered to * make use of them. Otherwise, your run counts against your metered time. *

* @return Returns a reference to this object so that method calls can be chained together. * @see BillingMethod */ public ScheduleRunConfiguration withBillingMethod(BillingMethod billingMethod) { this.billingMethod = billingMethod.toString(); 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 (getExtraDataPackageArn() != null) sb.append("ExtraDataPackageArn: ").append(getExtraDataPackageArn()).append(","); if (getNetworkProfileArn() != null) sb.append("NetworkProfileArn: ").append(getNetworkProfileArn()).append(","); if (getLocale() != null) sb.append("Locale: ").append(getLocale()).append(","); if (getLocation() != null) sb.append("Location: ").append(getLocation()).append(","); if (getVpceConfigurationArns() != null) sb.append("VpceConfigurationArns: ").append(getVpceConfigurationArns()).append(","); if (getCustomerArtifactPaths() != null) sb.append("CustomerArtifactPaths: ").append(getCustomerArtifactPaths()).append(","); if (getRadios() != null) sb.append("Radios: ").append(getRadios()).append(","); if (getAuxiliaryApps() != null) sb.append("AuxiliaryApps: ").append(getAuxiliaryApps()).append(","); if (getBillingMethod() != null) sb.append("BillingMethod: ").append(getBillingMethod()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof ScheduleRunConfiguration == false) return false; ScheduleRunConfiguration other = (ScheduleRunConfiguration) obj; if (other.getExtraDataPackageArn() == null ^ this.getExtraDataPackageArn() == null) return false; if (other.getExtraDataPackageArn() != null && other.getExtraDataPackageArn().equals(this.getExtraDataPackageArn()) == false) return false; if (other.getNetworkProfileArn() == null ^ this.getNetworkProfileArn() == null) return false; if (other.getNetworkProfileArn() != null && other.getNetworkProfileArn().equals(this.getNetworkProfileArn()) == false) return false; if (other.getLocale() == null ^ this.getLocale() == null) return false; if (other.getLocale() != null && other.getLocale().equals(this.getLocale()) == false) return false; if (other.getLocation() == null ^ this.getLocation() == null) return false; if (other.getLocation() != null && other.getLocation().equals(this.getLocation()) == false) return false; if (other.getVpceConfigurationArns() == null ^ this.getVpceConfigurationArns() == null) return false; if (other.getVpceConfigurationArns() != null && other.getVpceConfigurationArns().equals(this.getVpceConfigurationArns()) == false) return false; if (other.getCustomerArtifactPaths() == null ^ this.getCustomerArtifactPaths() == null) return false; if (other.getCustomerArtifactPaths() != null && other.getCustomerArtifactPaths().equals(this.getCustomerArtifactPaths()) == false) return false; if (other.getRadios() == null ^ this.getRadios() == null) return false; if (other.getRadios() != null && other.getRadios().equals(this.getRadios()) == false) return false; if (other.getAuxiliaryApps() == null ^ this.getAuxiliaryApps() == null) return false; if (other.getAuxiliaryApps() != null && other.getAuxiliaryApps().equals(this.getAuxiliaryApps()) == false) return false; if (other.getBillingMethod() == null ^ this.getBillingMethod() == null) return false; if (other.getBillingMethod() != null && other.getBillingMethod().equals(this.getBillingMethod()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getExtraDataPackageArn() == null) ? 0 : getExtraDataPackageArn().hashCode()); hashCode = prime * hashCode + ((getNetworkProfileArn() == null) ? 0 : getNetworkProfileArn().hashCode()); hashCode = prime * hashCode + ((getLocale() == null) ? 0 : getLocale().hashCode()); hashCode = prime * hashCode + ((getLocation() == null) ? 0 : getLocation().hashCode()); hashCode = prime * hashCode + ((getVpceConfigurationArns() == null) ? 0 : getVpceConfigurationArns().hashCode()); hashCode = prime * hashCode + ((getCustomerArtifactPaths() == null) ? 0 : getCustomerArtifactPaths().hashCode()); hashCode = prime * hashCode + ((getRadios() == null) ? 0 : getRadios().hashCode()); hashCode = prime * hashCode + ((getAuxiliaryApps() == null) ? 0 : getAuxiliaryApps().hashCode()); hashCode = prime * hashCode + ((getBillingMethod() == null) ? 0 : getBillingMethod().hashCode()); return hashCode; } @Override public ScheduleRunConfiguration clone() { try { return (ScheduleRunConfiguration) 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.devicefarm.model.transform.ScheduleRunConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy