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

org.gradle.execution.SelectedTaskExecutionActionTest.groovy Maven / Gradle / Ivy

/*
 * Copyright 2011 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.execution

import org.gradle.StartParameter
import org.gradle.api.Task
import org.gradle.api.internal.GradleInternal
import org.gradle.api.tasks.TaskState
import spock.lang.Specification

class SelectedTaskExecutionActionTest extends Specification {
    final SelectedTaskExecutionAction action = new SelectedTaskExecutionAction()
    final BuildExecutionContext context = Mock()
    final TaskGraphExecuter executer = Mock()
    final GradleInternal gradleInternal = Mock()
    final StartParameter startParameter = Mock()

    def setup() {
        _ * context.gradle >> gradleInternal
        _ * gradleInternal.taskGraph >> executer
        _ * gradleInternal.startParameter >> startParameter
    }

    def "executes selected tasks"() {
        given:
        _ * startParameter.continueOnFailure >> false

        when:
        action.execute(context)

        then:
        1 * executer.execute()
    }

    def "executes selected tasks when continue specified"() {
        given:
        _ * startParameter.continueOnFailure >> true

        when:
        action.execute(context)

        then:
        1 * executer.useFailureHandler(!null)
        1 * executer.execute()
    }

    def "adds failure handler that does not abort execution when continue specified"() {
        TaskFailureHandler handler
        RuntimeException failure = new RuntimeException()

        given:
        _ * startParameter.continueOnFailure >> true

        when:
        action.execute(context)

        then:
        1 * executer.useFailureHandler(!null) >> { handler = it[0] }
        1 * executer.execute() >> { handler.onTaskFailure(brokenTask(failure)) }
    }

    def brokenTask(Throwable failure) {
        Task task = Mock()
        TaskState state = Mock()
        _ * task.state >> state
        _ * state.failure >> failure
        _ * state.rethrowFailure() >> { throw failure }
        return task
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy