aboutsummaryrefslogtreecommitdiffstats
path: root/.github/workflows/push-containers.yml
diff options
context:
space:
mode:
authorChristian Marangi <ansuelsmth@gmail.com>2022-12-09 18:09:32 +0100
committerChristian Marangi <ansuelsmth@gmail.com>2022-12-24 12:09:23 +0100
commitaf4417418749b9233c5a205affbcdea659cc685b (patch)
tree971f3a8e19731f34240d8b7a03fa20877ba21766 /.github/workflows/push-containers.yml
parentf649a7b5f337f1b2a69879b45ebafffec1380011 (diff)
downloadupstream-af4417418749b9233c5a205affbcdea659cc685b.tar.gz
upstream-af4417418749b9233c5a205affbcdea659cc685b.tar.bz2
upstream-af4417418749b9233c5a205affbcdea659cc685b.zip
CI: tools: reogranize and split workflow
Generilize tools workflow for future usage in shared workflow for tools build. Split tools workflow to tools and push-containers: - tools just execute build test - push-containers build and push prebuilt containers Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
Diffstat (limited to '.github/workflows/push-containers.yml')
-rw-r--r--.github/workflows/push-containers.yml86
1 files changed, 86 insertions, 0 deletions
diff --git a/.github/workflows/push-containers.yml b/.github/workflows/push-containers.yml
new file mode 100644
index 0000000000..56e0daa611
--- /dev/null
+++ b/.github/workflows/push-containers.yml
@@ -0,0 +1,86 @@
+name: Build and Push prebuilt tools container
+
+on:
+ push:
+ paths:
+ - 'tools/**'
+ - '.github/workflows/build-tools.yml'
+ - '.github/workflows/push-containers.yml'
+ - '.github/workflows/Dockerfile.tools'
+
+permissions:
+ contents: read
+
+jobs:
+ build-linux-buildbot:
+ name: Build tools with buildbot container
+ uses: ./.github/workflows/build-tools.yml
+ with:
+ generate_prebuilt_artifacts: true
+
+ push-tools-container:
+ needs: build-linux-buildbot
+ name: Push prebuilt tools container
+ runs-on: ubuntu-latest
+
+ permissions:
+ contents: read
+ packages: write
+
+ steps:
+ - name: Set lower case owner name
+ env:
+ OWNER: ${{ github.repository_owner }}
+ run: |
+ echo "OWNER_LC=${OWNER,,}" >> "$GITHUB_ENV"
+
+ # Per branch tools container tag
+ # By default stick to latest
+ # For official test targetting openwrt stable branch
+ # Get the branch or parse the tag and push dedicated tools containers
+ # Any branch that will match this pattern openwrt-[0-9][0-9].[0-9][0-9]
+ # will refresh the tools container with the matching tag.
+ # (example branch openwrt-22.03 -> tools:openwrt-22.03)
+ # (example branch openwrt-22.03-test -> tools:openwrt-22.03)
+ - name: Determine tools container tag
+ run: |
+ CONTAINER_TAG=latest
+
+ if [ ${{ github.ref_type }} == "branch" ]; then
+ if echo "${{ github.ref_name }}" | grep -q -E 'openwrt-[0-9][0-9]\.[0-9][0-9]'; then
+ CONTAINER_TAG="$(echo ${{ github.ref_name }} | sed 's/^\(openwrt-[0-9][0-9]\.[0-9][0-9]\).*/\1/')"
+ fi
+ elif [ ${{ github.ref_type }} == "tag" ]; then
+ if echo "${{ github.ref_name }}" | grep -q -E 'v[0-9][0-9]\.[0-9][0-9]\..+'; then
+ CONTAINER_TAG=openwrt-"$(echo ${{ github.ref_name }} | sed 's/v\([0-9][0-9]\.[0-9][0-9]\)\..\+/\1/')"
+ fi
+ fi
+
+ echo "Tools container to push tools:$CONTAINER_TAG"
+ echo "CONTAINER_TAG=$CONTAINER_TAG" >> "$GITHUB_ENV"
+
+ - name: Checkout
+ uses: actions/checkout@v3
+ with:
+ path: 'openwrt'
+
+ - name: Download prebuilt tools from build job
+ uses: actions/download-artifact@v3
+ with:
+ name: linux-buildbot-prebuilt-tools
+ path: openwrt
+
+ - name: Login to GitHub Container Registry
+ uses: docker/login-action@v2
+ with:
+ registry: ghcr.io
+ username: ${{ github.actor }}
+ password: ${{ secrets.GITHUB_TOKEN }}
+
+ - name: Build and push
+ uses: docker/build-push-action@v3
+ with:
+ context: openwrt
+ push: true
+ tags: ghcr.io/${{ env.OWNER_LC }}/tools:${{ env.CONTAINER_TAG }}
+ file: openwrt/.github/workflows/Dockerfile.tools