107 lines
3.0 KiB
YAML
107 lines
3.0 KiB
YAML
name: Build slim packages
|
|
|
|
on:
|
|
pull_request:
|
|
workflow_dispatch:
|
|
|
|
jobs:
|
|
build:
|
|
runs-on: ${{ matrix.runs-on }}
|
|
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
otp:
|
|
- erl23.3.4.18-1
|
|
os:
|
|
- ubuntu20.04
|
|
- centos8
|
|
runs-on:
|
|
- aws-amd64
|
|
- ubuntu-20.04
|
|
use-self-hosted:
|
|
- ${{ github.repository_owner == 'emqx' }}
|
|
exclude:
|
|
- runs-on: ubuntu-20.04
|
|
use-self-hosted: true
|
|
- runs-on: aws-amd64
|
|
use-self-hosted: false
|
|
|
|
container: emqx/build-env:${{ matrix.otp }}-${{ matrix.os }}
|
|
|
|
steps:
|
|
- uses: AutoModality/action-clean@v1
|
|
- uses: actions/checkout@v3
|
|
with:
|
|
fetch-depth: 0 # clone full git history
|
|
- name: fix-git-unsafe-repository
|
|
run: git config --global --add safe.directory /__w/emqx/emqx
|
|
- uses: ./.github/actions/detect-profiles
|
|
- name: ensure access to github
|
|
if: endsWith(github.repository, 'enterprise')
|
|
run: |
|
|
echo "https://ci%40emqx.io:${{ secrets.CI_GIT_TOKEN }}@github.com" > $HOME/.git-credentials
|
|
git config --global credential.helper store
|
|
- uses: actions/cache@v3
|
|
with:
|
|
# dialyzer PLTs
|
|
path: ~/.cache/rebar3/
|
|
key: dialyzer-${{ matrix.otp }}
|
|
- name: make xref
|
|
run: make xref
|
|
- name: make dialyzer
|
|
run: make dialyzer
|
|
- name: build zip packages
|
|
run: make ${EMQX_NAME}-zip
|
|
- name: build deb/rpm packages
|
|
run: make ${EMQX_NAME}-pkg
|
|
- uses: actions/upload-artifact@v3
|
|
if: failure()
|
|
with:
|
|
name: rebar3.crashdump
|
|
path: ./rebar3.crashdump
|
|
- name: packages test
|
|
run: |
|
|
export CODE_PATH=$GITHUB_WORKSPACE
|
|
.ci/build_packages/tests.sh
|
|
- uses: actions/upload-artifact@v3
|
|
with:
|
|
name: ${{ matrix.os }}
|
|
path: _packages/**/*.zip
|
|
|
|
mac:
|
|
strategy:
|
|
matrix:
|
|
otp:
|
|
- 23.3.4.18-1
|
|
os:
|
|
- macos-11
|
|
runs-on: ${{ matrix.os }}
|
|
steps:
|
|
- uses: actions/checkout@v3
|
|
with:
|
|
fetch-depth: 0 # clone full git history
|
|
- name: ensure access to github
|
|
if: endsWith(github.repository, 'enterprise')
|
|
run: |
|
|
echo "https://ci%40emqx.io:${{ secrets.CI_GIT_TOKEN }}@github.com" > $HOME/.git-credentials
|
|
git config --global credential.helper store
|
|
- uses: ./.github/actions/detect-profiles
|
|
- uses: ./.github/actions/package-macos
|
|
with:
|
|
otp: ${{ matrix.otp }}
|
|
os: ${{ matrix.os }}
|
|
apple_id_password: ${{ secrets.APPLE_ID_PASSWORD }}
|
|
apple_developer_identity: ${{ secrets.APPLE_DEVELOPER_IDENTITY }}
|
|
apple_developer_id_bundle: ${{ secrets.APPLE_DEVELOPER_ID_BUNDLE }}
|
|
apple_developer_id_bundle_password: ${{ secrets.APPLE_DEVELOPER_ID_BUNDLE_PASSWORD }}
|
|
- uses: actions/upload-artifact@v3
|
|
if: failure()
|
|
with:
|
|
name: rebar3.crashdump
|
|
path: ./rebar3.crashdump
|
|
- uses: actions/upload-artifact@v3
|
|
with:
|
|
name: macos
|
|
path: _packages/**/*.zip
|