.NET Core Build and Release #47
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: .NET Core Build and Release | |
on: | |
push: | |
workflow_dispatch: | |
jobs: | |
build_and_test: | |
runs-on: ubuntu-latest | |
permissions: | |
packages: read | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-dotnet@v4 | |
with: | |
dotnet-version: "8.0.x" | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: "20" | |
#region jq | |
- name: Restore JQ cache | |
id: cache-jq | |
uses: actions/cache@v4 | |
with: | |
path: /usr/bin/jq | |
key: jq-${{ runner.os }}-${{ hashFiles('**/*.yml') }} | |
- name: Setup JQ | |
if: steps.cache-jq.outputs.cache-hit != 'true' | |
run: sudo apt-get install -y jq | |
#endregion | |
#region FFMpeg | |
- name: Restore FFmpeg cache | |
id: cache-ffmpeg | |
uses: actions/cache@v4 | |
with: | |
path: ffmpeg/ | |
key: ffmpeg-${{ runner.os }} | |
- name: Download FFmpeg | |
if: steps.cache-ffmpeg.outputs.cache-hit != 'true' | |
run: | | |
mkdir -p ffmpeg | |
wget -O ffmpeg.tar.xz https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-amd64-static.tar.xz | |
tar xvf ffmpeg.tar.xz -C ffmpeg --strip-components=1 | |
- name: Add FFmpeg into path | |
run: | | |
echo "$(pwd)/ffmpeg" >> $GITHUB_PATH | |
#endregion | |
- name: Compile LESS files | |
run: | | |
npm install -g less | |
lessc SwipetorApp/wwwroot/public/styles/public.less SwipetorApp/wwwroot/public/styles/public.css | |
lessc SwipetorApp/wwwroot/admin/styles/_main.less SwipetorApp/wwwroot/admin/styles/_main.css | |
rm -f SwipetorApp/wwwroot/public/styles/*.less | |
rm -f SwipetorApp/wwwroot/admin/styles/*.less | |
- name: Restore NuGet cache | |
uses: actions/cache@v4 | |
with: | |
path: ~/.nuget/packages | |
key: ${{ runner.os }}-nuget-${{ hashFiles('**/*.csproj', '**/*.fsproj', '**/*.vbproj') }} | |
restore-keys: | | |
${{ runner.os }}-nuget- | |
- name: Restore, Build and Test | |
run: | | |
dotnet nuget add source --username atas --password ${{ secrets.GITHUB_TOKEN }} --store-password-in-clear-text --name github "https://nuget.pkg.github.com/atas/index.json" | |
dotnet restore | |
dotnet build --no-restore | |
ffmpeg -version | |
dotnet test --no-build --verbosity normal --filter FullyQualifiedName~Tests | |
- name: Publish Application | |
run: dotnet publish --configuration Release --output ./publish | |
- name: Archive Published App | |
run: tar -czf swpserver.tar.gz -C ./publish . | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: swpserver | |
path: swpserver.tar.gz | |
release: | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write | |
needs: build_and_test | |
if: github.ref == 'refs/heads/main' | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- uses: actions/download-artifact@v4 | |
with: | |
name: swpserver | |
#region jq | |
- name: Restore JQ cache | |
id: cache-jq | |
uses: actions/cache@v4 | |
with: | |
path: /usr/bin/jq | |
key: jq-${{ runner.os }}-${{ hashFiles('**/*.yml') }} | |
- name: Setup JQ | |
if: steps.cache-jq.outputs.cache-hit != 'true' | |
run: sudo apt-get install -y jq | |
#endregion | |
- id: bump-release-calver | |
uses: atas/bump-release-calver-action@main | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Create GitHub Release | |
run: | | |
next_version="${{ steps.bump-release-calver.outputs.next_version }}" | |
echo "Next release version: $next_version" | |
mv swpserver.tar.gz swpserver-$next_version.tar.gz | |
COMMIT_MSG=$(git log -1 --pretty=%B) | |
gh release create "v$next_version" swpserver-$next_version.tar.gz\ | |
--title "Release v$next_version" \ | |
--notes "$COMMIT_MSG" | |
env: | |
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
deploy: | |
runs-on: ubuntu-latest | |
needs: release | |
if: github.ref == 'refs/heads/main' | |
environment: demo | |
steps: | |
- name: Set up SSH | |
run: | | |
mkdir -p ~/.ssh/ | |
ls -lha ~/.ssh | |
echo "${{ secrets.SSH_KEY }}" > ~/.ssh/id_ed25519 | |
chmod 600 ~/.ssh/id_ed25519 | |
ssh-keyscan -p ${{ secrets.SSH_PORT }} ${{ secrets.SSH_HOST }} >> ~/.ssh/known_hosts | |
- name: Trigger pull-deploy | |
run: | | |
ssh -p${{ secrets.SSH_PORT }} ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }} "/opt/swipetor/bin/pull-deploy/run.sh" |