使用 github 操作在 Windows 上测试 Perl

Testing Perl on Windows with github actions

我发布了 MooseX::Extended to the CPAN (github repository here).

我正在尝试设置 github 操作和 linux 测试 运行 就好了。然而,(Windows is failing with this error:

Configuring true-v1.0.2 ... OK
==> Found dependencies: Function::Parameters
--> Working on Function::Parameters
Fetching http://www.cpan.org/authors/id/M/MA/MAUKE/Function-Parameters-2.001003.tar.gz ... OK
Configuring Function-Parameters-2.001003 ... OK
Building Function-Parameters-2.001003 ... OK
Successfully installed Function-Parameters-2.001003
! Installing true failed. See C:\Users\RUNNER~1\.cpanm\work53412748.5640\build.log for details. Retry with --force to force install it.
Building true-v1.0.2 ... FAIL

当然,我看不到那个C:\Users\RUNNER~1\.cpanm\work53412748.5640\build.log来理解发生了什么。

true 模块 passes its CPAN testers tests on Windows,所以我不知道为什么它在 Github 操作中失败。

我的工作流程是这样的:

# Hacked from https://github.com/skaji/perl-github-actions-sample/blob/master/.github/workflows/windows.yml
# See also: https://perlmaven.com/github-actions-running-on-3-operating-systems
name: windows

on:
  push:
    branches:
      - '*'
    tags-ignore:
      - '*'
  pull_request:

jobs:
  perl:
    runs-on: windows-latest
    strategy:
      fail-fast: false
      matrix:
        perl-version:
          - '5.20'
          - '5.22'
          - '5.24'
          - '5.26'
          - '5.28'
          - '5.30'
          - '5.32'
          - '5.34'
          - 'latest'
    steps:
      - uses: actions/checkout@v2
      - name: Set up Perl
        run: |
          choco install strawberryperl
          echo "C:\strawberry\c\bin;C:\strawberry\perl\site\bin;C:\strawberry\perl\bin" >> $GITHUB_PATH
      - name: perl -V
        run: perl -V
      - name: Install Dependencies
        run: curl -sL https://git.io/cpm | perl - install -g --show-build-log-on-failure Dist::Zilla
      - name: Run Tests
        run: |
          dzil authordeps --missing | cpanm --notest
          dzil listdeps --author --missing | cpanm --notest
          dzil test --author --release

This is the PR to which the actions are attached.

我无法访问 Windows 框。有人知道我错过了什么吗?

由于 GitHub Actions/Workflows 使用的 Windows 容器已经有 Strawberry Perl pre-installed 的版本,因此它不允许您安装任何其他版本。您无法删除 pre-installed 的 Perl 版本,并且 removing/installing 通过 Chocolatey 的新版本也几乎是不可能的。如果你 re-install 已经在容器上的 Chocolatey 版本,它似乎允许这样做,但它基本上是一个 NOOP 供你作为测试设置。

容器也安装了MinGW;这对我们也不利。单独安装 MinGW 会阻止构建 XS 模块(无论它们是依赖项还是您自己的模块是 XS 模块)。当然,只有当 MinGW 出现在 Perl 安装之前的 PATH 中时才会发生这种情况,但是当您删除一个 Perl 并添加另一个 Perl 时,您将遇到这个问题。

要解决此问题,最好的做法是从 PATH 环境变量中删除当前安装的 Perl 版本,以及当前安装的 MinGW 版本。一旦两者都安全地脱离了 PATH,您就可以安装一个 Portable[1] Strawberry Perl,将那个 Perl 的路径放入您的 PATH 并开始使用全新安装的 Strawberry Perl 进行测试。 GitHub 最近打破了我们直接在 Action YAML 文件中执行此操作的能力。

这听起来很头疼,但事实并非如此。为此,我们可以使用一个操作:actions-setup-perl。通过此操作,您可以轻松地使用您喜欢的任何版本的 Perl 进行测试。因此,如果您听到有人在 Windows 上报告 Perl v5.26 的错误,您现在可以将其添加到您的矩阵并轻松测试,而无需来自用户的任何 back-and-forth:

name: windows
on:
  push:
    branches:
      - '*'
    tags-ignore:
      - '*'
  pull_request:
jobs:
  perl:
    runs-on: windows-latest
    strategy:
      fail-fast: true
      matrix:
        perl-version:
          - '5.30'
          # - '5.28'
          # - '5.26'
          # - '5.24'
          # - '5.22'
          # - '5.20'
          # - '5.18'
          # - '5.16'
          - '5.14'
    steps:
      - name: Setup perl
        uses: shogo82148/actions-setup-perl@v1
        with:
          perl-version: ${{ matrix.perl-version }}
          distribution: strawberry
      - name: Set git to use LF
        run: |
          git config --global core.autocrlf false
          git config --global core.eol lf
      - uses: actions/checkout@v2
      - name: perl -V
        run: perl -V
      - name: Ensure we have a working toolchain
        run: cpanm ExtUtils::Manifest App::cpanminus
      - name: Install Dependencies
        run: cpanm -n --installdeps .
      - name: Run Tests
        run: cpanm --test-only -v .

[1] Strawberry Perl 的便携式版本已压缩,已编译的 Perl 版本不需要您 运行 Windows 上的安装程序。这意味着不需要更高的权限等。您只需将存档解压缩到您想要 运行 Perl 的目录中,然后在 $env:PATH 变量中添加 Perl 的相关路径。它消除了构建违规等的任何烦恼。我发现它是在 Windows.

上进行测试的最明智的方法