-
-
Notifications
You must be signed in to change notification settings - Fork 9
152 lines (132 loc) · 5.82 KB
/
publish.yml
File metadata and controls
152 lines (132 loc) · 5.82 KB
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json
name: publish
on:
workflow_dispatch: # Allow running the workflow manually from the GitHub UI
release:
types:
- published # Run the workflow when a new GitHub release is published
env:
DOTNET_SKIP_FIRST_TIME_EXPERIENCE: 1
DOTNET_NOLOGO: true
NuGetDirectory: ${{ github.workspace}}/nuget
defaults:
run:
shell: bash
jobs:
create_nuget:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0 # Get all history to allow automatic versioning using MinVer
submodules: recursive # Required for LivekitRtc which depends on rust-sdks submodule
# Install the .NET SDK indicated in the global.json file
- name: Setup .NET
uses: actions/setup-dotnet@v4
# Determine which project to pack based on release tag
- name: Determine project to pack
id: determine_project
run: |
TAG="${{ github.event.release.tag_name }}"
if [[ "$TAG" == api-* ]]; then
echo "project=LivekitApi/LivekitApi.csproj" >> "$GITHUB_OUTPUT"
echo "project_name=LivekitApi" >> "$GITHUB_OUTPUT"
elif [[ "$TAG" == rtc-* ]]; then
echo "project=LivekitRtc/LivekitRtc.csproj" >> "$GITHUB_OUTPUT"
echo "project_name=LivekitRtc" >> "$GITHUB_OUTPUT"
else
echo "Invalid tag format. Expected 'api-X.Y.Z' or 'rtc-X.Y.Z', got '$TAG'" >&2
exit 1
fi
# Create the NuGet package for the specific project
- name: Pack NuGet package
run: dotnet pack ${{ steps.determine_project.outputs.project }} -c Release --output ${{ env.NuGetDirectory }}
# Publish the NuGet package as an artifact, so they can be used in the following jobs
- uses: actions/upload-artifact@v4
with:
name: nuget
if-no-files-found: error
retention-days: 7
path: ${{ env.NuGetDirectory }}/*.nupkg
validate_nuget:
runs-on: ubuntu-latest
needs: [create_nuget]
steps:
# Install the .NET SDK indicated in the global.json file
- name: Setup .NET
uses: actions/setup-dotnet@v4
# Download the NuGet package created in the previous job
- uses: actions/download-artifact@v4
with:
name: nuget
path: ${{ env.NuGetDirectory }}
- name: Install nuget validator
run: dotnet tool update Meziantou.Framework.NuGetPackageValidation.Tool --global
# Validate metadata and content of the NuGet package
# https://www.nuget.org/packages/Meziantou.Framework.NuGetPackageValidation.Tool#readme-body-tab
# If some rules are not applicable, you can disable them
# using the --excluded-rules or --excluded-rule-ids option
- name: Validate package
run: meziantou.validate-nuget-package --excluded-rules IconMustBeSet "${{ env.NuGetDirectory }}"/*.nupkg
run_test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
submodules: recursive # Required for LivekitRtc which depends on rust-sdks submodule
- name: Setup .NET
uses: actions/setup-dotnet@v4
- name: Run tests
run: dotnet test -c Release
deploy:
# Publish only when creating a GitHub Release
# https://docs.github.com/en/repositories/releasing-projects-on-github/managing-releases-in-a-repository
# You can update this logic if you want to manage releases differently
if: github.event_name == 'release'
runs-on: ubuntu-latest
needs: [validate_nuget, run_test]
steps:
# Download the NuGet package created in the previous job
- uses: actions/download-artifact@v4
with:
name: nuget
path: ${{ env.NuGetDirectory }}
# Install the .NET SDK indicated in the global.json file
- name: Setup .NET Core
uses: actions/setup-dotnet@v4
# Publish all NuGet packages to NuGet.org
# Use --skip-duplicate to prevent errors if a package with the same version already exists.
# If you retry a failed workflow, already published packages will be skipped without error.
- name: Publish NuGet package
run: |
for file in "${{ env.NuGetDirectory }}"/*.nupkg; do
dotnet nuget push "$file" --api-key "${{ secrets.NUGET_APIKEY }}" --source https://api.nuget.org/v3/index.json --skip-duplicate
done
- uses: actions/checkout@v4
with:
ref: main
- name: Post release steps
run: |
TAG="${{ github.event.release.tag_name }}"
# Determine which package to update based on tag prefix
# Expected tag formats: api-X.Y.Z or rtc-X.Y.Z
if [[ "$TAG" == api-* ]]; then
# API package release
VERSION="${TAG#api-}"
echo "Updating LivekitApi to version $VERSION"
sed -i "s|<PackageValidationBaselineVersion>.*</PackageValidationBaselineVersion>|<PackageValidationBaselineVersion>$VERSION</PackageValidationBaselineVersion>|" LivekitApi/LivekitApi.csproj
rm -f LivekitApi/CompatibilitySuppressions.xml
elif [[ "$TAG" == rtc-* ]]; then
# RTC package release
VERSION="${TAG#rtc-}"
echo "Updating LivekitRtc to version $VERSION"
sed -i "s|<PackageValidationBaselineVersion>.*</PackageValidationBaselineVersion>|<PackageValidationBaselineVersion>$VERSION</PackageValidationBaselineVersion>|" LivekitRtc/LivekitRtc.csproj
rm -f LivekitRtc/CompatibilitySuppressions.xml
else
echo "Invalid tag format. Expected 'api-X.Y.Z' or 'rtc-X.Y.Z'" >&2
exit 1
fi
- name: Push changes
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: "Post steps release ${{ github.event.release.tag_name }}"