Skip to content

Add CI to build the release #1

Add CI to build the release

Add CI to build the release #1

Workflow file for this run

name: Build and Release
on:
push:
tags:
- '*'
jobs:
build:
name: Build and Release Go Code
runs-on: ubuntu-latest
strategy:
matrix:
go-version: [1.18]
os: [linux, darwin]
arch: [amd64, arm64]
steps:
- name: Set up Go
uses: actions/setup-go@v3
with:
go-version: ${{ matrix.go-version }}
- name: Check out code
uses: actions/checkout@v3
- name: Set up QEMU (only for Linux)
if: matrix.os == 'linux'
uses: docker/setup-qemu-action@v1
- name: Set up Docker Buildx (only for Linux)
if: matrix.os == 'linux'
uses: docker/setup-buildx-action@v1
- name: Login to DockerHub (only for Linux)
if: matrix.os == 'linux'
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build binary
run: |
GOOS=${{ matrix.os }} GOARCH=${{ matrix.arch }} go build -o talm-${{ matrix.os }}-${{ matrix.arch }} ./main.go
- name: Upload Artifacts
uses: actions/upload-artifact@v3
with:
name: talm-${{ matrix.os }}-${{ matrix.arch }}
path: talm-${{ matrix.os }}-${{ matrix.arch }}
release:
needs: build
runs-on: ubuntu-latest
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/')
steps:
- name: Download Artifacts
uses: actions/download-artifact@v3
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ github.ref }}
release_name: Release ${{ github.ref_name }}
draft: false
prerelease: false
- name: Upload Release Asset
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./talm-${{ matrix.os }}-${{ matrix.arch }}
asset_name: talm-${{ matrix.os }}-${{ matrix.arch }}
asset_content_type: application/octet-stream