Skip to content

release-tiup-bench #148

release-tiup-bench

release-tiup-bench #148

---
name: release-tiup-bench
on:
push:
branches:
- ci/gh-*
- release-*
paths-ignore:
- '**.html'
- '**.md'
- 'CNAME'
- 'LICENSE'
- 'doc/**'
- 'embed/templates/examples/**'
release:
types:
- published
workflow_dispatch:
inputs:
git-ref:
description: git ref
required: true
nightly:
description: nightly build
required: false
type: boolean
schedule:
- cron: '0 0 * * *'
jobs:
release:
runs-on: ubuntu-latest
timeout-minutes: 30
outputs:
REL_VER: ${{ steps.build_tiup.outputs.REL_VER }}
strategy:
fail-fast: true
matrix:
os:
- "linux"
- "darwin"
arch:
- "amd64"
- "arm64"
env:
working-directory: ${{ github.workspace }}/go/src/github.com/${{ github.repository }}
steps:
- name: Set up Go 1.19
uses: actions/setup-go@v2
with:
go-version: 1.19.x
id: go
- name: Check out code into the Go module directory
uses: actions/checkout@v3
with:
ref: ${{ inputs.git-ref || github.event.pull_request.head.sha }}
path: go/src/github.com/${{ github.repository }}
fetch-depth: 0
- name: Check if this is a staging build
id: check_staging
working-directory: ${{ env.working-directory }}
if: github.event_name != 'release' && github.event_name != 'schedule'
run: |
STAGING_VER=`git describe --tags | sed -r "s/([^-]*-g)/r\1/"`
echo ::set-output name=STAGING::$STAGING_VER
- name: Check if this is a nightly build
id: check_nightly
working-directory: ${{ env.working-directory }}
if: inputs.nightly || github.event_name == 'schedule'
run: |
echo ::set-output name=NIGHTLY::YES
- name: Get git ref and commit
id: get_git
working-directory: ${{ env.working-directory }}
# when empty, it will be determined by Makefile
run: |
if [[ $GITHUB_REF == refs/tags/* ]]; then
echo ::set-output name=GIT_REF::${GITHUB_REF/refs\/tags\//}
elif [[ $GITHUB_REF == refs/heads/* ]]; then
echo ::set-output name=GIT_REF::${GITHUB_REF/refs\/heads\//}
fi
- name: Resolve latest dependencies
uses: actions/github-script@v6
id: deps
if: inputs.nightly || github.event_name == 'schedule'
env:
GOOS: ${{ matrix.os }}
GOARCH: ${{ matrix.arch }}
with:
script: |
async function resolveLatestURL(owner, repo, name, filter) {
const { data } = await github.rest.repos.getLatestRelease({ owner, repo });
const asset = data.assets.find(filter);
if (asset) {
core.setOutput(name, asset.browser_download_url);
} else {
core.setFailed(`Failed to resolve the latest build of ${owner}/${repo}`)
}
}
const { GOOS, GOARCH } = process.env;
await resolveLatestURL('pingcap', 'go-tpc', 'TPC_URL', a => a.name.includes(`${GOOS}_${GOARCH}.tar.gz`));
await resolveLatestURL('pingcap', 'go-ycsb', 'YCSB_URL', a => a.name.includes(`${GOOS}-${GOARCH}.tar.gz`));
- name: Build for ${{ matrix.os }}-${{ matrix.arch }}
id: build_tiup_bench
working-directory: ${{ env.working-directory }}
env:
GOOS: ${{ matrix.os }}
GOARCH: ${{ matrix.arch }}
COMMIT: ${GITHUB_SHA}
GITREF: ${{ steps.get_git.outputs.GIT_REF }}
TPC_URL: ${{ steps.deps.outputs.TPC_URL }}
YCSB_URL: ${{ steps.deps.outputs.YCSB_URL }}
actor: ${{ github.actor }}
event: ${{ github.event_name }}
run: |
export GOPATH=${GITHUB_WORKSPACE}/go
export PATH=$PATH:$GOPATH/bin
if [ ! -z ${{ steps.check_staging.outputs.STAGING }} ]; then
export EXTRA_LDFLAGS="-X \"github.com/${{ github.repository }}/pkg/version.TiUPVerName=${{ steps.check_staging.outputs.STAGING }}\""
export REL_VER=${{ steps.check_staging.outputs.STAGING }}+staging
else
export REL_VER=`git describe --tags --always`
fi
if [ '${{ steps.check_nightly.outputs.NIGHTLY }}' == 'YES' ]; then
export REL_VER=nightly-$(date +%Y%m%d)
fi
echo ::set-output name=REL_VER::$REL_VER
BUILD_FLAGS='-trimpath -mod=readonly -modcacherw -buildvcs=false' make package && \
echo "Build success."
checksum_file=checksum.${{ matrix.os }}-${{ matrix.arch }}.txt
checksum_header="TiUP Bench $REL_VER (${actor}@${event}) ${{ github.run_id }}"
echo ${checksum_header} > ${checksum_file}
echo "sha256sum:" >> ${checksum_file}
sha256sum bin/* >> ${checksum_file}
echo "b2sum:" >> ${checksum_file}
b2sum bin/* >> ${checksum_file}
cat ${checksum_file}
- name: Set up tiup
id: init_tiup
working-directory: ${{ env.working-directory }}
env:
ARCH: ${{ matrix.os }}-${{ matrix.arch }}
REL_VER: ${{ steps.build_tiup_bench.outputs.REL_VER }}
run: |
TMP_DIR=`mktemp -d`
export TIUP_HOME="$TMP_DIR/home"
echo ::set-output name=TIUP_HOME::$TIUP_HOME
echo ::set-output name=TIUP_BIN::$TIUP_HOME/bin/tiup
rm -rf $TIUP_HOME && mkdir -p $TIUP_HOME/{bin,keys}
wget -O $TMP_DIR/tiup-linux-amd64.tar.gz -q https://tiup-mirrors.pingcap.com/tiup-linux-amd64.tar.gz
tar -zxf $TMP_DIR/tiup-linux-amd64.tar.gz -C $TIUP_HOME/bin && chmod 755 $TIUP_HOME/bin/tiup
curl -s https://tiup-mirrors.pingcap.com/root.json -o $TIUP_HOME/bin/root.json
cp $TIUP_HOME/bin/root.json bin/root.json
if [ ! -z ${{ steps.check_staging.outputs.STAGING }} ]; then
TIUP_MIRRORS=${{ secrets.TIUP_SERVER_STAGING }}
else
TIUP_MIRRORS=${{ secrets.TIUP_SERVER_PROD }}
fi
$TIUP_HOME/bin/tiup mirror set ${TIUP_MIRRORS}
echo ${{ secrets.TIUP_COMP_KEY_PINGCAP }} | base64 -d > $TIUP_HOME/keys/private.json
- name: Publish package
working-directory: ${{ env.working-directory }}
env:
TIUP_HOME: ${{ steps.init_tiup.outputs.TIUP_HOME }}
TIUP_BIN: ${{ steps.init_tiup.outputs.TIUP_BIN }}
REL_VER: ${{ steps.build_tiup_bench.outputs.REL_VER }}
ARCH: ${{ matrix.os }}-${{ matrix.arch }}
bench_desc: "Benchmark database with different workloads"
run: |
# add a random delay before actually publishing, this can help reduce manifest conflict
# when there are multiple jobs running in parallel
sleep $[ ( $RANDOM % 10 ) ]s
${TIUP_BIN} mirror publish bench ${REL_VER} tiup-bench-${REL_VER}-${ARCH}.tar.gz tiup-bench --arch ${{ matrix.arch }} --os ${{ matrix.os }} --desc="${bench_desc}"
- name: Upload the tarball to GitHub release
uses: ncipollo/release-action@v1
if: github.event_name == 'release'
with:
allowUpdates: true
artifacts: ${{ env.working-directory }}/tiup-bench-${{ steps.build_tiup_bench.outputs.REL_VER }}-${{ matrix.os }}-${{ matrix.arch }}.tar.gz
artifactContentType: application/gzip
omitBodyDuringUpdate: true
omitNameDuringUpdate: true
prerelease: ${{ github.event.release.prerelease }}
token: ${{ secrets.GITHUB_TOKEN }}