chore: better workflow

This commit is contained in:
wwqgtxx 2023-01-15 15:04:27 +08:00
parent 2c80155c6f
commit 3b53f5bca3
5 changed files with 187 additions and 50 deletions

17
.github/release-cgo-android.sh vendored Normal file
View file

@ -0,0 +1,17 @@
#!/bin/bash
BRANCH=$(git branch --show-current)
if [ "$BRANCH" = "Alpha" ];then
VERSION=alpha-$(git rev-parse --short HEAD)
elif [ "$BRANCH" = "Beta" ]; then
VERSION=beta-$(git rev-parse --short HEAD)
elif [ "$BRANCH" = "" ]; then
VERSION=$(git describe --tags)
else
VERSION=$(git rev-parse --short HEAD)
fi
CC=${ANDROID_NDK_HOME}/toolchains/llvm/prebuilt/linux-x86_64/bin/aarch64-linux-android33-clang
Ldflags="-X 'github.com/Dreamacro/clash/constant.Version=${VERSION}' -X 'github.com/Dreamacro/clash/constant.BuildTime=${BUILDTIME}' -w -s -buildid="
CGO_ENABLED=1 go build -tags with_gvisor,with_lwip -trimpath -ldflags "${Ldflags}" -o bin/clash.meta-android-arm64

18
.github/release-cgo.sh vendored Normal file
View file

