Skip to content

Commit f8a9040

Browse files
authored
Merge pull request voxpupuli#66 from voxpupuli/ci
CI: Configure Vox Pupuli release defaults & Set minimal token permissions & Generate matrix dynamically
2 parents 89cc7c1 + fde94c5 commit f8a9040

File tree

4 files changed

+162
-27
lines changed

4 files changed

+162
-27
lines changed

.github/release.yml

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
---
2+
# https://docs.github.com/en/repositories/releasing-projects-on-github/automatically-generated-release-notes
3+
4+
changelog:
5+
exclude:
6+
labels:
7+
- duplicate
8+
- invalid
9+
- modulesync
10+
- question
11+
- skip-changelog
12+
- wont-fix
13+
- wontfix
14+
- github_actions
15+
16+
categories:
17+
- title: Breaking Changes 🛠
18+
labels:
19+
- backwards-incompatible
20+
21+
- title: New Features 🎉
22+
labels:
23+
- enhancement
24+
25+
- title: Bug Fixes 🐛
26+
labels:
27+
- bug
28+
- bugfix
29+
30+
- title: Documentation Updates 📚
31+
labels:
32+
- documentation
33+
- docs
34+
35+
- title: Dependency Updates ⬆️
36+
labels:
37+
- dependencies
38+
39+
- title: Other Changes
40+
labels:
41+
- "*"

.github/workflows/release.yml

Lines changed: 90 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -1,32 +1,106 @@
1-
name: Release
1+
---
2+
name: Gem Release
23

34
on:
45
push:
56
tags:
67
- '*'
78

9+
permissions: {}
10+
811
jobs:
9-
release:
10-
runs-on: ubuntu-latest
12+
build-release:
13+
# Prevent releases from forked repositories
1114
if: github.repository_owner == 'voxpupuli'
15+
name: Build the gem
16+
runs-on: ubuntu-24.04
1217
steps:
1318
- uses: actions/checkout@v4
14-
- name: Install Ruby 3.0
19+
- name: Install Ruby
1520
uses: ruby/setup-ruby@v1
1621
with:
17-
ruby-version: '3.0'
18-
env:
19-
BUNDLE_WITHOUT: release
22+
ruby-version: 'ruby'
2023
- name: Build gem
21-
run: gem build --strict --verbose *.gemspec
24+
shell: bash
25+
run: gem build --verbose *.gemspec
26+
- name: Upload gem to GitHub cache
27+
uses: actions/upload-artifact@v4
28+
with:
29+
name: gem-artifact
30+
path: '*.gem'
31+
retention-days: 1
32+
compression-level: 0
33+
34+
create-github-release:
35+
needs: build-release
36+
name: Create GitHub release
37+
runs-on: ubuntu-24.04
38+
permissions:
39+
contents: write # clone repo and create release
40+
steps:
41+
- name: Download gem from GitHub cache
42+
uses: actions/download-artifact@v5
43+
with:
44+
name: gem-artifact
45+
- name: Create Release
46+
shell: bash
47+
env:
48+
GH_TOKEN: ${{ github.token }}
49+
run: gh release create --repo ${{ github.repository }} ${{ github.ref_name }} --generate-notes *.gem
50+
51+
release-to-github:
52+
needs: build-release
53+
name: Release to GitHub
54+
runs-on: ubuntu-24.04
55+
permissions:
56+
packages: write # publish to rubygems.pkg.github.com
57+
steps:
58+
- name: Download gem from GitHub cache
59+
uses: actions/download-artifact@v5
60+
with:
61+
name: gem-artifact
62+
- name: Publish gem to GitHub packages
63+
run: gem push --host https://rubygems.pkg.github.com/${{ github.repository_owner }} *.gem
64+
env:
65+
GEM_HOST_API_KEY: ${{ secrets.GITHUB_TOKEN }}
66+
67+
release-to-rubygems:
68+
needs: build-release
69+
name: Release gem to rubygems.org
70+
runs-on: ubuntu-24.04
71+
environment: release # recommended by rubygems.org
72+
permissions:
73+
id-token: write # rubygems.org authentication
74+
steps:
75+
- name: Download gem from GitHub cache
76+
uses: actions/download-artifact@v5
77+
with:
78+
name: gem-artifact
79+
- uses: rubygems/[email protected]
2280
- name: Publish gem to rubygems.org
81+
shell: bash
2382
run: gem push *.gem
24-
env:
25-
GEM_HOST_API_KEY: '${{ secrets.RUBYGEMS_AUTH_TOKEN }}'
26-
- name: Setup GitHub packages access
83+
84+
release-verification:
85+
name: Check that all releases are done
86+
runs-on: ubuntu-24.04
87+
permissions:
88+
contents: read # minimal permissions that we have to grant
89+
needs:
90+
- create-github-release
91+
- release-to-github
92+
- release-to-rubygems
93+
steps:
94+
- name: Download gem from GitHub cache
95+
uses: actions/download-artifact@v5
96+
with:
97+
name: gem-artifact
98+
- name: Install Ruby
99+
uses: ruby/setup-ruby@v1
100+
with:
101+
ruby-version: 'ruby'
102+
- name: Wait for release to propagate
103+
shell: bash
27104
run: |
28-
mkdir -p ~/.gem
29-
echo ":github: Bearer ${{ secrets.GITHUB_TOKEN }}" >> ~/.gem/credentials
30-
chmod 0600 ~/.gem/credentials
31-
- name: Publish gem to GitHub packages
32-
run: gem push --key github --host https://rubygems.pkg.github.com/voxpupuli *.gem
105+
gem install rubygems-await
106+
gem await *.gem

