根据我的经验,我发现使用 GitHub 的container
指令会导致更多的混乱,而不是简单地在运行器本身上运行你想要的任何东西,就好像你在自己的机器上运行它一样。
我在 GitHub 上运行的大部分测试都在容器中运行,有些需要私有 DockerHub 映像。
我总是这样做:
- 创建一个
docker-compose.yml
供开发使用,这样我就可以在本地进行测试。
- 通常在 CI 中,您可能需要稍微不同的东西
docker-compose
(例如,没有卷映射) - 如果是这种情况,我将docker-compose.yml
在.ci
子文件夹中创建另一个。
- My
docker-compose.yml
包含一个test
服务,它运行我想要的任何测试(或测试套件)。
这是我正在使用的示例 GitHub 操作文件:
name: Test
on:
pull_request:
push: { branches: master }
jobs:
test:
name: Run test suite
runs-on: ubuntu-latest
env:
COMPOSE_FILE: .ci/docker-compose.yml
DOCKER_USER: ${{ secrets.DOCKER_USER }}
DOCKER_PASS: ${{ secrets.DOCKER_PASS }}
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Login to DockerHub
run: docker login -u $DOCKER_USER -p $DOCKER_PASS
- name: Build docker images
run: docker-compose build
- name: Run tests
run: docker-compose run test
当然,这需要设置上面提到的两个秘密,但除此之外,我发现这种方法是:
- 可靠的
- 便携(我用相同的方法轻松地从 Travis CI 切换)
- 兼容开发环境
- 在本地和 CI 中易于理解和重现