mirror of
https://github.com/prometheus-community/windows_exporter.git
synced 2026-03-05 18:16:35 +00:00
chore: remove test push pipelines (#1621)
This commit is contained in:
96
.github/workflows/push.yml
vendored
96
.github/workflows/push.yml
vendored
@@ -1,96 +0,0 @@
|
|||||||
name: Push Check
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
permissions:
|
|
||||||
contents: write
|
|
||||||
packages: write
|
|
||||||
|
|
||||||
env:
|
|
||||||
VERSION_PROMU: '0.14.0'
|
|
||||||
VERSION_CONTAINERD: '1.7.21'
|
|
||||||
VERSION_BUILDKIT: '0.15.2'
|
|
||||||
VERSION_BUILDX: '0.16.2'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
stale:
|
|
||||||
if: github.repository_owner == 'jkroepke'
|
|
||||||
runs-on: windows-2022
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
- uses: actions/setup-go@v5
|
|
||||||
with:
|
|
||||||
go-version-file: 'go.mod'
|
|
||||||
|
|
||||||
# https://github.com/pl4nty/Windows-Containers/blob/Main/helpful_tools/Install-BuildKit-GitHubActions/workflow.yaml
|
|
||||||
- name: Setup containerd
|
|
||||||
run: |
|
|
||||||
curl.exe -L https://github.com/containerd/containerd/releases/download/v${{ env.VERSION_CONTAINERD }}/containerd-${{ env.VERSION_CONTAINERD }}-windows-amd64.tar.gz -o containerd.tar.gz
|
|
||||||
tar.exe xvf containerd.tar.gz
|
|
||||||
.\bin\containerd.exe --register-service
|
|
||||||
Start-Service containerd
|
|
||||||
- name: Setup BuildKit
|
|
||||||
run: |
|
|
||||||
curl.exe -L https://github.com/moby/buildkit/releases/download/v${{ env.VERSION_BUILDKIT }}/buildkit-v${{ env.VERSION_BUILDKIT }}.windows-amd64.tar.gz -o buildkit.tar.gz
|
|
||||||
tar.exe xvf buildkit.tar.gz
|
|
||||||
|
|
||||||
.\bin\buildkitd.exe --register-service
|
|
||||||
Start-Service buildkitd
|
|
||||||
- name: Setup Docker Buildx
|
|
||||||
run: |
|
|
||||||
curl.exe -L https://github.com/docker/buildx/releases/download/v${{ env.VERSION_BUILDX }}/buildx-v${{ env.VERSION_BUILDX }}.windows-amd64.exe -o $env:ProgramData\Docker\cli-plugins\docker-buildx.exe
|
|
||||||
- uses: docker/setup-buildx-action@v3
|
|
||||||
with:
|
|
||||||
driver: remote
|
|
||||||
endpoint: npipe:////./pipe/buildkitd
|
|
||||||
|
|
||||||
- name: Install WiX
|
|
||||||
run: dotnet tool install --global wix
|
|
||||||
|
|
||||||
- name: Install WiX extensions
|
|
||||||
run: |
|
|
||||||
wix extension add -g WixToolset.Util.wixext
|
|
||||||
wix extension add -g WixToolset.Firewall.wixext
|
|
||||||
|
|
||||||
- name: Install Build deps
|
|
||||||
run: |
|
|
||||||
Invoke-WebRequest -Uri https://github.com/prometheus/promu/releases/download/v$($Env:VERSION_PROMU)/promu-$($Env:VERSION_PROMU).windows-amd64.zip -OutFile promu-$($Env:VERSION_PROMU).windows-amd64.zip
|
|
||||||
Expand-Archive -Path promu-$($Env:VERSION_PROMU).windows-amd64.zip -DestinationPath .
|
|
||||||
Copy-Item -Path promu-$($Env:VERSION_PROMU).windows-amd64\promu.exe -Destination "$(go env GOPATH)\bin"
|
|
||||||
|
|
||||||
# GOPATH\bin dir must be added to PATH else the `promu` commands won't be found
|
|
||||||
echo "$(go env GOPATH)\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
|
||||||
|
|
||||||
- name: Build
|
|
||||||
run: |
|
|
||||||
$ErrorActionPreference = "Stop"
|
|
||||||
|
|
||||||
$Version = git describe --tags --always
|
|
||||||
$Version = $Version -replace 'v', ''
|
|
||||||
# '+' symbols are invalid characters in image tags
|
|
||||||
$Version = $Version -replace '\+', '_'
|
|
||||||
$Version | Set-Content VERSION -PassThru
|
|
||||||
|
|
||||||
make build-all
|
|
||||||
|
|
||||||
# GH requires all files to have different names, so add version/arch to differentiate
|
|
||||||
foreach($Arch in "amd64", "arm64") {
|
|
||||||
Move-Item output\$Arch\windows_exporter.exe output\windows_exporter-$Version-$Arch.exe
|
|
||||||
}
|
|
||||||
|
|
||||||
Get-ChildItem -Path output
|
|
||||||
|
|
||||||
- name: Login to GitHub container registry
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.repository_owner }}
|
|
||||||
password: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
||||||
- name: Push Latest image
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
VERSION: ${{ startsWith(github.ref, 'refs/tags/') && 'latest' || github.ref_name }}
|
|
||||||
run: |
|
|
||||||
make push-all
|
|
||||||
18
Makefile
18
Makefile
@@ -7,7 +7,7 @@ DOCKER_REPO ?= prometheuscommunity
|
|||||||
DOCKER_IMAGE_NAME ?= windows-exporter
|
DOCKER_IMAGE_NAME ?= windows-exporter
|
||||||
|
|
||||||
# ALL_DOCKER_REPOS is the list of repositories to push the image to. ghcr.io requires that org name be the same as the image repo name.
|
# ALL_DOCKER_REPOS is the list of repositories to push the image to. ghcr.io requires that org name be the same as the image repo name.
|
||||||
ALL_DOCKER_REPOS ?= ghcr.io/jkroepke # quay.io/$(DOCKER_REPO)
|
ALL_DOCKER_REPOS ?= docker.io/$(DOCKER_REPO) ghcr.io/prometheus-community # quay.io/$(DOCKER_REPO)
|
||||||
|
|
||||||
# Image Variables for host process Container
|
# Image Variables for host process Container
|
||||||
# Windows image build is heavily influenced by https://github.com/kubernetes/kubernetes/blob/master/cluster/images/etcd/Makefile
|
# Windows image build is heavily influenced by https://github.com/kubernetes/kubernetes/blob/master/cluster/images/etcd/Makefile
|
||||||
@@ -56,10 +56,10 @@ package: crossbuild
|
|||||||
powershell -NonInteractive -ExecutionPolicy Bypass -File .\installer\build.ps1 -PathToExecutable .\output\amd64\windows_exporter.exe -Version $(shell git describe --tags --abbrev=0)
|
powershell -NonInteractive -ExecutionPolicy Bypass -File .\installer\build.ps1 -PathToExecutable .\output\amd64\windows_exporter.exe -Version $(shell git describe --tags --abbrev=0)
|
||||||
|
|
||||||
build-image: crossbuild
|
build-image: crossbuild
|
||||||
$(DOCKER) build --build-arg=BASE=$(BASE_IMAGE):$(OS) -f Dockerfile -t local/$(DOCKER_IMAGE_NAME):pr1561-$(OS) .
|
$(DOCKER) build --build-arg=BASE=$(BASE_IMAGE):$(OS) -f Dockerfile -t local/$(DOCKER_IMAGE_NAME):$(VERSION)-$(OS) .
|
||||||
|
|
||||||
build-hostprocess:
|
build-hostprocess:
|
||||||
$(DOCKER) buildx build --build-arg=BASE=mcr.microsoft.com/oss/kubernetes/windows-host-process-containers-base-image:v1.0.0 -f Dockerfile -t local/$(DOCKER_IMAGE_NAME):pr1561-hostprocess .
|
$(DOCKER) buildx build --build-arg=BASE=mcr.microsoft.com/oss/kubernetes/windows-host-process-containers-base-image:v1.0.0 -f Dockerfile -t local/$(DOCKER_IMAGE_NAME):$(VERSION)-hostprocess .
|
||||||
|
|
||||||
sub-build-%:
|
sub-build-%:
|
||||||
$(MAKE) OS=$* build-image
|
$(MAKE) OS=$* build-image
|
||||||
@@ -70,20 +70,20 @@ push:
|
|||||||
set -x; \
|
set -x; \
|
||||||
for docker_repo in ${DOCKER_REPO}; do \
|
for docker_repo in ${DOCKER_REPO}; do \
|
||||||
for osversion in ${ALL_OS}; do \
|
for osversion in ${ALL_OS}; do \
|
||||||
$(DOCKER) tag local/$(DOCKER_IMAGE_NAME):pr1561-$${osversion} $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561-$${osversion}; \
|
$(DOCKER) tag local/$(DOCKER_IMAGE_NAME):$(VERSION)-$${osversion} $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION)-$${osversion}; \
|
||||||
$(DOCKER) push $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561-$${osversion}; \
|
$(DOCKER) push $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION)-$${osversion}; \
|
||||||
$(DOCKER) manifest create --amend $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561 $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561-$${osversion}; \
|
$(DOCKER) manifest create --amend $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION) $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION)-$${osversion}; \
|
||||||
full_version=`$(DOCKER) manifest inspect $(BASE_IMAGE):$${osversion} | grep "os.version" | head -n 1 | awk -F\" '{print $$4}'` || true; \
|
full_version=`$(DOCKER) manifest inspect $(BASE_IMAGE):$${osversion} | grep "os.version" | head -n 1 | awk -F\" '{print $$4}'` || true; \
|
||||||
$(DOCKER) manifest annotate --os windows --arch amd64 --os-version $${full_version} $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561 $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561-$${osversion}; \
|
$(DOCKER) manifest annotate --os windows --arch amd64 --os-version $${full_version} $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION) $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION)-$${osversion}; \
|
||||||
done; \
|
done; \
|
||||||
$(DOCKER) manifest push --purge $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561 ; \
|
$(DOCKER) manifest push --purge $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION); \
|
||||||
done
|
done
|
||||||
|
|
||||||
# We can't load the image into the local docker store, so we have to build and push it in one go
|
# We can't load the image into the local docker store, so we have to build and push it in one go
|
||||||
push-hostprocess:
|
push-hostprocess:
|
||||||
set -x; \
|
set -x; \
|
||||||
for docker_repo in ${DOCKER_REPO}; do \
|
for docker_repo in ${DOCKER_REPO}; do \
|
||||||
$(DOCKER) buildx build --push --build-arg=BASE=mcr.microsoft.com/oss/kubernetes/windows-host-process-containers-base-image:v1.0.0 -f Dockerfile -t $${docker_repo}/$(DOCKER_IMAGE_NAME):pr1561-hostprocess .; \
|
$(DOCKER) buildx build --push --build-arg=BASE=mcr.microsoft.com/oss/kubernetes/windows-host-process-containers-base-image:v1.0.0 -f Dockerfile -t $${docker_repo}/$(DOCKER_IMAGE_NAME):$(VERSION)-hostprocess .; \
|
||||||
done
|
done
|
||||||
|
|
||||||
.PHONY: push-all
|
.PHONY: push-all
|
||||||
|
|||||||
Reference in New Issue
Block a user