2023-03-22 14:17:19 +01:00
# Copyright (c) HashiCorp, Inc.
# SPDX-License-Identifier: MPL-2.0
2021-10-25 23:01:18 -07:00
name : build
on :
push :
# Sequence of patterns matched against refs/heads
2022-01-06 14:32:35 -05:00
branches :
# Push events on the main branch
- main
2022-08-01 13:56:55 -06:00
- release/**
2021-10-28 22:22:38 -07:00
2021-10-25 23:01:18 -07:00
env :
PKG_NAME : consul
2023-08-22 09:46:03 -05:00
# TODO(spatel): CE refactor
2023-01-05 14:16:47 -06:00
METADATA : oss
2023-06-21 11:26:27 -04:00
GOPRIVATE : github.com/hashicorp # Required for enterprise deps
2021-10-25 23:01:18 -07:00
jobs :
2024-01-08 17:18:41 -05:00
get-go-version :
uses : ./.github/workflows/reusable-get-go-version.yml
2023-01-05 14:16:47 -06:00
set-product-version :
2021-10-25 23:01:18 -07:00
runs-on : ubuntu-latest
outputs :
2023-01-05 14:16:47 -06:00
product-version : ${{ steps.set-product-version.outputs.product-version }}
base-product-version : ${{ steps.set-product-version.outputs.base-product-version }}
2022-03-23 18:26:42 -07:00
product-date : ${{ steps.get-product-version.outputs.product-date }}
2023-01-05 14:16:47 -06:00
pre-version : ${{ steps.set-product-version.outputs.prerelease-product-version }}
2021-10-25 23:01:18 -07:00
shared-ldflags : ${{ steps.shared-ldflags.outputs.shared-ldflags }}
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2023-10-18 15:39:52 -04:00
# action-set-product-version implicitly sets fields like 'product-version' using version/VERSION
# https://github.com/hashicorp/actions-set-product-version
2023-01-05 14:16:47 -06:00
- name : set product version
id : set-product-version
2024-05-14 15:49:03 -04:00
uses : hashicorp/actions-set-product-version@v2
2021-10-25 23:01:18 -07:00
- name : get product version
id : get-product-version
run : |
2022-06-01 19:29:40 -07:00
CONSUL_DATE=$(build-support/scripts/build-date.sh)
2023-05-30 08:17:53 -07:00
echo "product-date=${CONSUL_DATE}" >> "$GITHUB_OUTPUT"
2021-10-25 23:01:18 -07:00
- name : Set shared -ldflags
id : shared-ldflags
2022-03-23 18:26:42 -07:00
run : |
T="github.com/hashicorp/consul/version"
2023-05-30 08:17:53 -07:00
echo "shared-ldflags=-X ${T}.GitCommit=${GITHUB_SHA::8} \
2023-01-05 14:16:47 -06:00
-X ${T}.GitDescribe=${{ steps.set-product-version.outputs.product-version }} \
-X ${T}.BuildDate=${{ steps.get-product-version.outputs.product-date }} \
2023-05-30 08:17:53 -07:00
" >> " $GITHUB_OUTPUT"
2023-01-05 14:16:47 -06:00
validate-outputs :
needs : set-product-version
runs-on : ubuntu-latest
steps :
- name : Validate Outputs
run : |
echo "Product Version: ${{ needs.set-product-version.outputs.product-version }}"
echo "Base Product Version: ${{ needs.set-product-version.outputs.base-product-version }}"
echo "Product Metadata: ${{ env.METADATA }}"
echo "Product Date: ${{ needs.set-product-version.outputs.product-date }}"
echo "Prerelease Version: ${{ needs.set-product-version.outputs.pre-version }}"
echo "Ldflags: ${{ needs.set-product-version.outputs.shared-ldflags }}"
2023-07-12 16:10:34 -07:00
2021-10-25 23:01:18 -07:00
generate-metadata-file :
2023-01-05 14:16:47 -06:00
needs : set-product-version
2021-10-25 23:01:18 -07:00
runs-on : ubuntu-latest
outputs :
filepath : ${{ steps.generate-metadata-file.outputs.filepath }}
steps :
- name : 'Checkout directory'
2024-05-14 15:49:03 -04:00
uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2021-10-25 23:01:18 -07:00
- name : Generate metadata file
id : generate-metadata-file
2022-04-22 12:26:12 -04:00
uses : hashicorp/actions-generate-metadata@v1
2021-10-25 23:01:18 -07:00
with :
2023-01-05 14:16:47 -06:00
version : ${{ needs.set-product-version.outputs.product-version }}
2021-10-25 23:01:18 -07:00
product : ${{ env.PKG_NAME }}
2024-05-14 15:49:03 -04:00
- uses : actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3
2021-10-25 23:01:18 -07:00
with :
name : metadata.json
path : ${{ steps.generate-metadata-file.outputs.filepath }}
build :
2024-01-08 17:18:41 -05:00
needs :
- set-product-version
- get-go-version
2021-10-25 23:01:18 -07:00
runs-on : ubuntu-latest
strategy :
matrix :
include :
2024-01-08 17:18:41 -05:00
- {goos : "linux" , goarch : "386" }
- {goos : "linux" , goarch : "amd64" }
- {goos : "linux" , goarch : "arm" }
- {goos : "linux" , goarch : "arm64" }
2024-06-26 12:13:57 -04:00
- {goos : "darwin" , goarch : "amd64" }
- {goos : "darwin" , goarch : "arm64" }
2024-01-08 17:18:41 -05:00
- {goos : "freebsd" , goarch : "386" }
- {goos : "freebsd" , goarch : "amd64" }
- {goos : "windows" , goarch : "386" }
- {goos : "windows" , goarch : "amd64" }
- {goos : "solaris" , goarch : "amd64" }
2021-10-25 23:01:18 -07:00
fail-fast : true
2024-01-08 17:18:41 -05:00
name : Go ${{ needs.get-go-version.outputs.go-version }} ${{ matrix.goos }} ${{ matrix.goarch }} build
2021-10-25 23:01:18 -07:00
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2021-10-25 23:01:18 -07:00
- name : Setup with node and yarn
2024-05-14 15:49:03 -04:00
uses : actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2
2021-10-25 23:01:18 -07:00
with :
2023-10-23 11:29:04 -07:00
node-version : '18'
2021-10-25 23:01:18 -07:00
cache : 'yarn'
cache-dependency-path : 'ui/yarn.lock'
- name : Build UI
run : |
2023-01-05 14:16:47 -06:00
CONSUL_VERSION=${{ needs.set-product-version.outputs.product-version }}
CONSUL_DATE=${{ needs.set-product-version.outputs.product-date }}
2021-10-25 23:01:18 -07:00
CONSUL_BINARY_TYPE=${CONSUL_BINARY_TYPE}
CONSUL_COPYRIGHT_YEAR=$(git show -s --format=%cd --date=format:%Y HEAD)
echo "consul_version is ${CONSUL_VERSION}"
2022-06-01 19:29:40 -07:00
echo "consul_date is ${CONSUL_DATE}"
2021-10-25 23:01:18 -07:00
echo "consul binary type is ${CONSUL_BINARY_TYPE}"
echo "consul copyright year is ${CONSUL_COPYRIGHT_YEAR}"
cd ui && make && cd ..
2022-05-31 15:33:56 -04:00
rm -rf agent/uiserver/dist
mv ui/packages/consul-ui/dist agent/uiserver/
2023-01-05 14:16:47 -06:00
- name : Go Build
2021-10-25 23:01:18 -07:00
env :
2023-01-05 14:16:47 -06:00
PRODUCT_VERSION : ${{ needs.set-product-version.outputs.product-version }}
PRERELEASE_VERSION : ${{ needs.set-product-version.outputs.pre-version }}
CGO_ENABLED : "0"
GOLDFLAGS : "${{needs.set-product-version.outputs.shared-ldflags}}"
2024-05-24 14:54:54 -04:00
uses : hashicorp/actions-go-build@make-clean-flag-optional
2021-10-25 23:01:18 -07:00
with :
2023-01-05 14:16:47 -06:00
product_name : ${{ env.PKG_NAME }}
product_version : ${{ needs.set-product-version.outputs.product-version }}
2024-01-08 17:18:41 -05:00
go_version : ${{ needs.get-go-version.outputs.go-version }}
2023-01-05 14:16:47 -06:00
os : ${{ matrix.goos }}
arch : ${{ matrix.goarch }}
2024-05-24 15:32:59 -04:00
reproducible : nope
2024-05-24 14:54:54 -04:00
clean : false
2023-01-05 14:16:47 -06:00
instructions : |-
2024-05-03 15:10:04 -07:00
cp LICENSE $TARGET_DIR/LICENSE.txt
2023-01-05 14:16:47 -06:00
go build -ldflags="$GOLDFLAGS" -o "$BIN_PATH" -trimpath -buildvcs=false
2021-10-25 23:01:18 -07:00
2024-05-03 15:10:04 -07:00
- name : Copy license file
2024-05-07 12:02:02 -04:00
if : ${{ !endsWith(github.repository, '-enterprise') }}
2024-05-03 15:10:04 -07:00
env :
LICENSE_DIR : ".release/linux/package/usr/share/doc/${{ env.PKG_NAME }}"
run : |
mkdir -p "$LICENSE_DIR"
cp LICENSE "$LICENSE_DIR/LICENSE.txt"
2021-10-25 23:01:18 -07:00
- name : Package
if : ${{ matrix.goos == 'linux' }}
uses : hashicorp/actions-packaging-linux@v1
with :
name : ${{ github.event.repository.name }}
description : "Consul is a distributed, highly available, and data center aware solution to connect and configure applications across dynamic, distributed infrastructure. "
arch : ${{ matrix.goarch }}
2023-01-05 14:16:47 -06:00
version : ${{ needs.set-product-version.outputs.product-version }}
2021-10-25 23:01:18 -07:00
maintainer : "HashiCorp"
homepage : "https://github.com/hashicorp/consul"
2024-05-03 15:10:04 -07:00
license : "BSL-1.1"
2021-10-25 23:01:18 -07:00
binary : "dist/${{ env.PKG_NAME }}"
deb_depends : "openssl"
rpm_depends : "openssl"
config_dir : ".release/linux/package"
preinstall : ".release/linux/preinstall"
postinstall : ".release/linux/postinstall"
2022-02-01 12:07:18 -08:00
preremove : ".release/linux/preremove"
2021-10-25 23:01:18 -07:00
postremove : ".release/linux/postremove"
- name : Set Package Names
if : ${{ matrix.goos == 'linux' }}
run : |
echo "RPM_PACKAGE=$(basename out/*.rpm)" >> $GITHUB_ENV
echo "DEB_PACKAGE=$(basename out/*.deb)" >> $GITHUB_ENV
2024-05-14 15:49:03 -04:00
- uses : actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3
2021-10-25 23:01:18 -07:00
if : ${{ matrix.goos == 'linux' }}
with :
name : ${{ env.RPM_PACKAGE }}
path : out/${{ env.RPM_PACKAGE }}
2024-05-14 15:49:03 -04:00
- uses : actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3
2021-10-25 23:01:18 -07:00
if : ${{ matrix.goos == 'linux' }}
with :
name : ${{ env.DEB_PACKAGE }}
path : out/${{ env.DEB_PACKAGE }}
2023-07-12 16:10:34 -07:00
build-s390x :
2024-01-08 17:18:41 -05:00
needs :
- set-product-version
- get-go-version
2023-07-12 16:10:34 -07:00
if : ${{ endsWith(github.repository, '-enterprise') }}
runs-on : ubuntu-latest
strategy :
matrix :
include :
2024-01-08 17:18:41 -05:00
- {goos : "linux" , goarch : "s390x" }
2023-07-12 16:10:34 -07:00
fail-fast : true
2024-01-08 17:18:41 -05:00
name : Go ${{ needs.get-go-version.outputs.go-version }} ${{ matrix.goos }} ${{ matrix.goarch }} build
2023-07-12 16:10:34 -07:00
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2023-07-12 16:10:34 -07:00
- name : Setup with node and yarn
2024-05-14 15:49:03 -04:00
uses : actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2
2023-07-12 16:10:34 -07:00
with :
2023-10-23 11:29:04 -07:00
node-version : '18'
2023-07-12 16:10:34 -07:00
cache : 'yarn'
cache-dependency-path : 'ui/yarn.lock'
- name : Build UI
run : |
CONSUL_VERSION=${{ needs.set-product-version.outputs.product-version }}
CONSUL_DATE=${{ needs.set-product-version.outputs.product-date }}
CONSUL_BINARY_TYPE=${CONSUL_BINARY_TYPE}
CONSUL_COPYRIGHT_YEAR=$(git show -s --format=%cd --date=format:%Y HEAD)
echo "consul_version is ${CONSUL_VERSION}"
echo "consul_date is ${CONSUL_DATE}"
echo "consul binary type is ${CONSUL_BINARY_TYPE}"
echo "consul copyright year is ${CONSUL_COPYRIGHT_YEAR}"
cd ui && make && cd ..
rm -rf agent/uiserver/dist
mv ui/packages/consul-ui/dist agent/uiserver/
- name : Go Build
env :
PRODUCT_VERSION : ${{ needs.set-product-version.outputs.product-version }}
PRERELEASE_VERSION : ${{ needs.set-product-version.outputs.pre-version }}
CGO_ENABLED : "0"
GOLDFLAGS : "${{needs.set-product-version.outputs.shared-ldflags}}"
2024-05-24 14:54:54 -04:00
uses : hashicorp/actions-go-build@make-clean-flag-optional
2023-07-12 16:10:34 -07:00
with :
product_name : ${{ env.PKG_NAME }}
product_version : ${{ needs.set-product-version.outputs.product-version }}
2024-01-08 17:18:41 -05:00
go_version : ${{ needs.get-go-version.outputs.go-version }}
2023-07-12 16:10:34 -07:00
os : ${{ matrix.goos }}
arch : ${{ matrix.goarch }}
2024-05-24 15:32:59 -04:00
reproducible : nope
2024-05-24 14:54:54 -04:00
clean : false
2023-07-12 16:10:34 -07:00
instructions : |-
2024-05-03 15:10:04 -07:00
cp LICENSE $TARGET_DIR/LICENSE.txt
2023-07-12 16:10:34 -07:00
go build -ldflags="$GOLDFLAGS" -o "$BIN_PATH" -trimpath -buildvcs=false
2021-10-25 23:01:18 -07:00
build-docker :
name : Docker ${{ matrix.arch }} build
needs :
2023-01-05 14:16:47 -06:00
- set-product-version
2021-10-25 23:01:18 -07:00
- build
runs-on : ubuntu-latest
strategy :
matrix :
2023-07-24 11:22:34 -04:00
include :
- { arch : "386" }
- { arch : "arm" }
- { arch : "amd64" }
- { arch : "arm64" }
2021-10-25 23:01:18 -07:00
env :
repo : ${{github.event.repository.name}}
2023-01-05 14:16:47 -06:00
version : ${{needs.set-product-version.outputs.product-version}}
2021-10-25 23:01:18 -07:00
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2022-06-24 13:45:57 -07:00
# Strip everything but MAJOR.MINOR from the version string and add a `-dev` suffix
# This naming convention will be used ONLY for per-commit dev images
- name : Set docker dev tag
run : |
2023-10-18 15:39:52 -04:00
echo "full_dev_tag=${{ env.version }}"
echo "full_dev_tag=${{ env.version }}" >> $GITHUB_ENV
echo "minor_dev_tag=$(echo ${{ env.version }}| sed -E 's/([0-9]+\.[0-9]+)\.[0-9]+(-[0-9a-zA-Z\+\.]+)?$/\1\2/')"
echo "minor_dev_tag=$(echo ${{ env.version }}| sed -E 's/([0-9]+\.[0-9]+)\.[0-9]+(-[0-9a-zA-Z\+\.]+)?$/\1\2/')" >> $GITHUB_ENV
2022-06-24 13:45:57 -07:00
2021-10-25 23:01:18 -07:00
- name : Docker Build (Action)
2024-05-14 15:49:03 -04:00
uses : hashicorp/actions-docker-build@v2
2021-10-25 23:01:18 -07:00
with :
version : ${{env.version}}
target : default
arch : ${{matrix.arch}}
tags : |
docker.io/hashicorp/${{env.repo}}:${{env.version}}
2021-12-15 13:17:16 -08:00
public.ecr.aws/hashicorp/${{env.repo}}:${{env.version}}
2022-05-17 12:23:03 -07:00
dev_tags : |
2023-10-18 15:39:52 -04:00
docker.io/hashicorppreview/${{ env.repo }}:${{ env.full_dev_tag }}
docker.io/hashicorppreview/${{ env.repo }}:${{ env.full_dev_tag }}-${{ github.sha }}
docker.io/hashicorppreview/${{ env.repo }}:${{ env.minor_dev_tag }}
docker.io/hashicorppreview/${{ env.repo }}:${{ env.minor_dev_tag }}-${{ github.sha }}
2022-06-06 14:42:11 -07:00
smoke_test : .github/scripts/verify_docker.sh v${{ env.version }}
2022-05-26 09:49:47 -07:00
2022-07-25 16:43:24 -06:00
build-docker-ubi-dockerhub :
2023-11-30 14:49:40 -08:00
name : Docker Build UBI Images
2022-07-25 16:43:24 -06:00
needs :
2023-01-05 14:16:47 -06:00
- set-product-version
2022-07-25 16:43:24 -06:00
- build
runs-on : ubuntu-latest
env :
repo : ${{github.event.repository.name}}
2023-01-05 14:16:47 -06:00
version : ${{needs.set-product-version.outputs.product-version}}
2022-07-25 16:43:24 -06:00
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2022-07-25 16:43:24 -06:00
# Strip everything but MAJOR.MINOR from the version string and add a `-dev` suffix
# This naming convention will be used ONLY for per-commit dev images
- name : Set docker dev tag
run : |
2023-10-18 15:39:52 -04:00
echo "full_dev_tag=${{ env.version }}"
echo "full_dev_tag=${{ env.version }}" >> $GITHUB_ENV
echo "minor_dev_tag=$(echo ${{ env.version }}| sed -E 's/([0-9]+\.[0-9]+)\.[0-9]+(-[0-9a-zA-Z\+\.]+)?$/\1\2/')"
echo "minor_dev_tag=$(echo ${{ env.version }}| sed -E 's/([0-9]+\.[0-9]+)\.[0-9]+(-[0-9a-zA-Z\+\.]+)?$/\1\2/')" >> $GITHUB_ENV
2022-07-25 16:43:24 -06:00
2024-05-14 15:49:03 -04:00
- uses : hashicorp/actions-docker-build@v2
2022-07-25 16:43:24 -06:00
with :
version : ${{env.version}}
target : ubi
arch : amd64
tags : |
docker.io/hashicorp/${{env.repo}}:${{env.version}}-ubi
public.ecr.aws/hashicorp/${{env.repo}}:${{env.version}}-ubi
dev_tags : |
2023-10-18 15:39:52 -04:00
docker.io/hashicorppreview/${{ env.repo }}:${{ env.full_dev_tag }}-ubi
docker.io/hashicorppreview/${{ env.repo }}:${{ env.full_dev_tag }}-ubi-${{ github.sha }}
docker.io/hashicorppreview/${{ env.repo }}:${{ env.minor_dev_tag }}-ubi
docker.io/hashicorppreview/${{ env.repo }}:${{ env.minor_dev_tag }}-ubi-${{ github.sha }}
2022-07-25 16:43:24 -06:00
smoke_test : .github/scripts/verify_docker.sh v${{ env.version }}
2023-11-30 14:49:40 -08:00
redhat_tag : quay.io/redhat-isv-containers/60f9fdbec3a80eac643abedf:${{env.version}}-ubi
2022-07-25 16:43:24 -06:00
2022-06-06 14:42:11 -07:00
verify-linux :
2022-05-27 14:50:41 -04:00
needs :
2023-01-05 14:16:47 -06:00
- set-product-version
2022-05-27 14:50:41 -04:00
- build
runs-on : ubuntu-latest
strategy :
matrix :
2023-07-24 11:22:34 -04:00
include :
- { arch : "386" }
- { arch : "arm" }
- { arch : "amd64" }
- { arch : "arm64" }
2022-05-27 14:50:41 -04:00
fail-fast : true
env :
2023-01-05 14:16:47 -06:00
version : ${{ needs.set-product-version.outputs.product-version }}
zip_name : consul_${{ needs.set-product-version.outputs.product-version }}_linux_${{ matrix.arch }}.zip
2022-06-06 14:42:11 -07:00
name : Verify ${{ matrix.arch }} linux binary
2022-05-27 14:50:41 -04:00
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2023-07-12 16:10:34 -07:00
if : ${{ endsWith(github.repository, '-enterprise') || matrix.arch != 's390x' }}
2022-06-06 14:42:11 -07:00
- name : Download ${{ matrix.arch }} zip
2023-07-12 16:10:34 -07:00
if : ${{ endsWith(github.repository, '-enterprise') || matrix.arch != 's390x' }}
2024-05-14 15:49:03 -04:00
uses : actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # v4.1.7
2022-05-27 14:50:41 -04:00
with :
2022-06-06 14:42:11 -07:00
name : ${{ env.zip_name }}
- name : Set up QEMU
2024-05-14 15:49:03 -04:00
uses : docker/setup-qemu-action@68827325e0b33c7199eb31dd4e31fbe9023e06e3 # v3.0.0
2022-06-06 14:42:11 -07:00
if : ${{ matrix.arch == 'arm' || matrix.arch == 'arm64' }}
with :
# this should be a comma-separated string as opposed to an array
platforms : arm,arm64
- name : Run verification for ${{ matrix.arch }} binary
2023-07-12 16:10:34 -07:00
if : ${{ endsWith(github.repository, '-enterprise') || matrix.arch != 's390x' }}
2022-06-06 14:42:11 -07:00
run : .github/scripts/verify_artifact.sh ${{ env.zip_name }} v${{ env.version }}
2022-05-27 14:50:41 -04:00
verify-linux-packages-deb :
2022-06-06 14:42:11 -07:00
needs :
- build
2023-01-05 14:16:47 -06:00
- set-product-version
2022-05-27 14:50:41 -04:00
runs-on : ubuntu-latest
strategy :
matrix :
2023-07-24 11:22:34 -04:00
include :
- { arch : "i386" }
- { arch : "armhf" }
- { arch : "amd64" }
- { arch : "arm64" }
2022-06-06 14:42:11 -07:00
# fail-fast: true
env :
2023-01-05 14:16:47 -06:00
version : ${{ needs.set-product-version.outputs.product-version }}
2022-05-27 14:50:41 -04:00
name : Verify ${{ matrix.arch }} debian package
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2022-06-16 13:27:37 +01:00
2022-06-06 14:42:11 -07:00
- name : Set package version
run : |
2023-01-05 14:16:47 -06:00
echo "pkg_version=$(echo ${{ needs.set-product-version.outputs.product-version }} | sed 's/\-/~/g')" >> $GITHUB_ENV
2022-05-27 14:50:41 -04:00
2022-06-06 14:42:11 -07:00
- name : Set package name
2022-05-27 14:50:41 -04:00
run : |
2022-06-16 13:27:37 +01:00
echo "pkg_name=consul_${{ env.pkg_version }}-1_${{ matrix.arch }}.deb" >> $GITHUB_ENV
2022-06-06 14:42:11 -07:00
- name : Download workflow artifacts
2024-05-14 15:49:03 -04:00
uses : actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # v4.1.7
2022-06-06 14:42:11 -07:00
with :
name : ${{ env.pkg_name }}
- name : Set up QEMU
2024-05-14 15:49:03 -04:00
uses : docker/setup-qemu-action@68827325e0b33c7199eb31dd4e31fbe9023e06e3 # v3.0.0
2022-06-06 14:42:11 -07:00
with :
platforms : all
2022-05-27 14:50:41 -04:00
- name : Verify ${{ matrix.arch }} debian package
2022-06-06 14:42:11 -07:00
run : ./.github/scripts/verify_artifact.sh ${{ env.pkg_name }} v${{ env.version }}
2022-05-27 14:50:41 -04:00
verify-linux-packages-rpm :
2022-06-06 14:42:11 -07:00
needs :
- build
2023-01-05 14:16:47 -06:00
- set-product-version
2022-05-27 14:50:41 -04:00
runs-on : ubuntu-latest
strategy :
matrix :
2023-07-24 11:22:34 -04:00
include :
- { arch : "i386" }
- { arch : "x86_64" }
2022-08-11 10:26:21 -07:00
# TODO(eculver): re-enable when there is a smaller verification container available
2023-07-24 11:22:34 -04:00
# - { arch: "armv7hl" }
# - { arch: "aarch64" }
2022-06-06 14:42:11 -07:00
env :
2023-01-05 14:16:47 -06:00
version : ${{ needs.set-product-version.outputs.product-version }}
2022-05-27 14:50:41 -04:00
2022-06-06 14:42:11 -07:00
name : Verify ${{ matrix.arch }} rpm
2022-05-27 14:50:41 -04:00
steps :
2024-05-14 15:49:03 -04:00
- uses : actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4.1.4
2022-05-27 14:50:41 -04:00
2022-06-06 14:42:11 -07:00
- name : Set package version
2022-05-27 14:50:41 -04:00
run : |
2023-01-05 14:16:47 -06:00
echo "pkg_version=$(echo ${{ needs.set-product-version.outputs.product-version }} | sed 's/\-/~/g')" >> $GITHUB_ENV
2022-05-27 14:50:41 -04:00
2022-06-06 14:42:11 -07:00
- name : Set package name
2022-05-27 14:50:41 -04:00
run : |
2022-06-16 13:27:37 +01:00
echo "pkg_name=consul-${{ env.pkg_version }}-1.${{ matrix.arch }}.rpm" >> $GITHUB_ENV
2022-06-06 14:42:11 -07:00
- name : Download workflow artifacts
2024-05-14 15:49:03 -04:00
uses : actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e # v4.1.7
2022-06-06 14:42:11 -07:00
with :
name : ${{ env.pkg_name }}
- name : Set up QEMU
2024-05-14 15:49:03 -04:00
uses : docker/setup-qemu-action@68827325e0b33c7199eb31dd4e31fbe9023e06e3 # v3.0.0
2022-06-06 14:42:11 -07:00
with :
platforms : all
2022-06-16 13:27:37 +01:00
- name : Verify ${{ matrix.arch }} rpm
2022-06-06 14:42:11 -07:00
run : ./.github/scripts/verify_artifact.sh ${{ env.pkg_name }} v${{ env.version }}