com.sandpolis.core.instance.OutcomeSet Maven / Gradle / Ivy
/******************************************************************************
* *
* Copyright 2017 Subterranean Security *
* *
* 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.sandpolis.core.instance;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
import com.sandpolis.core.proto.util.Result.Outcome;
/**
* A {@link Set} of {@link Outcome}s representing the overall result of some
* larger action which may consist of multiple components.
*
* @author cilki
* @since 4.0.0
*/
public final class OutcomeSet extends HashSet {
private static final long serialVersionUID = 1L;
/**
* Add an outcome to the set.
*
* @param outcome
* The outcome to add
*/
public void add(Outcome.Builder outcome) {
add(outcome.build());
}
/**
* Get the current result.
*
* @return The overall outcome of the {@code OutcomeSet}
*/
public boolean getResult() {
for (Outcome outcome : this)
if (!outcome.getResult())
return false;
return true;
}
/**
* Get one of the failed outcomes.
*
* @return A failed outcome or {@code null} if all outcomes succeeded
*/
public Outcome getOneFailed() {
return stream().filter(outcome -> !outcome.getResult()).findAny().orElse(null);
}
/**
* Get all failed outcomes.
*
* @return A list of all failed outcomes in the {@code OutcomeSet}
*/
public List getFailed() {
return stream().filter(outcome -> !outcome.getResult()).collect(Collectors.toList());
}
/**
* Get all passed outcomes.
*
* @return A list of all passed outcomes in the {@code OutcomeSet}
*/
public List getPassed() {
return stream().filter(outcome -> outcome.getResult()).collect(Collectors.toList());
}
/**
* Get the total duration.
*
* @return The cumulative duration of all outcomes in the {@code OutcomeSet}.
*/
public long getTime() {
return stream().mapToLong(Outcome::getTime).sum();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy