Automate releases (#3732)

* Test custom action with custom input

* Run test workflow on push

* Automated release configuration
This commit is contained in:
Bert Blommers 2021-03-03 09:06:22 +00:00 committed by GitHub
parent 1579e44a27
commit 562d0eef69
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 87 additions and 12 deletions

View File

@ -1,21 +1,69 @@
name: Release
on: on:
workflow_dispatch: workflow_dispatch:
inputs: inputs:
version: version:
description: 'Version' description: 'Version'
required: true required: true
default: ''
jobs: jobs:
hello_world_job: release-moto-job:
runs-on: ubuntu-latest runs-on: ubuntu-latest
name: A job to say hello name: Release Moto
env:
VERSION: 0.0.0
steps: steps:
- name: Hello world action step - name: Set Env
id: hello run: |
uses: bblommers/moto-release-action@v1 echo "VERSION=${{ github.event.inputs.version }}" >> $GITHUB_ENV
- uses: actions/checkout@v2
with: with:
who-to-greet: 'Mona the Octocat wants to release ${{ github.event.inputs.version }}' fetch-depth: 0
# Use the output from the `hello` step - name: Set up Python 3.8
- name: Get the output time uses: actions/setup-python@v2
run: echo "The time was ${{ steps.hello.outputs.time }}" with:
python-version: 3.8
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install wheel setuptools packaging twine --upgrade
- name: Verify Tag does not exist
run: |
! git rev-parse ${{ env.VERSION }} || { echo "Ensure that no tag exists for ${{ env.VERSION }}" ; exit 1; }
- name: Verify supplied version exists in the CHANGELOG
run: |
grep ${{ env.VERSION }} CHANGELOG.md || { echo "Ensure that the CHANGELOG contains an entry for ${{ env.VERSION }}" ; exit 1; }
- name: Set version number
run: python update_version_from_git.py ${{ env.VERSION }}
- name: Build
run: python setup.py sdist bdist_wheel
- name: Publish to PyPI
uses: pypa/gh-action-pypi-publish@master
with:
password: ${{ secrets.PYPI_API_TOKEN }}
- name: Tag version on Github
run: |
git tag ${{ env.VERSION }}
git push origin ${{ env.VERSION }}
- name: Build Docker release
run: |
docker build -t motoserver/moto . --tag moto:${{ env.VERSION }}
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v2
with:
push: true
tags: motoserver/moto:${{ env.VERSION }}
- name: Increase patch version number
run: |
python update_version_from_git.py patch
git config --local user.email "admin@getmoto.org"
git config --local user.name "Moto Admin"
git add moto/__init__.py
git commit -m "Increase version number post-release"
git push

View File

@ -10,4 +10,5 @@ prompt-toolkit==2.0.10 # 3.x is not available with python2
click==6.7 click==6.7
inflection==0.3.1 inflection==0.3.1
lxml==4.2.3 lxml==4.2.3
packaging

View File

@ -4,6 +4,9 @@ Adapted from https://github.com/pygame/pygameweb/blob/master/pygameweb/builds/up
For updating the version from git. For updating the version from git.
__init__.py contains a __version__ field. __init__.py contains a __version__ field.
Update that. Update that.
If the user supplies "patch" as a CLi argument, we want to bump the existing patch version
If the user supplied the full version as a CLI argument, we want to use that version.
Otherwise,
If we are on master, we want to update the version as a pre-release. If we are on master, we want to update the version as a pre-release.
git describe --tags git describe --tags
With these: With these:
@ -22,6 +25,8 @@ import io
import os import os
import re import re
import subprocess import subprocess
import sys
from packaging.version import Version
def migrate_source_attribute(attr, to_this, target_file, regex): def migrate_source_attribute(attr, to_this, target_file, regex):
@ -49,7 +54,7 @@ def migrate_version(target_file, new_version):
regex = r"['\"](.*)['\"]" regex = r"['\"](.*)['\"]"
migrate_source_attribute( migrate_source_attribute(
"__version__", "__version__",
"'{new_version}'".format(new_version=new_version), "\"{new_version}\"".format(new_version=new_version),
target_file, target_file,
regex, regex,
) )
@ -114,6 +119,15 @@ def get_version():
raise RuntimeError("Unable to find version string.") raise RuntimeError("Unable to find version string.")
def increase_patch_version(old_version):
"""
:param old_version: 2.0.1
:return: 2.0.2.dev
"""
v = Version(old_version)
return "{}.{}.{}.dev".format(v.major, v.minor, v.micro + 1)
def release_version_correct(): def release_version_correct():
"""Makes sure the: """Makes sure the:
- prerelease verion for master is correct. - prerelease verion for master is correct.
@ -142,4 +156,16 @@ def release_version_correct():
if __name__ == "__main__": if __name__ == "__main__":
release_version_correct() new_version = None
if len(sys.argv) == 1:
release_version_correct()
elif len(sys.argv) == 2:
for _, arg in enumerate(sys.argv):
new_version = arg
if new_version == "patch":
new_version = increase_patch_version(get_version())
initpy = os.path.abspath("moto/__init__.py")
migrate_version(initpy, new_version)
else:
print("Invalid usage. Supply 0 or 1 arguments. "
"Argument can be either a version '1.2.3' or 'patch' if you want to increase the patch-version (1.2.3 -> 1.2.4.dev)")