-
-
Notifications
You must be signed in to change notification settings - Fork 9
108 lines (93 loc) · 3.95 KB
/
psqldeko.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
name: .NET
on:
push:
branches:
- psqldeko
jobs:
build:
runs-on: self-hosted
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0 # This ensures all history is fetched
- name: Setup .NET
uses: actions/setup-dotnet@v2
with:
dotnet-version: 8.0.300
- name: Get previous tag
id: prev_tag
run: |
echo "prev_tag=$(git describe --tags --abbrev=0 2>/dev/null || echo '')" >> $GITHUB_ENV
- name: Get commit count since previous tag
id: commit_count
run: |
if [ -z "${{ env.prev_tag }}" ]; then
commit_count=$(git rev-list --count HEAD)
else
commit_count=$(git rev-list --count ${{ env.prev_tag }}..HEAD)
fi
echo "commit_count=$commit_count" >> $GITHUB_ENV
echo "count=$commit_count" >> $GITHUB_OUTPUT
- name: Build Skipped
if: ${{ steps.commit_count.outputs.count < 20 }}
run: echo "Build skipped because there are less than 20 commits since last build."
- name: Restore dependencies Mewdeko
if: ${{ steps.commit_count.outputs.count >= 20 }}
run: dotnet restore src/Mewdeko/Mewdeko.csproj
- name: Build Mewdeko
if: ${{ steps.commit_count.outputs.count >= 20 }}
run: dotnet publish src/Mewdeko/Mewdeko.csproj --no-restore -c Release -r win-x64 --self-contained true -p:PublishSingleFile=true -p:PublishTrimmed=false -p:IncludeNativeLibrariesForSelfExtract=true -p:UseAppHost=true -o output/
- name: Test
if: ${{ steps.commit_count.outputs.count >= 20 }}
run: dotnet test --no-restore --verbosity normal
- name: Zip artifacts
if: ${{ steps.commit_count.outputs.count >= 20 }}
run: |
cd output
find . -name "*.pdb" -delete
zip -r ../MewdekoPsql-win64.zip .
- name: Get current date
if: ${{ steps.commit_count.outputs.count >= 20 }}
id: get_date
run: echo "date=$(date +'%Y-%m-%d')" >> $GITHUB_ENV
- name: Get commit messages with links
if: ${{ steps.commit_count.outputs.count >= 20 }}
id: commit_messages
run: |
if [ -z "${{ env.prev_tag }}" ]; then
echo 'messages<<EOF' >> $GITHUB_ENV
git log -1 --pretty=format:"* [%h](https://github.com/${{ github.repository }}/commit/%H) %s" >> $GITHUB_ENV
echo '' >> $GITHUB_ENV
echo 'EOF' >> $GITHUB_ENV
else
echo 'messages<<EOF' >> $GITHUB_ENV
git log --pretty=format:"* [%h](https://github.com/${{ github.repository }}/commit/%H) %s" ${{ env.prev_tag }}..HEAD >> $GITHUB_ENV
echo '' >> $GITHUB_ENV
echo 'EOF' >> $GITHUB_ENV
fi
- name: Create Release
if: ${{ steps.commit_count.outputs.count >= 20 }}
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: psqldeko-${{ github.run_number }}
release_name: PsqlDeko build ${{ github.run_number }} (${{ env.date }})
body: |
Automated psql build for commit ${{ github.sha }}
# WARNING: Mewdeko on PSQL is in early beta and has missing features. If you find bugs please report them.
## Commits since previous release:
${{ env.messages }}
draft: false
prerelease: true
- name: Upload Release Asset
if: ${{ steps.commit_count.outputs.count >= 20 }}
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./MewdekoPsql-win64.zip
asset_name: MewdekoPsql-win64.zip
asset_content_type: application/zip