From 9e11192a03eef2b7a5601b2837a510ddc42553a2 Mon Sep 17 00:00:00 2001 From: Glenn Jocher Date: Sat, 31 Aug 2024 19:40:56 +0200 Subject: [PATCH] Update publish.yml (#15932) --- .github/workflows/publish.yml | 69 ++--------------------------------- 1 file changed, 3 insertions(+), 66 deletions(-) diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index 4f7fd5b6..24e75705 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -34,7 +34,7 @@ jobs: - name: Install dependencies run: | python -m pip install --upgrade pip wheel - pip install openai requests build twine toml + pip install requests build twine toml - name: Check PyPI version shell: python run: | @@ -97,72 +97,9 @@ jobs: GITHUB_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN || secrets.GITHUB_TOKEN }} CURRENT_TAG: ${{ steps.check_pypi.outputs.version }} PREVIOUS_TAG: ${{ steps.check_pypi.outputs.previous_version }} - shell: python run: | - import openai - import os - import requests - import json - import subprocess - - # Retrieve environment variables - OPENAI_API_KEY = os.getenv('OPENAI_API_KEY') - GITHUB_TOKEN = os.getenv('GITHUB_TOKEN') - CURRENT_TAG = os.getenv('CURRENT_TAG') - PREVIOUS_TAG = os.getenv('PREVIOUS_TAG') - - # Check for required environment variables - if not all([OPENAI_API_KEY, GITHUB_TOKEN, CURRENT_TAG, PREVIOUS_TAG]): - raise ValueError("One or more required environment variables are missing.") - - latest_tag = f"v{CURRENT_TAG}" - previous_tag = f"v{PREVIOUS_TAG}" - repo = os.getenv('GITHUB_REPOSITORY') - headers = {"Authorization": f"token {GITHUB_TOKEN}", "Accept": "application/vnd.github.v3.diff"} - - # Get the diff between the tags - url = f"https://api.github.com/repos/{repo}/compare/{previous_tag}...{latest_tag}" - response = requests.get(url, headers=headers) - diff = response.text if response.status_code == 200 else f"Failed to get diff: {response.content}" - - # Get summary - messages = [ - { - "role": "system", - "content": "You are an Ultralytics AI assistant skilled in software development and technical communication. Your task is to summarize GitHub releases in a way that is detailed, accurate, and understandable to both expert developers and non-expert users. Focus on highlighting the key changes and their impact in simple and intuitive terms." - }, - { - "role": "user", - "content": f"Summarize the updates made in the '{latest_tag}' tag, focusing on major changes, their purpose, and potential impact. Keep the summary clear and suitable for a broad audience. Add emojis to enliven the summary. Reply directly with a summary along these example guidelines, though feel free to adjust as appropriate:\n\n" - f"## 🌟 Summary (single-line synopsis)\n" - f"## 📊 Key Changes (bullet points highlighting any major changes)\n" - f"## 🎯 Purpose & Impact (bullet points explaining any benefits and potential impact to users)\n" - f"\n\nHere's the release diff:\n\n{diff[:300000]}", - } - ] - client = openai.OpenAI(api_key=OPENAI_API_KEY) - completion = client.chat.completions.create(model="gpt-4o-2024-08-06", messages=messages) - summary = completion.choices[0].message.content.strip() - - # Get the latest commit message - commit_message = subprocess.run(['git', 'log', '-1', '--pretty=%B'], check=True, text=True, capture_output=True).stdout.split("\n")[0].strip() - - # Prepare release data - release = { - 'tag_name': latest_tag, - 'name': f"{latest_tag} - {commit_message}", - 'body': summary, - 'draft': False, - 'prerelease': False - } - - # Create the release on GitHub - release_url = f"https://api.github.com/repos/{repo}/releases" - release_response = requests.post(release_url, headers=headers, data=json.dumps(release)) - if release_response.status_code == 201: - print(f'Successfully created release {latest_tag}') - else: - print(f'Failed to create release {latest_tag}: {release_response.content}') + curl -s "https://raw.githubusercontent.com/ultralytics/actions/main/utils/summarize_release.py" | python - + shell: bash - name: Publish to PyPI continue-on-error: true if: (github.event_name == 'push' || github.event.inputs.pypi == 'true') && steps.check_pypi.outputs.increment == 'True'