.github/workflows/test.yml

Lines changed: 30 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,4 @@
1+
---
12
name: Test
23

34
on:
@@ -6,20 +7,33 @@ on:
67
branches:
78
- master
89

9-
env:
10-
BUNDLE_WITHOUT: release
10+
permissions:
11+
contents: read
1112

1213
jobs:
14+
rubocop_and_matrix:
15+
runs-on: ubuntu-24.04
16+
outputs:
17+
ruby: ${{ steps.ruby.outputs.versions }}
18+
steps:
19+
- uses: actions/checkout@v4
20+
- name: Install Ruby ${{ matrix.ruby }}
21+
uses: ruby/setup-ruby@v1
22+
with:
23+
ruby-version: "3.4"
24+
bundler-cache: true
25+
- name: Run Rubocop
26+
run: bundle exec rake rubocop
27+
- id: ruby
28+
uses: voxpupuli/ruby-version@v1
29+
1330
test:
14-
runs-on: ubuntu-latest
31+
runs-on: ubuntu-24.04
32+
needs: rubocop_and_matrix
1533
strategy:
1634
fail-fast: false
1735
matrix:
18-
include:
19-
- ruby: "2.7"
20-
- ruby: "3.0"
21-
- ruby: "3.1"
22-
- ruby: "3.2"
36+
ruby: ${{ fromJSON(needs.rubocop_and_matrix.outputs.ruby) }}
2337
steps:
2438
- uses: actions/checkout@v4
2539
- name: Install Ruby ${{ matrix.ruby }}
@@ -31,10 +45,16 @@ jobs:
3145
run: bundle exec rake rubocop
3246
- name: Build the gem
3347
run: gem build --strict --verbose *.gemspec
48+
3449
tests:
50+
if: always()
3551
needs:
52+
- rubocop_and_matrix
3653
- test
37-
runs-on: ubuntu-latest
54+
runs-on: ubuntu-24.04
3855
name: Test suite
3956
steps:
40-
- run: echo Test suite completed
57+
- name: Decide whether the needed jobs succeeded or failed
58+
uses: re-actors/alls-green@release/v1
59+
with:
60+
jobs: ${{ toJSON(needs) }}

Gemfile

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@ source 'https://rubygems.org'
44

55
gemspec
66

7-
group :release do
7+
group :release, optional: true do
88
gem 'faraday-retry', '~> 2.1', require: false
99
gem 'github_changelog_generator', '~> 1.16.4', require: false
1010
end

0 commit comments

Comments
 (0)