Github actions/cache 对我的工作流程没有影响

Github actions/cache has no effect on my workflow

我正在尝试 运行 Github 一个 php 项目的工作流程:

name: CI

on: [push, pull_request]
jobs:
  test:
    runs-on: ubuntu-latest
    env:
      DB_NAME: ${{ secrets.DB_NAME }}
      DB_USER: ${{ secrets.DB_USER }}
      DB_PASSWORD: ${{ secrets.DB_PASSWORD }}
      MYSQL_ROOT_PASSWORD: ${{ secrets.MYSQL_ROOT_PASSWORD }}

    steps:
    - uses: actions/checkout@v2

    - name: Set up the CI environment
      run: |
        envsubst < src/.env.ci > src/.env
        docker pull composer
        alias composer="docker run --rm --interactive --tty --volume $(pwd):/app --volume ${COMPOSER_HOME:-$HOME/.composer}:/tmp --user $(id -u):$(id -g) composer"
        composer --version

    - name: Get Composer Cache Directory
      id: composer-cache
      run: |
        echo "::set-output name=dir::$(composer config cache-files-dir)"

    - uses: actions/cache@v1
      with:
        path: ${{ steps.composer-cache.outputs.dir }}
        key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
        restore-keys: |
          ${{ runner.os }}-composer-

    - name: Install composer dependencies
      if: steps.composer-cache.outputs.cache-hit != 'true'
      run: composer install

场景如下。我有一个基于 docker 的开发环境,由 docker-compose 编排。 Php 作曲家和其他工具 运行 来自 docker 个图像。

看来我在这里遗漏了一些东西,因为 cache-hit 正在发生,正如我在日志中看到的那样:

2020-03-28T10:37:07.2837003Z Cache restored from key: Linux-composer-0dffe7e110c8249b30d4e46844fede7ea6b8e1433061bed12cbb9a2ae964e2bb

但是没有生效,因为步骤Install composer dependencies还在运行ning和下载工件。我的期望是要么不 运行 要么 运行 但不下载任何东西,因为它从恢复的缓存中获取所有内容。

有人知道我缺少什么吗?

更新

我确实接受了@edric 的回答,因为在这种情况下,我问了我的问题,他的回答为我的问题提供了解决方案。虽然我说这不是完全的解决方案。

我需要从最后一步删除条件:if: steps.composer-cache.outputs.cache-hit != 'true' 以获取工作流的其余部分 运行ning。我确实注意到作曲家缓存是 恢复并且 composer install 不是 运行,由于缺少依赖项而导致稍后出现问题。没有 if 条件 composer install 运行 always 但使用恢复的缓存。

那是因为您没有在缓存锁定文件的步骤中设置 ID,并且您还在接下来的步骤中使用了错误的 ID 来检查是否命中了缓存。建议大家将获取缓存目录的步骤ID改成其他ID,以免混淆:

- name: Get Composer Cache Directory
  id: get-composer-cache-dir # Instead of composer-cache
  run: |
    echo "::set-output name=dir::$(composer config cache-files-dir)"
- name: Cache Composer
  uses: actions/cache@v1
  id: composer-cache
  with:
        path: ${{ steps.get-composer-cache-dir.outputs.dir }}
        key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }}
        restore-keys: |
          ${{ runner.os }}-composer-
- name: Install composer dependencies
  if: steps.composer-cache.outputs.cache-hit != 'true'
  run: composer install