|
|
|
@ -1,6 +1,6 @@
|
|
|
|
|
from pathlib import Path
|
|
|
|
|
from infrastructure import VersionRepository, ReleaseRepository, GitApi
|
|
|
|
|
from domain import Version, ReleaseType
|
|
|
|
|
from domain import Version, ReleaseType, Release
|
|
|
|
|
|
|
|
|
|
class PrepareReleaseService():
|
|
|
|
|
|
|
|
|
@ -8,12 +8,10 @@ class PrepareReleaseService():
|
|
|
|
|
self.release_repo = release_repo
|
|
|
|
|
self.release = release_repo.get_release()
|
|
|
|
|
self.git_api = GitApi()
|
|
|
|
|
self.main_branch = None
|
|
|
|
|
|
|
|
|
|
def __write_and_commit_version(self, version: Version, commit_message: str):
|
|
|
|
|
if self.main_branch != self.git_api.get_current_branch():
|
|
|
|
|
raise Exception('Trying to release while not on main branch')
|
|
|
|
|
|
|
|
|
|
self.release.validate(self.release_repo.main_branch)
|
|
|
|
|
|
|
|
|
|
self.release_repo.version_repository.write_file(version.get_version_string())
|
|
|
|
|
self.git_api.add_file(self.release_repo.version_repository.file)
|
|
|
|
|
self.git_api.commit(commit_message)
|
|
|
|
@ -30,8 +28,8 @@ class TagAndPushReleaseService():
|
|
|
|
|
def __init__(self, git_api: GitApi):
|
|
|
|
|
self.git_api = git_api
|
|
|
|
|
|
|
|
|
|
def tag_and_push_release(self, release_version: Version):
|
|
|
|
|
annotation = 'v' + release_version.get_version_string()
|
|
|
|
|
def tag_and_push_release(self, release: Release):
|
|
|
|
|
annotation = 'v' + release.version.get_version_string()
|
|
|
|
|
message = 'Release ' + annotation
|
|
|
|
|
self.git_api.tag_annotated(annotation, message, 1)
|
|
|
|
|
# self.git_api.push()
|
|
|
|
|