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

com.spotify.helios.common.descriptors.RolloutOptions Maven / Gradle / Ivy

There is a newer version: 0.9.283
Show newest version
/*-
 * -\-\-
 * Helios Client
 * --
 * Copyright (C) 2016 Spotify AB
 * --
 * 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 com.spotify.helios.common.descriptors;

import static com.google.common.base.MoreObjects.firstNonNull;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.util.Objects;
import java.util.concurrent.TimeUnit;
import org.jetbrains.annotations.Nullable;

/**
 * Represents a deployment group's rollout options.
 *
 * 

An sample expression of it in JSON might be: *

 * {
 *   "migrate": false,
 *   "parallelism": 2,
 *   "timeout": 1000,
 *   "overlap": true,
 *   "token": "insecure-access-token",
 *   "ignoreFailures": false
 * }
 * 
*/ @JsonIgnoreProperties(ignoreUnknown = true) public class RolloutOptions { private static final long DEFAULT_TIMEOUT = TimeUnit.MINUTES.toSeconds(5); private static final int DEFAULT_PARALLELISM = 1; static final boolean DEFAULT_MIGRATE = false; private static final boolean DEFAULT_OVERLAP = false; static final String DEFAULT_TOKEN = Job.EMPTY_TOKEN; static final boolean DEFAULT_IGNORE_FAILURES = false; private static final RolloutOptions DEFAULT = RolloutOptions.newBuilder() .setTimeout(DEFAULT_TIMEOUT) .setParallelism(DEFAULT_PARALLELISM) .setMigrate(DEFAULT_MIGRATE) .setOverlap(DEFAULT_OVERLAP) .setToken(DEFAULT_TOKEN) .setIgnoreFailures(DEFAULT_IGNORE_FAILURES) .build(); private final Long timeout; private final Integer parallelism; private final Boolean migrate; private final Boolean overlap; private final String token; private final Boolean ignoreFailures; private RolloutOptions(@JsonProperty("timeout") @Nullable final Long timeout, @JsonProperty("parallelism") @Nullable final Integer parallelism, @JsonProperty("migrate") @Nullable final Boolean migrate, @JsonProperty("overlap") @Nullable final Boolean overlap, @JsonProperty("token") @Nullable final String token, @JsonProperty("ignoreFailures") @Nullable final Boolean ignoreFailures) { this.timeout = timeout; this.parallelism = parallelism; this.migrate = migrate; this.overlap = overlap; this.token = token; this.ignoreFailures = ignoreFailures; } public static RolloutOptions getDefault() { return DEFAULT; } public static Builder newBuilder() { return new Builder(); } public Builder toBuilder() { return new Builder() .setTimeout(timeout) .setParallelism(parallelism) .setMigrate(migrate) .setOverlap(overlap) .setToken(token) .setIgnoreFailures(ignoreFailures); } /** * Return a new RolloutOptions instance by merging this instance with another one. * @throws NullPointerException if any attribute in both instances are null. */ public RolloutOptions withFallback(final RolloutOptions that) { return RolloutOptions.newBuilder() .setTimeout(firstNonNull(timeout, that.timeout)) .setParallelism(firstNonNull(parallelism, that.parallelism)) .setMigrate(firstNonNull(migrate, that.migrate)) .setOverlap(firstNonNull(overlap, that.overlap)) .setToken(firstNonNull(token, that.token)) .setIgnoreFailures(firstNonNull(ignoreFailures, that.ignoreFailures)) .build(); } @Nullable public Long getTimeout() { return timeout; } @Nullable public Integer getParallelism() { return parallelism; } @Nullable public Boolean getMigrate() { return migrate; } @Nullable public Boolean getOverlap() { return overlap; } @Nullable public String getToken() { return token; } @Nullable public Boolean getIgnoreFailures() { return ignoreFailures; } @Override public boolean equals(final Object obj) { if (this == obj) { return true; } if (obj == null || getClass() != obj.getClass()) { return false; } final RolloutOptions that = (RolloutOptions) obj; return Objects.equals(this.migrate, that.migrate) && Objects.equals(this.parallelism, that.parallelism) && Objects.equals(this.timeout, that.timeout) && Objects.equals(this.overlap, that.overlap) && Objects.equals(this.token, that.token) && Objects.equals(this.ignoreFailures, that.ignoreFailures); } @Override public int hashCode() { return Objects.hash(timeout, parallelism, migrate, overlap, token, ignoreFailures); } @Override public String toString() { return "RolloutOptions{" + "timeout=" + timeout + ", parallelism=" + parallelism + ", migrate=" + migrate + ", overlap=" + overlap + ", token=" + token + ", ignoreFailures=" + ignoreFailures + '}'; } public static class Builder { private Long timeout; private Integer parallelism; private Boolean migrate; private Boolean overlap; private String token; private Boolean ignoreFailures; public Builder() { } public Builder setTimeout(final Long timeout) { this.timeout = timeout; return this; } public Builder setParallelism(final Integer parallelism) { this.parallelism = parallelism; return this; } public Builder setMigrate(final Boolean migrate) { this.migrate = migrate; return this; } public Builder setOverlap(final Boolean overlap) { this.overlap = overlap; return this; } public Builder setToken(final String token) { this.token = token; return this; } public Builder setIgnoreFailures(final Boolean ignoreFailures) { this.ignoreFailures = ignoreFailures; return this; } public RolloutOptions build() { return new RolloutOptions(timeout, parallelism, migrate, overlap, token, ignoreFailures); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy