Add state diagram and correct the CLI invocation #53
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# By default, GitHub Actions don't have permission to write to the ghcr.io registry. | |
# - Go to: Settings (of this repository) -> Actions -> General -> Workflow permissions | |
# - Enable: Read and write permissions | |
name: Lint and Test | |
on: | |
push: | |
branches: | |
- main | |
- master | |
pull_request: | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
permissions: write-all | |
strategy: | |
matrix: | |
python-version: [ "3.11.8" ] | |
name: Python ${{ matrix.python-version }} | |
env: | |
TAG: devcontainer-${{ matrix.python-version }}-${{ github.head_ref || github.ref_name }} | |
steps: | |
# https://github.com/actions/checkout | |
- name: Checkout | |
uses: actions/checkout@v4 | |
# Add an empty .env file. | |
# The devcontainers/ci build action fails when the docker-compose.yml file references an .env file that does not exist. | |
- name: Touch .env | |
run: touch .env | |
# Remove slashes from the branch name. | |
- name: Normalize Branch Name | |
run: echo "NORMALIZED_TAG=$(echo $TAG | sed 's|/|-|g')" >> $GITHUB_ENV | |
# https://github.com/docker/login-action | |
- name: Log in to registry | |
uses: docker/login-action@v3 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
# https://github.com/devcontainers/ci | |
- name: Build DevContainer | |
uses: devcontainers/[email protected] | |
env: | |
PYTHON_VERSION: ${{ matrix.python-version }} | |
with: | |
imageName: ghcr.io/${{ github.repository }} | |
cacheFrom: ghcr.io/${{ github.repository }}:${{ env.NORMALIZED_TAG }} | |
imageTag: ${{ env.NORMALIZED_TAG }} | |
push: always | |
- name: Run lint | |
uses: devcontainers/[email protected] | |
with: | |
cacheFrom: ghcr.io/${{ github.repository }}:${{ env.NORMALIZED_TAG }} | |
push: never | |
runCmd: poe lint | |
- name: Run test | |
uses: devcontainers/[email protected] | |
with: | |
cacheFrom: ghcr.io/${{ github.repository }}:${{ env.NORMALIZED_TAG }} | |
push: never | |
runCmd: poe test | |
# https://github.com/codecov/codecov-action | |
- name: Upload coverage | |
uses: codecov/codecov-action@v4 | |
with: | |
files: reports/coverage.xml | |
env: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
fail_ci_if_error: false | |
verbose: true |