/*
* Copyright 2015 the original author or authors.
*
* 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 org.gradle.testkit.runner;
import org.gradle.api.Incubating;
/**
* The outcome of executing a task during a build.
*
* @since 2.6
* @see BuildTask#getOutcome()
*/
@Incubating
public enum TaskOutcome {
/**
* The task executed and performed its actions without failure.
*/
SUCCESS,
/**
* The task attempted to execute, but did not complete successfully.
*/
FAILED,
/**
* The task was not executed, as its output was up to date.
*/
UP_TO_DATE,
/**
* The task was not executed due to some reason.
*
* For Gradle version < 3.4, a task may be skipped if it had no work to do (e.g. no source to compile).
*/
SKIPPED,
/**
* The task executed, but did not perform work as its output was found in a build cache.
* <p>
* This outcome only occurs when the build under test has been configured for
* <a href="https://docs.gradle.org/current/userguide/build_cache.html#sec:task_output_caching" target="_top">task output caching</a>.
* </p>
* <p>NOTE: If the Gradle version used for the build under test is older than 3.3,
* no tasks will have this outcome.</p>
*
* @since 3.3
*/
FROM_CACHE,
/**
* The task was skipped due to all input files declared with {@code @SkipWhenEmpty} being empty.
*
* @since 3.4
*/
NO_SOURCE
}