标签
名字
一个字母数字标识步骤的字符串(允许使用下划线)。
类型
必须MvnBuild
对于这一步,输入:
配置
指定步骤执行环境的所有配置选择。此步骤继承Bash/PowerShell步骤配置标签,包括这些相关的标签:
标签 |
使用说明 |
必需的/可选 |
---|---|---|
集成 |
必须指定Artifactory集成 | 要求 |
input2022世界杯阿根廷预选赛赛程Resources |
必须指定一个GitRepo资源。mvn命令在Git存储库中的文件上执行构建 还可以选择指定文件规范资源,该资源指定要复制到的文件 |
要求 |
output2022世界杯阿根廷预选赛赛程Resources |
必须指定BuildInfo资源如果 |
可能需要 |
此外,可以定义这些标签来支持步骤的本机操作:
标签 |
使用说明 |
必需的/可选 |
---|---|---|
mvnCommand |
指定要与Maven一起使用的选项的命令行字符串。 默认是 |
可选 |
sourceLocation |
指定源文件的位置。默认情况下,它被设置为GitRepo资源的根目录。D默认为GitRepo的根目录。 如果源文件不在根目录下,则需要。 |
可能需要 |
resolverSnapshotRepo |
用于解析快照依赖关系的人工存储库。如果设置, 不要与…一起使用 |
可选 |
resolverReleaseRepo |
用于解析版本依赖关系的人工存储库。如果设置, 不要与…一起使用 |
可选 |
deployerSnapshotRepo |
MvnBuild创建的快照构件被上传到这个Artifactory存储库。如果设置, 不要与…一起使用 |
可选 |
deployerReleaseRepo |
由MvnBuild创建的发布构件被上传到这个Artifactory存储库。如果设置,则使用deployerSnapshot 不要与…一起使用 |
可选 |
forceXrayScan |
当设置为 |
可选 |
failOnScan |
当设置为 |
可选 |
autoPublishBuildInfo |
当设置为 |
可选 |
configFileName |
JFrog命令行mvn-config文件的名称。的 只有当您已将此配置文件提交到源文件时,才应该使用此选项 |
可选 |
configFileLocation |
指定包含JFrog CLI mvn-config文件的目录,相对于 只有当您已将此配置文件提交到源文件时,才应该使用此选项 |
可选 |
执行
声明要在执行前和执行后阶段执行的shell命令序列的集合:标签 | 使用说明 | 必需的/可选 |
---|---|---|
onStart |
在本机操作之前执行的命令 | 可选 |
调用onSuccess |
成功完成时执行的命令 | 可选 |
onFailure |
完成失败时执行的命令 | 可选 |
onComplete |
在任何补全时执行的命令 | 可选 |
执行的操作onExecute
阶段是此步骤类型所固有的,并且不能被覆盖。
例子
下面的示例展示了配置MvnBuild步骤的几种方法。
全管道示例
- 这个例子需要Artifactory集成和一个GitHub集成。
- 这个示例的管道DSL是可以在这个存储库在JFrogGitHub帐户。
- 有关完整教程,请参见管道示例:Maven Build。
这个配置文件是模板化的,所以它可以很容易地定制。值可以与值一起提供。yml文件。template: true #本地模板需要valuesFilePath: ./values。—名称:2022世界杯阿根廷预选赛赛程mvn_repo类型:GitRepo配置:路径:{{。repoPath}} gitProvider: {{. values。gitProvider}} -名称:mvn_build_info类型:BuildInfo配置:sourceArtifactory: {{. values。一个rtifactory }} pipelines: - name: demo_maven steps: - name: mvn_build_step type: MvnBuild configuration: deployerSnapshotRepo: {{ .Values.deployerRepo }} deployerReleaseRepo: {{ .Values.deployerRepo }} inputResources: - name: mvn_repo integrations: - name: {{ .Values.artifactory }} - name: publish_build type: PublishBuildInfo configuration: forceXrayScan: false inputSteps: - name: mvn_build_step outputResources: - name: mvn_build_info
使用默认值的基本示例
MvnBuild最基本的形式。使用所有默认值。元素中指定的repo的根目录input2022世界杯阿根廷预选赛赛程Resources
数组,并执行MVN清洁安装
。它不发布构建或请求x射线扫描。
管道:—名称:MyMavenPipeline步骤:—名称:MavenWithArtifactory类型:MvnBuild配置:集成:—名称:art inputResources:—名称:mvn_repo2022世界杯阿根廷预选赛赛程
使用Artifactory作为解析器和部署器
本例使用Artifactory作为解析器和部署器,这样您的项目的依赖项就会从指定的repo中提取出来,并将生成的工件推回Artifactory。它还向Artifactory发布构建信息,并请求进行x射线扫描。
管道:—名称:MyMavenPipeline步骤:—名称:MavenWithAll类型:MvnBuild配置:集成:—名称:art inputResources:—名称:mvn_repo outputResources:—名称:mvn_build_2022世界杯阿根廷预选赛赛程info mvnCommand: clean install test sourceLocation: mvnproject resolverSnapshotRepo:快照-remote-maven resolverReleaseRepo:释放-remote-maven deployerSnapshotRepo:快照-local-maven deployerReleaseRepo:释放-local-maven forceXrayScan: true failOnScan: true autoPublishBuildInfo: true
使用配置文件
这个例子使用一个已提交的配置文件来完成与上面相同的事情示例2所做的事。
管道:-名称:MyMavenPipeline步骤:-名称:MvnWithConfig类型:MvnBuild配置:集成:-名称:art inputResources: -名称:mvn_repo outputResources: -名称:mvn_buil2022世界杯阿根廷预选赛赛程d_info mvnCommand: clean install test sourceLocation: mvnproject configFileLocation: "." configFileName: mvn-art-config forceXrayScan: true failOnScan: true autoPublishBuildInfo: true
它是如何工作的
当你使用MvnBuild管道中的原生步骤,它在后台执行以下操作:
jfrog rt配置#配置jfrog CLI yaml中列出与集成jfrog rt mvn-config #如果configFileName configFileLocation没有设置在yaml jfrog rt mvn mvnCommand #主要maven构建命令add_run_variables #美元节省一些信息在运行状态下对未来步骤参考jfrog rt build-collect-env #收集构建环境,准备构建发布jfrog rt构建发布#只有autoPublishBuildInfo是真的write_output #更新buildinfo资源,如果存在jfrog rt build-scan #如果forceXrayScan为真add_run_files #将BuildInfo添加到运行状态