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

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

/*
 * Copyright 2010 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.api.Task
import org.gradle.api.internal.TaskInternal
import org.gradle.api.internal.project.ProjectInternal
import org.gradle.api.internal.tasks.TaskContainerInternal
import spock.lang.Specification

class TaskNameResolverTest extends Specification {
    def tasks = Mock(TaskContainerInternal)
    def project = Mock(ProjectInternal)

    def setup() {
        _ * project.getTasks() >> tasks
    }

    private final TaskNameResolver resolver = new TaskNameResolver()

    def "eagerly locates task with given name for single project"() {
        def task = task('task')

        when:
        def candidates = resolver.selectWithName('task', project, false)

        then:
        1 * tasks.discoverTasks()
        1 * tasks.names >> (['task'] as SortedSet)
        0 * tasks._

        when:
        def matches = asTasks(candidates)

        then:
        matches == [task]

        and:
        1 * tasks.getByName('task') >> task
        0 * tasks._
    }

    def "returns null when no task with given name for single project"() {
        given:
        tasks.names >> (['not-a-task'] as SortedSet)

        expect:
        resolver.selectWithName('task', project, false) == null
    }

    def "eagerly locates tasks with given name for multiple projects"() {
        given:
        def task1 = task('task')
        def task2 = task('task')
        def childTasks = Mock(TaskContainerInternal)
        def childProject = Mock(ProjectInternal) {
            _ * getTasks() >> childTasks
            _ * getChildProjects() >> [:]
        }

        _ * project.childProjects >> [child: childProject]

        when:
        def results = resolver.selectWithName('task', project, true)

        then:
        1 * tasks.discoverTasks()
        1 * childTasks.discoverTasks()
        1 * tasks.names >> (['task'] as SortedSet)
        1 * childTasks.names >> (['task'] as SortedSet)
        1 * tasks.getByName('task') >> task1
        1 * childTasks.getByName('task') >> task2
        0 * tasks._
        0 * childTasks._

        when:
        def matches = asTasks(results)

        then:
        matches == [task1, task2]

        and:
        0 * tasks._
        0 * childTasks._
    }

    def "does not select tasks in sub projects when task implies sub projects"() {
        given:
        def task1 = task('task')
        task1.impliesSubProjects >> true
        def childTasks = Mock(TaskContainerInternal)
        def childProject = Mock(ProjectInternal) {
            _ * getTasks() >> childTasks
            _ * getChildProjects() >> [:]
        }

        _ * project.childProjects >> [child: childProject]

        when:
        def results = resolver.selectWithName('task', project, true)

        then:
        1 * tasks.discoverTasks()
        1 * tasks.names >> (['task'] as SortedSet)
        1 * tasks.getByName('task') >> task1
        0 * tasks._
        0 * childTasks._

        when:
        def matches = asTasks(results)

        then:
        matches == [task1]

        and:
        0 * tasks._
        0 * childTasks._
    }

    def "locates tasks in child projects with given name when missing in starting project"() {
        given:
        def task1 = task('task')
        def childTasks = Mock(TaskContainerInternal)
        def childProject = Mock(ProjectInternal) {
            _ * getTasks() >> childTasks
            _ * getChildProjects() >> [:]
        }
        _ * project.childProjects >> [child: childProject]

        when:
        def results = resolver.selectWithName('task', project, true)

        then:
        1 * tasks.discoverTasks()
        1 * childTasks.discoverTasks()
        1 * tasks.names >> (['not-a-task'] as SortedSet)
        1 * tasks.findByName('task') >> null
        1 * childTasks.names >> (['task'] as SortedSet)
        1 * childTasks.getByName('task') >> task1
        0 * tasks._
        0 * childTasks._

        when:
        def matches = asTasks(results)

        then:
        matches == [task1]

        and:
        0 * tasks._
        0 * childTasks._
    }

    def "lazily locates all tasks for a single project"() {
        given:
        def task1 = task('task1')

        when:
        def result = resolver.selectAll(project, false)

        then:
        result.keySet() == ['task1', 'task2'] as Set

        and:
        1 * tasks.discoverTasks()
        1 * tasks.names >> (['task1', 'task2'] as SortedSet)
        0 * tasks._

        when:
        def matches = asTasks(result['task1'])

        then:
        matches == [task1]

        and:
        1 * tasks.getByName('task1') >> task1
        0 * tasks._
    }

    def "lazily locates all tasks for multiple projects"() {
        given:
        def task1 = task('task1')
        def task2 = task('task1')
        def childTasks = Mock(TaskContainerInternal)
        def childProject = Mock(ProjectInternal) {
            _ * getTasks() >> childTasks
            _ * getChildProjects() >> [:]
        }
        _ * project.childProjects >> [child: childProject]

        when:
        def result = resolver.selectAll(project, true)

        then:
        result.keySet() == ['task1', 'task2', 'task3'] as Set

        and:
        1 * tasks.discoverTasks()
        1 * tasks.names >> (['task1', 'task2'] as SortedSet)
        0 * tasks._
        1 * childTasks.discoverTasks()
        1 * childTasks.names >> (['task1', 'task3'] as SortedSet)
        0 * childTasks._

        when:
        def matches = asTasks(result['task1'])

        then:
        matches == [task1, task2]

        and:
        1 * tasks.names >> (['task1', 'task2'] as SortedSet)
        1 * tasks.getByName('task1') >> task1
        1 * childTasks.names >> (['task1', 'task3'] as SortedSet)
        1 * childTasks.getByName('task1') >> task2
        0 * tasks._
        0 * childTasks._
    }

    def "does not visit sub-projects when task implies sub-projects"() {
        given:
        def task1 = task('task1')
        task1.impliesSubProjects >> true
        def childTasks = Mock(TaskContainerInternal)
        def childProject = Mock(ProjectInternal) {
            _ * getTasks() >> childTasks
            _ * getChildProjects() >> [:]
        }
        _ * project.childProjects >> [child: childProject]

        when:
        def result = resolver.selectAll(project, true)

        then:
        result.keySet() == ['task1', 'task2', 'task3'] as Set

        and:
        1 * tasks.discoverTasks()
        1 * tasks.names >> (['task1', 'task2'] as SortedSet)
        0 * tasks._
        1 * childTasks.discoverTasks()
        1 * childTasks.names >> (['task1', 'task3'] as SortedSet)
        0 * childTasks._

        when:
        def matches = asTasks(result['task1'])

        then:
        matches == [task1]

        and:
        1 * tasks.names >> (['task1', 'task2'] as SortedSet)
        1 * tasks.getByName('task1') >> task1
        0 * tasks._
        0 * childTasks._
    }

    def task(String name, String description = "") {
        Stub(TaskInternal) { TaskInternal task ->
            _ * task.getName() >> name
            _ * task.getDescription() >> description
        }
    }

    private static List asTasks(TaskSelectionResult taskSelectionResult) {
        def result = []
        taskSelectionResult.collectTasks(result)
        return result
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy