Skip to content

Release notes automatiques #41

Release notes automatiques

Release notes automatiques #41

name: Create release notes
#on:
# workflow_call:
# inputs:
# tag:
# type: string
# required: true
# secrets:
# GITHUB_TOKEN:
# required: true
on:
pull_request:
types: [ opened, ready_for_review, review_requested, synchronize ]
jobs:
create-release-notes:
name: Create release notes
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Get tag of latest release
id: get-latest-release-tag
uses: actions/github-script@v7
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
const latestRelease = await github.request(`GET /repos/${{ github.repository }}/releases/latest`)
return latestRelease.data.tag_name
result-encoding: string
- name: Generate release notes from latest release
id: generate-release-notes
uses: actions/github-script@v7
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
const releaseNotes = await github.request(`POST /repos/${{ github.repository }}/releases/generate-notes`, {
tag_name: "v651",
previous_tag_name: `${{steps.get-latest-release-tag.outputs.result}}` })
console.log(releaseNotes)
console.log("1--")
console.log(releaseNotes.data)
console.log("2--")
console.log(releaseNotes.data.name)
console.log(releaseNotes.data.body)
return releaseNotes.data
- name: Create release
uses: actions/github-script@v7
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
console.log(`${{steps.generate-release-notes.outputs.result}}`)
const releaseNotes = JSON.parse(`${{steps.generate-release-notes.outputs.result}}`)
console.log("releaseNotes.name")
console.log(releaseNotes.name)
await github.request(`POST /repos/${{ github.repository }}/releases`, {
tag_name: "v651",
name: `${releaseNotes.name}`,
body: `${releaseNotes.body}`})