Gradle之恋-任务2

时间:2024-03-25 20:06:38

由于任务作为Gradle的核心功能模块,多花点精力是值得的,本文继上一篇主要涉及到:任务的执行顺序、为任务添加组和描述、跳过任务、扩展任务属性、定义默认任务。

Gradle之恋-任务2

任务顺序

如果构建(build)不能在清理(clean)之前执行,因为这样无意义;构建之前必须先验证;做集成测试前先做单元测试等就必须指定其任务的执行顺序。

任务依赖的顺序

指定顺序不同于任务间的依赖顺序:依赖是影响那些任务执行,而顺序是影响这些要执行的任务之间的顺序。

task hello{
    doLast{
        print 'hello'
    }
}

task aline{
    doLast{
        print ' - '
    }
}

task world(dependsOn:[hello,aline]){
    doLast{
        println 'world!'
    }
}

当执行world任务时,执行的顺序是aline,hello,world,输出

- helloworld!

可见当任务有多个依赖时,会先执行被依赖的任务,而被依赖的任务执行顺序是依据任务名的字典顺序。你可以自定义顺序如

aline.mustRunAfter hello

则aline任务必须在hello之后执行,输出

hello - world!

指定顺序

指定顺序是通过两个关键词来设定的:mustRunAfter和shouldRunAfter,前者是严格指定的,而后者比较宽松,在两种情况下不按照指定的顺序执行:

  • 如果使用它产生循环顺序时,如指定了taskA在taskB之后,而又指定了taskB在taskA之后。
  • 这种情况官方文档貌似没说清楚?!!!后续再研究下源码看看。

    bash task taskX { doLast { println 'taskX' } } task taskY { doLast { println 'taskY' } } task taskZ { doLast { println 'taskZ' } } taskX.dependsOn taskY taskY.dependsOn taskZ taskZ.shouldRunAfter taskX

    执行

    $ gradle -q taskX

    taskZ

    taskY

    taskX

添加描述与组

可以通过关键词description和grou为任务添加描述和组,然后可以使用gradle tasks来查看,如果改任务没有组,则需要额外参数--all来查看。

task description{
    group 'mine'
    description 'this is just a description.'
}

查看

Mine tasks

----------

description - this is just a description.

替换任务

有时根据需要,你可能想替换一个任务,这个很简单:更加任务名进行重写:

task overwriteTask{
    doLast{
        println 'this is a str task';
    }
}

task overwriteTask(overwrite:true){
    doLast{
        println 'this is a new overwrite str task.'
    }
}

执行

$ gradle -q oT

this is a new overwrite str task.

跳过任务

Gradle提供多种跳过任务的方法,不仅有命令行形式的,还有代码级别的。

命令行

当你想跳过依赖的任务时,可以使用-x形式跳过,如执行build跳过单元测试时:

$ gradle build -x test
断言

你可以使用onlyIf()来做单元,当其返回值为true时被执行,否则跳过.

task hello{
    doLast{
        println 'hello world!'
    }
}

hello.onlyIf{!project.hasProperty('skipHello')}

当执行gradle hello -PskipHello 时,任务hello并不会执行。命令行参数-P为命令行设置property。

StopExecutionException

当任务抛出StopExecutionException将跳过任务继续执行下一个任务。

task hello{
    doLast{
        print 'hello '
    }
}
hello.doFirst{
    throw new StopExecutionException()
}

task world(dependsOn:hello){
    doLast{
        println 'world!'
    }
}

执行任务world即可看到效果。

enabled属性

每个任务都有一个enabled属性,设置为false将跳过。

task hello{
    doLast{
        print 'hello '
    }
}
hello.enabled = false

task world(dependsOn:hello){
    doLast{
        println 'world!'
    }
}

扩展属性

你可以通过ext来扩展任务的属性

task hello{
    ext.str="hello world!"
}

task say(){
    doLast{
        println hello.str
    }
}

默认任务

Gradle允许你使用关键词defaultTasks定义一个或多个任务作为默认任务,当没有任务指定时则执行默认任务。

defaultTasks 'hello','intro'

task hello{
    doLast{
        println 'hello,welcome to you!'
    }
}

task intro(){
    doLast{
        println 'my name is zhai'
    }
}

可以执行gradle -q来验证。

未完待续....


更多原创文章可关注我的个人博客:宅前疯 或微信公众账号

Gradle之恋-任务2

相关文章