@ -0,0 +1,18 @@
#!/bin/bash
BRANCH=$(git branch --show-current)
if [ "$BRANCH" = "Alpha" ];then
VERSION=alpha-$(git rev-parse --short HEAD)
elif [ "$BRANCH" = "Beta" ]; then
VERSION=beta-$(git rev-parse --short HEAD)
elif [ "$BRANCH" = "" ]; then
VERSION=$(git describe --tags)
else
VERSION=$(git rev-parse --short HEAD)
fi
xgoTarget=windows/*,linux/*,darwin-10.16/*
xgoTags=with_gvisor,with_lwip
Ldflags="-X 'github.com/Dreamacro/clash/constant.Version=${VERSION}' -X 'github.com/Dreamacro/clash/constant.BuildTime=${BUILDTIME}' -w -s -buildid="
xgo --branch ${BRANCH} --out=${BINDIR}/${NAME} --targets="${xgoTarget}" --tags="${xgoTags}" -ldflags="${Ldflags}" github.com/${REPO}

View file

@ -5,22 +5,22 @@ for FILENAME in $FILENAMES
do do
if [[ $FILENAME =~ "darwin-10.16-arm64" ]];then if [[ $FILENAME =~ "darwin-10.16-arm64" ]];then
echo "rename darwin-10.16-arm64 $FILENAME" echo "rename darwin-10.16-arm64 $FILENAME"
mv $FILENAME clash.meta-darwin-arm64-${VERSION}-${ShortSHA} mv $FILENAME clash.meta-darwin-arm64-cgo-${VERSION}-${ShortSHA}
elif [[ $FILENAME =~ "darwin-10.16-amd64" ]];then elif [[ $FILENAME =~ "darwin-10.16-amd64" ]];then
echo "rename darwin-10.16-amd64 $FILENAME" echo "rename darwin-10.16-amd64 $FILENAME"
mv $FILENAME clash.meta-darwin-amd64-${VERSION}-${ShortSHA} mv $FILENAME clash.meta-darwin-amd64-cgo-${VERSION}-${ShortSHA}
elif [[ $FILENAME =~ "windows-4.0-386" ]];then elif [[ $FILENAME =~ "windows-4.0-386" ]];then
echo "rename windows 386 $FILENAME" echo "rename windows 386 $FILENAME"
mv $FILENAME clash.meta-windows-386-${VERSION}-${ShortSHA}.exe mv $FILENAME clash.meta-windows-386-cgo-${VERSION}-${ShortSHA}.exe
elif [[ $FILENAME =~ "windows-4.0-amd64" ]];then elif [[ $FILENAME =~ "windows-4.0-amd64" ]];then
echo "rename windows amd64 $FILENAME" echo "rename windows amd64 $FILENAME"
mv $FILENAME clash.meta-windows-amd64-${VERSION}-${ShortSHA}.exe mv $FILENAME clash.meta-windows-amd64-cgo-${VERSION}-${ShortSHA}.exe
elif [[ $FILENAME =~ "linux" ]];then elif [[ $FILENAME =~ "linux" ]];then
echo "rename linux $FILENAME" echo "rename linux $FILENAME"
mv $FILENAME $FILENAME-${VERSION}-${ShortSHA} mv $FILENAME $FILENAME-cgo-${VERSION}-${ShortSHA}
elif [[ $FILENAME =~ "android" ]];then elif [[ $FILENAME =~ "android" ]];then
echo "rename android $FILENAME" echo "rename android $FILENAME"
mv $FILENAME $FILENAME-${VERSION}-${ShortSHA} mv $FILENAME $FILENAME-cgo-${VERSION}-${ShortSHA}
else echo "skip $FILENAME" else echo "skip $FILENAME"
fi fi
done done

View file

@ -10,7 +10,49 @@ on:
- Alpha - Alpha
- Beta - Beta
jobs: jobs:
Build-Prerelease: Build-Prerelease-WithoutCGO:
runs-on: ubuntu-latest
steps:
- name: Check out code into the Go module directory
uses: actions/checkout@v3
- name: Setup Go
uses: actions/setup-go@v3
with:
go-version: '1.19'
check-latest: true
- name: Cache go module
uses: actions/cache@v3
with:
path: |
~/.cache/go-build
~/go/pkg/mod
key: ${{ runner.os }}-go-WithoutCGO-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-WithoutCGO-
${{ runner.os }}-go-
- name: Test
if: ${{github.ref_name=='Beta'}}
run: |
go test ./...
- name: Build
if: success()
env:
NAME: Clash.Meta
BINDIR: bin
run: make -j$(($(nproc) + 1)) releases
- name: Delete current release assets
uses: andreaswilli/delete-release-assets-action@v2.0.0
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
tag: Prerelease-${{ github.ref_name }}
deleteOnlyFromDrafts: false
Build-Prerelease-WithCGO:
permissions: write-all permissions: write-all
runs-on: ubuntu-22.04 runs-on: ubuntu-22.04
@ -19,13 +61,13 @@ jobs:
uses: actions/checkout@v3 uses: actions/checkout@v3
- name: Set variables - name: Set variables
if: ${{ github.ref_name }} == Alpha if: ${{github.ref_name=='Alpha'}}
run: echo "VERSION=master" >> $GITHUB_ENV run: echo "VERSION=alpha" >> $GITHUB_ENV
shell: bash shell: bash
- name: Set variables - name: Set variables
if: ${{ github.ref_name }} == Beta if: ${{github.ref_name=='Beta'}}
run: echo "VERSION=alpha" >> $GITHUB_ENV run: echo "VERSION=beta" >> $GITHUB_ENV
shell: bash shell: bash
- name: Set ENV - name: Set ENV
@ -33,8 +75,6 @@ jobs:
echo "NAME=clash.meta" >> $GITHUB_ENV echo "NAME=clash.meta" >> $GITHUB_ENV
echo "BUILD_TIME=$(date +%Y%m%d%H%M)" >> $GITHUB_ENV echo "BUILD_TIME=$(date +%Y%m%d%H%M)" >> $GITHUB_ENV
echo "REPO=${{ github.repository }}" >> $GITHUB_ENV echo "REPO=${{ github.repository }}" >> $GITHUB_ENV
echo "TARGET=windows/*,linux/*,darwin-10.16/*" >> $GITHUB_ENV
echo "TAGS=with_gvisor,with_lwip" >> $GITHUB_ENV
echo "ShortSHA=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_ENV echo "ShortSHA=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_ENV
echo "$ShortSHA" echo "$ShortSHA"
echo "$REPO" echo "$REPO"
@ -45,18 +85,6 @@ jobs:
with: with:
go-version: '1.19' go-version: '1.19'
check-latest: true check-latest: true
cache: true
- uses: nttld/setup-ndk@v1
id: setup-ndk
with:
ndk-version: r25b
add-to-path: false
- name: Go Test
if: ${{github.ref_name=='Beta'}}
run: |
go test ./...
- name: Set up xgo - name: Set up xgo
run: | run: |
@ -69,23 +97,111 @@ jobs:
ANDROID_NDK_HOME: ${{ steps.setup-ndk.outputs.ndk-path }} ANDROID_NDK_HOME: ${{ steps.setup-ndk.outputs.ndk-path }}
run: | run: |
mkdir bin mkdir bin
make android-arm64 cp .github/release-cgo.sh ./bin/
make xgoall cp .github/rename-cgo.sh ./bin/
cp release.sh ./bin/
cd bin cd bin
ls -la ls -la
chmod +x * chmod +x *
bash ./release.sh bash ./release-cgo.sh
rm ./release.sh rm ./release-cgo.sh
bash ./rename-cgo.sh
rm ./rename-cgo.sh
ls -la ls -la
cd .. cd ..
- name: Delete current release assets - uses: actions/upload-artifact@v3
uses: andreaswilli/delete-release-assets-action@v2.0.0 if: ${{ success() }}
with: with:
github_token: ${{ secrets.GITHUB_TOKEN }} name: artifact
tag: Prerelease-${{ github.ref_name }} path: bin/
deleteOnlyFromDrafts: false
Build-Prerelease-WithCGO-Android:
permissions: write-all
runs-on: ubuntu-22.04
steps:
- name: Check out code into the Go module directory
uses: actions/checkout@v3
- name: Set variables
if: ${{github.ref_name=='Alpha'}}
run: echo "VERSION=alpha" >> $GITHUB_ENV
shell: bash
- name: Set variables
if: ${{github.ref_name=='Beta'}}
run: echo "VERSION=beta" >> $GITHUB_ENV
shell: bash
- name: Set ENV
run: |
echo "NAME=clash.meta" >> $GITHUB_ENV
echo "BUILD_TIME=$(date +%Y%m%d%H%M)" >> $GITHUB_ENV
echo "REPO=${{ github.repository }}" >> $GITHUB_ENV
echo "ShortSHA=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_ENV
echo "$ShortSHA"
echo "$REPO"
shell: bash
- name: Setup Go
uses: actions/setup-go@v3
with:
go-version: '1.19'
check-latest: true
- name: Cache go module
uses: actions/cache@v3
with:
path: |
~/.cache/go-build
~/go/pkg/mod
key: ${{ runner.os }}-go-WithCGO-Android-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-WithCGO-Android-
${{ runner.os }}-go-
- uses: nttld/setup-ndk@v1
id: setup-ndk
with:
ndk-version: r25b
add-to-path: false
- name: Build
if: success()
env:
ANDROID_NDK_HOME: ${{ steps.setup-ndk.outputs.ndk-path }}
run: |
mkdir bin
cp .github/release-cgo-android.sh ./
bash ./release-cgo-android.sh
rm ./release-cgo-android.sh
cp .github/rename-cgo.sh ./bin/
cd bin
ls -la
chmod +x *
bash ./rename-cgo.sh
rm ./rename-cgo.sh
ls -la
cd ..
- uses: actions/upload-artifact@v3
if: ${{ success() }}
with:
name: artifact
path: bin/
Upload-Prerelease:
needs: [ Build-Prerelease-WithoutCGO, Build-Prerelease-WithCGO, Build-Prerelease-WithCGO-Android ]
runs-on: ubuntu-latest
steps:
- uses: actions/download-artifact@v3
with:
name: artifact
path: bin/
- name: Display structure of downloaded files
run: ls -R
working-directory: bin
- name: Tag Repo - name: Tag Repo
uses: richardsimko/update-tag@v1 uses: richardsimko/update-tag@v1

View file

@ -47,23 +47,9 @@ all:linux-amd64 linux-arm64\
darwin-amd64 darwin-arm64\ darwin-amd64 darwin-arm64\
windows-amd64 windows-arm64\ windows-amd64 windows-arm64\
xgoTarget = windows/*,linux/*,darwin-10.16/*
xgoTags = with_gvisor,with_lwip
Ldflags =-X "github.com/Dreamacro/clash/constant.Version=$(VERSION)" -X "github.com/Dreamacro/clash/constant.BuildTime=$(BUILDTIME)" -w -s -buildid=
xgoall: SHELL:=/bin/bash
xgoall:
xgo --branch $(BRANCH) --out=$(BINDIR)/$(NAME) --targets='$(xgoTarget)' --tags='$(xgoTags)' -ldflags='$(Ldflags)' github.com/$(REPO)
darwin-all: darwin-amd64 darwin-arm64 darwin-all: darwin-amd64 darwin-arm64
GOBUILDCGO = CGO_ENABLED=1 go build -tags with_gvisor,with_lwip -trimpath -ldflags '-X "github.com/Dreamacro/clash/constant.Version=$(VERSION)" \
-X "github.com/Dreamacro/clash/constant.BuildTime=$(BUILDTIME)" \
-w -s -buildid='
CCAndroid=$(ANDROID_NDK_HOME)/toolchains/llvm/prebuilt/linux-x86_64/bin/aarch64-linux-android33-clang
docker: docker:
GOAMD64=v3 $(GOBUILD) -o $(BINDIR)/$(NAME)-$@ GOAMD64=v3 $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
@ -116,7 +102,7 @@ linux-mips64le:
GOARCH=mips64le GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@ GOARCH=mips64le GOOS=linux $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
android-arm64: android-arm64:
CC=$(CCAndroid) GOARCH=arm64 GOOS=android $(GOBUILDCGO) -o $(BINDIR)/$(NAME)-$@ GOARCH=arm64 GOOS=android $(GOBUILD) -o $(BINDIR)/$(NAME)-$@
freebsd-386: freebsd-386:
GOARCH=386 GOOS=freebsd $(GOBUILD) -o $(BINDIR)/$(NAME)-$@ GOARCH=386 GOOS=freebsd $(GOBUILD) -o $(BINDIR)/$(NAME)-$@