def create_github_release(): configure_git() version = get_project_version() if not version: print("Unable to determine the current version") sys.exit(1) tag_exists = (check_exit_code([ f'git show-ref --tags --quiet --verify -- "refs/tags/{version}"' ]) == 0) if not tag_exists: run_process(["git", "tag", version]) run_process(["git", "push", "--tags"]) _, changelog = get_release_info() gh_release_create( REPO_SLUG, version, publish=True, name=f"{PROJECT_NAME} {version}", body=changelog, asset_pattern="dist/*", )
def create_github_release(): try: from github_release import gh_release_create except ModuleNotFoundError: print("Cannot create GitHub release due to missing dependency: github_release") sys.exit(1) configure_git() version = get_project_version() tag = f"{TAG_PREFIX}{version}" if not version: print("Unable to determine the current version") sys.exit(1) tag_exists = ( check_exit_code([f'git show-ref --tags --quiet --verify -- "refs/tags/{tag}"']) == 0 ) if not tag_exists: run_process(["git", "tag", tag]) run_process(["git", "push", "--tags"]) _, changelog = get_release_info() gh_release_create( REPO_SLUG, tag, publish=True, name=f"{PROJECT_NAME} {version}", body=changelog, asset_pattern="dist/*", )
def prepare_release(): configure_git() POETRY_DUMP_VERSION_OUTPUT = re.compile( r"Bumping version from \d+\.\d+\.\d+ to (?P<version>\d+\.\d+\.\d+)") type_, release_changelog = get_release_info() output = run_process(["poetry", "version", type_]) version_match = POETRY_DUMP_VERSION_OUTPUT.match(output) if not version_match: print("Unable to bump the project version using Poetry") sys.exit(1) new_version = version_match.group("version") if VERSION_STRINGS: for version_file in VERSION_STRINGS: file_path = ROOT / version_file update_version_strings(file_path, new_version) current_date = datetime.utcnow().strftime("%Y-%m-%d") old_changelog_data = "" header = "" if not CHANGELOG_FILE.is_file(): with open(CHANGELOG_FILE, "a+") as f: f.write(f"CHANGELOG\n{CHANGELOG_HEADER}\n\n") with open(CHANGELOG_FILE, "r") as f: lines = f.readlines() for index, line in enumerate(lines): if CHANGELOG_HEADER != line.strip(): continue old_changelog_data = lines[index + 1:] header = lines[:index + 1] break with open(CHANGELOG_FILE, "w") as f: f.write("".join(header)) new_version_header = f"{new_version} - {current_date}" f.write(f"\n{new_version_header}\n") f.write(f"{VERSION_HEADER * len(new_version_header)}\n\n") f.write(release_changelog) append_github_contributor(f) f.write("\n") f.write("".join(old_changelog_data))
def git_commit_and_push(): configure_git() version = get_project_version() git(["add", PYPROJECT_FILE_NAME]) git(["add", CHANGELOG_FILE_NAME]) if VERSION_STRINGS: for version_file in VERSION_STRINGS: git(["add", version_file]) git(["rm", "--cached", RELEASE_FILE_NAME]) git(["commit", "-m", f"Release {PROJECT_NAME} {version}"]) git(["push", "origin", "HEAD"])
import sys import os sys.path.append(os.path.dirname(__file__)) # noqa from base import ( get_project_version, git, configure_git, PROJECT_TOML_FILE_NAME, CHANGELOG_FILE_NAME, RELEASE_FILE_NAME, ) if __name__ == "__main__": configure_git() version = get_project_version() git(["add", PROJECT_TOML_FILE_NAME]) git(["add", CHANGELOG_FILE_NAME]) git(["rm", "--cached", RELEASE_FILE_NAME]) git(["commit", "-m", f"Release 🍓 {version}"]) git(["push", "origin", "HEAD"])