Skip to content

Commit

Permalink
include manifest for build images
Browse files Browse the repository at this point in the history
  • Loading branch information
arturcic committed Jan 20, 2025
1 parent 3f5fb34 commit e1d34e3
Show file tree
Hide file tree
Showing 4 changed files with 72 additions and 2 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/build-deps.yml
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ jobs:
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
build_deps_manifests:
name: Build Deps Manifests
name: Build Deps Manifests (${{ matrix.distro }})
needs: [ prepare, build_deps ]
env:
PUSH_IMAGES: ${{github.event_name != 'pull_request' && github.repository_owner == 'GitTools'}}
Expand Down
68 changes: 67 additions & 1 deletion .github/workflows/build-images.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ jobs:
id: set_matrix
run: dotnet run/build.dll --target=SetMatrix

build:
build_images:
name: Build Images (${{ matrix.arch }} - ${{ matrix.distro }}) (${{ matrix.version }} - ${{ matrix.variant }})
needs: [ prepare ]
env:
Expand Down Expand Up @@ -107,3 +107,69 @@ jobs:
--dotnet_version=${{ matrix.version }} --dotnet_variant=${{ matrix.variant }} `
--dotnet_distro=${{ matrix.distro }} --docker_registry=github `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
build_images_manifest:
name: Build Images (${{ matrix.distro }}) (${{ matrix.version }} - ${{ matrix.variant }})
needs: [ prepare, build_images ]
env:
PUSH_IMAGES: ${{github.event_name != 'pull_request' && github.repository_owner == 'GitTools'}}
runs-on: ubuntu-24.04
strategy:
matrix:
distro: ${{ fromJson(needs.prepare.outputs.dockerDistros) }}
version: ${{ fromJson(needs.prepare.outputs.dotnetVersions) }}
variant: ${{ fromJson(needs.prepare.outputs.dotnetVariants) }}
fail-fast: false

steps:
- name: Checkout
uses: actions/checkout@v4
- name: Use cached cake frosting
id: cache-cake
uses: actions/cache@v4
with:
path: run
key: run-${{ runner.os }}-${{ hashFiles('./build/**') }}
- name: Setup .NET SDK
uses: actions/setup-dotnet@v4
with:
global-json-file: build/global.json
- name: Set up Docker
uses: docker/setup-docker-action@v4
with:
daemon-config: '{ "features": { "containerd-snapshotter": true } }'
- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v3
with:
version: 'latest'
driver-opts: 'image=moby/buildkit:buildx-stable-1'
install: true
- name: Login to DockerHub
if: success() && env.PUSH_IMAGES == 'true'
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: '[Build Docker images]'
shell: pwsh
run: |
dotnet run/build.dll `
--target=DockerBuildImagesManifest `
--dotnet_version=${{ matrix.version }} --dotnet_variant=${{ matrix.variant }} `
--dotnet_distro=${{ matrix.distro }} --docker_registry=dockerhub `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
- name: Login to GitHub Container Registry
if: success() && env.PUSH_IMAGES == 'true'
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.DOCKER_GITHUB_TOKEN }}
- name: '[Build Docker images]'
shell: pwsh
run: |
dotnet run/build.dll `
--target=DockerBuildImagesManifest `
--dotnet_version=${{ matrix.version }} --dotnet_variant=${{ matrix.variant }} `
--dotnet_distro=${{ matrix.distro }} --docker_registry=github `
--push_images=${{env.PUSH_IMAGES}} --verbosity=diagnostic
2 changes: 2 additions & 0 deletions build/build/Tasks/DockerBuildDepsManifest.cs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
namespace Build;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

[TaskName(nameof(DockerBuildDepsManifest))]
[TaskDescription("Builds the docker images dependencies manifest")]
public class DockerBuildDepsManifest : BaseDockerBuildManifest
{
public override void Run(BuildContext context)
Expand Down
2 changes: 2 additions & 0 deletions build/build/Tasks/DockerBuildImagesManifest.cs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
namespace Build;
using DockerBuildXImageToolsCreateSettings = Build.Cake.Docker.DockerBuildXImageToolsCreateSettings;

[TaskName(nameof(DockerBuildImagesManifest))]
[TaskDescription("Builds the docker images manifest")]
public class DockerBuildImagesManifest : BaseDockerBuildManifest
{
public override void Run(BuildContext context)
Expand Down

0 comments on commit e1d34e3

Please sign in to comment.