如何在 Azure DevOps 中自动对 npm 包进行版本控制(不触发新管道)?

ctw*_*els 2 npm semantic-versioning azure-devops

我们正在努力做什么

我们正在使用 Azure Pipelines ( azure-pipelines.yml) 来自动化 ci/cd。我们的部分配置完成了项目的版本控制,以发布到 Azure Artifacts。我们还尝试对其进行配置以更新现有版本号,而package.json不会在 Azure DevOps 中触发新管道。

这是我们文件的相关部分azure-pipelines.yml

  - script: |
      git config --global user.email "email@example.com"
      git config --global user.name "User name"
      npm version patch -m "Bump version to %s [skip ci]" --force
    displayName: 'Bump release version'
  - script: |
      npm pack
    displayName: 'Package package'
Run Code Online (Sandbox Code Playgroud)

这可以很好地将包发布到我们的 Azure Artifacts feed,但不会更新现有版本package.json

我们的package.json包含以下内容:

"release": {
    "plugins": [
        "@semantic-release/commit-analyzer",
        "@semantic-release/release-notes-generator",
        "@semantic-release/changelog",
        [
            "@semantic-release/npm",
            {
                "npmPublish": false
            }
        ],
        [
            "@semantic-release/git",
            {
                "assets": [
                    "dist/",
                    "package.json",
                    "CHANGELOG.md"
                ],
                "message": "chore(release): ${nextRelease.version} [skip ci]\n\n${nextRelease.notes}"
            }
        ]
    ]
}
Run Code Online (Sandbox Code Playgroud)

问题

我们如何更新脚本以确保versionin 中的值package.json也被更新,而不触发另一个管道执行(这将导致触发新管道执行的无限循环)?

Lev*_*SFT 5

您可以添加另一个脚本任务来推送回您的 devops git 存储库。但首先,您需要添加结帐步骤并将persistCredentials设置为 true 以验证 git 命令。请参阅下面的示例:

- checkout: self
  persistCredentials: true

- script: |

   git config --global user.email "email@example.com"
   git config --global user.name "User name"
   npm version patch -m "Bump version to %s [skip ci]" --force

  displayName: 'Bump release version'

- script: |

   git push origin HEAD:$(Build.SourceBranchName)

  displayName: 'Update Git Repo'
  
Run Code Online (Sandbox Code Playgroud)

因为您在提交消息中有[skip ci] 。推回更新的 package.json 文件不会触发新的构建。看这里