From dedf4710382d5fd37cf74283a0fd54b365a32f3d Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Mon, 6 Oct 2025 10:00:48 +0900 Subject: [PATCH] Add push_gem.yml --- .github/workflows/push_gem.yml | 50 ++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 .github/workflows/push_gem.yml diff --git a/.github/workflows/push_gem.yml b/.github/workflows/push_gem.yml new file mode 100644 index 0000000..6feef80 --- /dev/null +++ b/.github/workflows/push_gem.yml @@ -0,0 +1,50 @@ +name: Publish gem to rubygems.org + +on: + push: + tags: + - 'v*' + +permissions: + contents: read + +jobs: + push: + if: startsWith(github.repository, 'ruby') + runs-on: ubuntu-latest + + environment: + name: rubygems.org + url: https://rubygems.org/gems/date + + permissions: + contents: write + id-token: write + + strategy: + matrix: + ruby: 3.4 + + steps: + - name: Harden Runner + uses: step-security/harden-runner@f4a75cfd619ee5ce8d5b864b0d183aff3c69b55a # v2.13.1 + with: + egress-policy: audit + + - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + + - name: Set up Ruby + uses: ruby/setup-ruby@eaecf785f6a34567a6d97f686bbb7bccc1ac1e5c # v1.237.0 + with: + bundler-cache: true + ruby-version: ${{ matrix.ruby }} + + - name: Publish to RubyGems + uses: rubygems/release-gem@a25424ba2ba8b387abc8ef40807c2c85b96cbe32 # v1.1.1 + + - name: Create GitHub release + run: | + tag_name="$(git describe --tags --abbrev=0)" + gh release create "${tag_name}" --verify-tag --generate-notes + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}