com.urbanairship.api.experiments.model.Experiment Maven / Gradle / Ivy
/*
* Copyright (c) 2013-2017. Urban Airship and Contributors
*/
package com.urbanairship.api.experiments.model;
import com.google.common.base.Preconditions;
import com.google.common.collect.Lists;
import com.urbanairship.api.push.model.Campaigns;
import com.urbanairship.api.push.model.DeviceTypeData;
import com.urbanairship.api.push.model.Orchestration;
import com.urbanairship.api.push.model.audience.Selector;
import com.urbanairship.api.push.model.audience.SelectorType;
import com.urbanairship.api.push.model.notification.email.MessageType;
import java.math.BigDecimal;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
/**
* Represents a set of varied pushes to send as part of an A/B experiment.
*/
public final class Experiment extends ExperimentModelObject {
private final Optional name;
private final Optional description;
private final Optional control;
private final Selector audience;
private final DeviceTypeData deviceTypes;
private final List variants;
private final Optional orchestration;
private final Optional messageType;
private final Optional campaigns;
private Experiment(Builder builder) {
this.name = Optional.ofNullable(builder.name);
this.description = Optional.ofNullable(builder.description);
this.control = Optional.ofNullable(builder.control);
this.audience = builder.audience;
this.deviceTypes = builder.deviceTypes;
this.variants = builder.variants;
this.orchestration = Optional.ofNullable(builder.orchestration);
this.messageType = Optional.ofNullable(builder.messageType);
this.campaigns = Optional.ofNullable(builder.campaigns);
}
/**
* Experiment builder
*
* @return Builder
*/
public static Builder newBuilder() {
return new Builder();
}
/**
* Get the name of the experiment.
*
* @return an Optional String
*/
public Optional getName() {
return name;
}
/**
* Get the description for the experiment.
*
* @return an Optional String
*/
public Optional getDescription() {
return description;
}
/**
* Get the control group for the experiment. A control is a float between 0 and 1, e.g., 0.4,
* representing the proportion of the audience that will not receive a push.
* The remaining audience is split between the variants.
*
* @return an Optional BigDecimal
*/
public Optional getControl() {
return control;
}
/**
* Get the audience for the experiment.
*
* @return an Audience object
*/
public Selector getAudience() {
return audience;
}
/**
* Boolean indicating whether audience is SelectorType.ALL
*
* @return Boolean
*/
public boolean isBroadcast() {
return audience.getType().equals(SelectorType.ALL);
}
/**
* Get the device types for the experiment.
*
* @return a DeviceTypeData object
*/
public DeviceTypeData getDeviceTypes() {
return deviceTypes;
}
/**
* Get the variants for the experiment. A variant defines a push that will be sent to a subset of the experiment's
* audience.
*
* @return variants List<Variant>
*/
public List getVariants() {
return variants;
}
/**
* Get the orchestration for the experiment.
*
* @return an Orchestration object
*/
public Optional getOrchestration() {
return orchestration;
}
/**
* Get the message type for the experiment.
*
* @return an MessageType object
*/
public Optional getMessageType() {
return messageType;
}
/**
* Get the campaigns object for the experiment.
*
* @return an Campaigns object
*/
public Optional getCampaigns() {
return campaigns;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Experiment that = (Experiment) o;
return Objects.equals(name, that.name) &&
Objects.equals(description, that.description) &&
Objects.equals(control, that.control) &&
Objects.equals(audience, that.audience) &&
Objects.equals(deviceTypes, that.deviceTypes) &&
Objects.equals(variants, that.variants) &&
Objects.equals(orchestration, that.orchestration) &&
Objects.equals(messageType, that.messageType) &&
Objects.equals(campaigns, that.campaigns);
}
@Override
public int hashCode() {
return Objects.hash(name, description, control, audience, deviceTypes,
variants, orchestration, messageType, campaigns);
}
@Override
public String toString() {
return "Experiment{" +
"name=" + name +
", description=" + description +
", control=" + control +
", audience=" + audience +
", deviceTypes=" + deviceTypes +
", variants=" + variants +
", orchestration=" + orchestration +
", messageType=" + messageType +
", campaigns=" + campaigns +
'}';
}
/**
* Experiment Builder
*/
public static class Builder {
private String name = null;
private String description = null;
private BigDecimal control = null;
private Selector audience = null;
private DeviceTypeData deviceTypes = null;
private final List variants = Lists.newArrayList();
private Orchestration orchestration = null;
private MessageType messageType = null;
private Campaigns campaigns = null;
private Builder() {
}
/**
* Set the experiment name.
*
* @param name String
* @return Builder
*/
public Builder setName(String name) {
this.name = name;
return this;
}
/**
* Set the experiment description.
*
* @param description String
* @return Builder
*/
public Builder setDescription(String description) {
this.description = description;
return this;
}
/**
* Set the control group for the experiment. A control is a float between 0 and 1, e.g., 0.4,
* representing the proportion of the audience that will not receive a push.
* The remaining audience is split between the variants.
*
* @param control BigDecimal
* @return Builder
*/
public Builder setControl(BigDecimal control) {
this.control = control;
return this;
}
/**
* Set the audience for the experiment.
*
* @param audience Selector
* @return Builder
*/
public Builder setAudience(Selector audience) {
this.audience = audience;
return this;
}
/**
* Set the device types for the experiment.
*
* @param deviceTypes DeviceTypeData
* @return Builder
*/
public Builder setDeviceTypes(DeviceTypeData deviceTypes) {
this.deviceTypes = deviceTypes;
return this;
}
/**
* Add a variant to the experiment. A variant defines a push that will be sent to a subset of the experiment's
* audience.
*
* @param variant List<Variant>
* @return Builder
*/
public Builder addVariant(Variant variant) {
variants.add(variant);
return this;
}
public Builder addAllVariants(List variants) {
this.variants.addAll(variants);
return this;
}
/**
* Set the Orchestration for the experiment.
*
* @param orchestration Orchestration
* @return Builder
*/
public Builder setOrchestration(Orchestration orchestration) {
this.orchestration = orchestration;
return this;
}
/**
* Set the message type for the experiment.
*
* @param messageType MessageType
* @return Builder
*/
public Builder setMessageType(MessageType messageType) {
this.messageType = messageType;
return this;
}
/**
* Set the campaigns for the experiment.
*
* @param campaigns Campaigns
* @return Builder
*/
public Builder setCampaigns(Campaigns campaigns) {
this.campaigns = campaigns;
return this;
}
/**
* Build an Experiment object. Will fail if any of the following
* preconditions are not met.
*
* 1. Audience must be set.
* 2. DeviceTypes (device types) must be set.
* 3. At least one variant must be present.
*
*
* @return Experiment
* @throws IllegalArgumentException if illegal arguments are used
* @throws NullPointerException if audience, deviceTypes, or variants is not set
*/
public Experiment build() {
Preconditions.checkNotNull(audience, "'audience' must be set");
Preconditions.checkNotNull(deviceTypes,
"'device_types' must be set");
Preconditions.checkNotNull(variants,
"An experiment requires at least one variant.");
Preconditions.checkArgument(variants.size() > 0,
"At least one variant must be present.");
return new Experiment(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy