Skip to content

Commit

Permalink
workflows: build image only on build context changes
Browse files Browse the repository at this point in the history
Also switch to using docker-buildx, and remove unneeded step.
  • Loading branch information
zakame committed Sep 23, 2024
1 parent 3db6a43 commit cbd6422
Showing 1 changed file with 19 additions and 13 deletions.
32 changes: 19 additions & 13 deletions .github/workflows/build-image.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,14 @@ name: Build and Test
on:
push:
branches:
- '**'
- master
tags-ignore:
- '*'
pull_request:
paths:
- '**/Dockerfile'
- '!.devcontainer/Dockerfile'
- '**/DevelPatchPerl.patch'

defaults:
run:
Expand All @@ -18,46 +22,56 @@ jobs:
runs-on: ubuntu-latest
outputs:
matrix: ${{ steps.generate.outputs.matrix }}

steps:
- uses: actions/checkout@master
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7

- id: generate
name: Enumerate Dockerfiles
run: |
matrix="$(dirname */Dockerfile | sort -rn | jq -csR 'rtrimstr("\n") | split("\n") | { directory: . }')"
echo "matrix=$matrix" >> $GITHUB_OUTPUT
build-image:
needs: generate-matrix
runs-on: ubuntu-latest
strategy:
matrix: ${{ fromJson(needs.generate-matrix.outputs.matrix) }}
name: ${{ matrix.directory }}

steps:
- uses: actions/checkout@master

- name: Clone docker-library/official-images (for testing)
run: |
git clone --depth 1 --single-branch https://github.com/docker-library/official-images.git
- name: Build image
run: |
docker version
dir='${{ matrix.directory }}'
img="perl:${dir//,/-}"
docker build -t "$img" "$dir"
docker buildx build --progress=plain -t "$img" "$dir"
- name: Inspect image creation and tag time
run: |
dir='${{ matrix.directory }}'
img="perl:${dir//,/-}"
docker image inspect --format '{{.Created}}' "$img"
docker image inspect --format '{{.Metadata.LastTagTime}}' "$img"
- name: Run tests from docker-library/official-images
run: |
dir='${{ matrix.directory }}'
img="perl:${dir//,/-}"
./official-images/test/run.sh "$img"
- name: Run HTTPS access test
run: |
dir='${{ matrix.directory }}'
img="perl:${dir//,/-}"
docker run "$img" perl -MHTTP::Tiny -E 'if (HTTP::Tiny->new->get("https://github.com")->{status} == 200) { exit 0 } exit 1'
- name: Run cpanm install test
run: |
dir='${{ matrix.directory }}'
Expand All @@ -67,13 +81,15 @@ jobs:
docker run "$img" cpanm -v Net::[email protected]_02
fi
docker run "$img" cpanm -v Mojolicious
- name: Run cpanm no-lwp by default test
run: |
dir='${{ matrix.directory }}'
img="perl:${dir//,/-}"
if [[ "$dir" != *"slim"* ]]; then
docker run "$img" bash -c "cpanm -v -n LWP && cpanm -v -n local::lib"
fi
- name: Run cpm install test
run: |
dir='${{ matrix.directory }}'
Expand All @@ -83,13 +99,3 @@ jobs:
docker run "$img" cpm install -v Net::[email protected]_02
fi
docker run "$img" cpm install -v Mojolicious
- name: COPY all to default WORKDIR
run: |
dir='${{ matrix.directory }}'
img="perl:${dir//,/-}"
mkdir -p test/lib
cat <<EOF >Dockerfile
FROM $img
COPY . .
EOF
docker build -f Dockerfile test

0 comments on commit cbd6422

Please sign in to comment.