Skip to content

Bump danielpalme/ReportGenerator-GitHub-Action from 5.3.8 to 5.4.2 #839

Bump danielpalme/ReportGenerator-GitHub-Action from 5.3.8 to 5.4.2

Bump danielpalme/ReportGenerator-GitHub-Action from 5.3.8 to 5.4.2 #839

Workflow file for this run

name: CI
on:
# Trigger the workflow on push or pull request,
# for any branch or version tag
push:
branches:
- '**'
tags:
- 'v*.*.*'
pull_request:
branches:
- '**'
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Resolve project name
shell: pwsh
run: Add-Content -Path ${env:GITHUB_ENV} "`nprojectName=$(${env:GITHUB_REPOSITORY}.substring(${env:GITHUB_REPOSITORY}.IndexOf('/') + 1))" -Encoding utf8
- name: Checkout
uses: actions/[email protected]
with:
fetch-depth: 0
- name: Install GitVersion
uses: gittools/actions/gitversion/[email protected]
with:
versionSpec: '5.x'
- name: Use GitVersion
id: gitversion # step id used as reference for output values
uses: gittools/actions/gitversion/[email protected]
with:
useConfigFile: true
configFilePath: ./GitVersion.yml
- name: Update project version
uses: roryprimrose/[email protected]
with:
projectFilter: 'package.props'
version: ${{ steps.gitversion.outputs.NuGetVersionV2 }}
assemblyVersion: ${{ steps.gitversion.outputs.AssemblySemVer }}
fileVersion: ${{ steps.gitversion.outputs.MajorMinorPatch }}
informationalVersion: ${{ steps.gitversion.outputs.InformationalVersion }}
- name: Setup dotnet v9.0
uses: actions/[email protected]
with:
dotnet-version: '9.0.x' # SDK Version to use.
- name: Download snk file
run: echo "${{ secrets.SNK_FILE }}" | base64 --decode > Neovolve.Logging.Xunit.snk
- name: Restore
run: dotnet restore
- name: Build
run: dotnet build -c Release --no-restore
- name: Test
run: dotnet test -c Release --no-build /p:CollectCoverage=true /p:CoverletOutputFormat=cobertura
- name: Generate coverage report
# run: reportgenerator -reports:**/coverage.cobertura.xml -targetdir:Report -reporttypes:HtmlInline_AzurePipelines;Cobertura
uses: danielpalme/[email protected]
with:
reports: "**/coverage*cobertura.xml"
targetdir: "Report"
reporttypes: "HtmlInline;Cobertura"
tag: '${{ github.run_number }}_${{ github.run_id }}'
# Don't run on fork or dependabot builds
if: github.event_name == 'pull_request' && github.repository == github.event.pull_request.head.repo.full_name && github.actor != 'dependabot[bot]'
- name: Publish coverage report
uses: 5monkeys/cobertura-action@master
with:
path: Report/Cobertura.xml
repo_token: ${{ secrets.GITHUB_TOKEN }}
minimum_coverage: 75
# Don't run on fork or dependabot builds
if: github.event_name == 'pull_request' && github.repository == github.event.pull_request.head.repo.full_name && github.actor != 'dependabot[bot]'
- name: Pack
run: dotnet pack -c Release --no-build --include-symbols -o $GITHUB_WORKSPACE/staging
- name: Publish build artifacts
uses: actions/upload-artifact@v4
with:
name: packages
path: staging
- shell: bash
name: Write version
run: |
echo '${{ steps.gitversion.outputs.NuGetVersionV2 }}' > version.txt
- name: Upload version
uses: actions/upload-artifact@v4
with:
name: version
path: version.txt
publish:
needs: build
runs-on: ubuntu-latest
# Only run on pushes which should only be on the base repository
if: (github.event_name == 'push' || github.event_name == 'pull_request') && github.actor != 'dependabot[bot]'
steps:
- name: Resolve project name
shell: pwsh
run: Add-Content -Path ${env:GITHUB_ENV} "`nprojectName=$(${env:GITHUB_REPOSITORY}.substring(${env:GITHUB_REPOSITORY}.IndexOf('/') + 1))" -Encoding utf8
- name: Download version
uses: actions/download-artifact@v4
with:
name: version
- name: Read version
shell: bash
run: |
value=`cat version.txt`
echo NuGetVersionV2=$(echo $value) >> $GITHUB_ENV
- name: Download packages
uses: actions/download-artifact@v4
with:
name: packages
- name: Setup nuget
uses: nuget/setup-nuget@v2
- name: Download version
uses: actions/download-artifact@v4
with:
name: version
- name: Read version
shell: bash
run: |
value=`cat version.txt`
echo NuGetVersionV2=$(echo $value) >> $GITHUB_ENV
- name: Publish package to MyGet.org
env:
MYGET_APIKEY: ${{ secrets.MYGET_APIKEY }}
run: nuget push ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.symbols.nupkg $MYGET_APIKEY -source https://www.myget.org/F/neovolve/api/v2/package
- name: Publish signed package to MyGet.org
env:
MYGET_APIKEY: ${{ secrets.MYGET_APIKEY }}
run: nuget push ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.symbols.nupkg $MYGET_APIKEY -source https://www.myget.org/F/neovolve/api/v2/package
release:
needs: build
runs-on: ubuntu-latest
# Only run on pushes which should only be on the base repository and only where the branch is main or is a version tagged build
if: (github.event_name == 'push' || github.event_name == 'pull_request') && (github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v')) && github.actor != 'dependabot[bot]'
steps:
- name: Resolve project name
shell: pwsh
run: Add-Content -Path ${env:GITHUB_ENV} "`nprojectName=$(${env:GITHUB_REPOSITORY}.substring(${env:GITHUB_REPOSITORY}.IndexOf('/') + 1))" -Encoding utf8
- name: Download version
uses: actions/download-artifact@v4
with:
name: version
- name: Read version
shell: bash
run: |
value=`cat version.txt`
echo NuGetVersionV2=$(echo $value) >> $GITHUB_ENV
- name: Download packages
uses: actions/download-artifact@v4
with:
name: packages
- name: Setup nuget
uses: nuget/setup-nuget@v2
- name: Publish package to GitHub
run: nuget push ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.symbols.nupkg ${{ secrets.GITHUB_TOKEN }} -source "https://nuget.pkg.github.com/roryprimrose/index.json"
- name: Publish signed package to GitHub
run: nuget push ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.symbols.nupkg ${{ secrets.GITHUB_TOKEN }} -source "https://nuget.pkg.github.com/roryprimrose/index.json"
- name: Publish package to NuGet.org
env:
NUGET_APIKEY: ${{ secrets.NUGET_APIKEY }}
run: nuget push ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.symbols.nupkg $NUGET_APIKEY -source https://api.nuget.org/v3/index.json
- name: Publish signed package to NuGet.org
env:
NUGET_APIKEY: ${{ secrets.NUGET_APIKEY }}
run: nuget push ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.symbols.nupkg $NUGET_APIKEY -source https://api.nuget.org/v3/index.json
- name: Create release
id: create_release
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ env.NuGetVersionV2 }}
release_name: Release ${{ env.NuGetVersionV2 }}
draft: false
prerelease: ${{ contains(env.NuGetVersionV2, 'beta') }}
- name: Upload release asset for package
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.nupkg
asset_name: ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.nupkg
asset_content_type: application/zip
- name: Upload release asset for symbol package
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.symbols.nupkg
asset_name: ${{ env.projectName }}.${{ env.NuGetVersionV2 }}.symbols.nupkg
asset_content_type: application/zip
- name: Upload release asset for signed package
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.nupkg
asset_name: ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.nupkg
asset_content_type: application/zip
- name: Upload release asset for signed symbol package
uses: actions/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.symbols.nupkg
asset_name: ${{ env.projectName }}.Signed.${{ env.NuGetVersionV2 }}.symbols.nupkg
asset_content_type: application/zip