与执行器集成
生成构建信息
弹簧靴执行器的info
端点在存在META-INF/build-info.properties
文件。
一个BuildInfo
任务来生成此文件。
使用该任务的最简单方法是通过插件的 DSL:
-
Groovy
-
Kotlin
springBoot {
buildInfo()
}
springBoot {
buildInfo()
}
这将配置一个BuildInfo
名为bootBuildInfo
并且,如果存在,则使 Java 插件的classes
任务取决于它。
任务的目标目录将是META-INF
在主源代码集资源的输出目录中(通常build/resources/main
).
默认情况下,生成的构建信息派生自项目:
属性 | 默认值 |
---|---|
|
的基本名称 |
|
项目组 |
|
项目名称 |
|
项目版本 |
|
项目建设时间 |
可以使用 DSL 自定义属性:
-
Groovy
-
Kotlin
springBoot {
buildInfo {
properties {
artifact = 'example-app'
version = '1.2.3'
group = 'com.example'
name = 'Example application'
}
}
}
springBoot {
buildInfo {
properties {
artifact.set("example-app")
version.set("1.2.3")
group.set("com.example")
name.set("Example application")
}
}
}
若要从生成的生成信息中排除任何默认属性,请将其名称添加到排除项中。
例如,time
属性可以按如下方式排除:
-
Groovy
-
Kotlin
springBoot {
buildInfo {
excludes = ['time']
}
}
springBoot {
buildInfo {
excludes.set(setOf("time"))
}
}
的默认值build.time
是构建项目的瞬间。
这样做的副作用是任务永远不会是最新的。
因此,由于必须执行更多任务(包括项目的测试),构建将需要更长的时间。
另一个副作用是任务的输出总是会改变,因此,构建将不是真正可重复的。
如果您更看重构建性能或可重复性,而不是build.time
属性,排除time
属性,如前面的示例所示。
还可以将其他属性添加到生成信息中:
-
Groovy
-
Kotlin
springBoot {
buildInfo {
properties {
additional = [
'a': 'alpha',
'b': 'bravo'
]
}
}
}
springBoot {
buildInfo {
properties {
additional.set(mapOf(
"a" to "alpha",
"b" to "bravo"
))
}
}
}
可以使用Provider
.