Move commit logic to prepare_release_service
This commit is contained in:
parent
c58ddf70da
commit
fa6beebc4e
3 changed files with 28 additions and 32 deletions
|
@ -30,29 +30,24 @@ class ReleaseMixin(DevopsBuild):
|
|||
self.config_file = release_mixin_config['config_file']
|
||||
self.main_branch = release_mixin_config['main_branch']
|
||||
self.version_repo = VersionRepository(self.config_file)
|
||||
self.git_repo = GitRepository()
|
||||
self.release_version = None
|
||||
self.bump_version = None
|
||||
self.commit_string = None
|
||||
|
||||
def init(self):
|
||||
def init_release(self):
|
||||
init_service = InitReleaseService(self.version_repo)
|
||||
self.release_version = init_service.create_release_version(self.commit_string)
|
||||
self.bump_version = self.release_version.create_bump_version()
|
||||
|
||||
def prepare(self, version):
|
||||
git_repository = GitRepository()
|
||||
if self.main_branch not in git_repository.get_current_branch():
|
||||
raise Exception('Trying to release while not on main branch')
|
||||
def prepare_release(self):
|
||||
prepare_release_service = PrepareReleaseService(self.version_repo, self.config_file, self.main_branch)
|
||||
if self.release_version is None or self.bump_version is None:
|
||||
raise Exception('prepare_release was called before init_release')
|
||||
|
||||
self.version_repo.write_file(version.get_version_string())
|
||||
git_repository.add_file(self.config_file)
|
||||
match version.release_type:
|
||||
case None:
|
||||
raise Exception('Release type not set but trying to commit.')
|
||||
case ReleaseType.BUMP:
|
||||
git_repository.commit(f'Version bump')
|
||||
case _:
|
||||
git_repository.commit(f'Release {version.get_version_string()}')
|
||||
# prepare_release_service.run_tests() # not implemented
|
||||
prepare_release_service.write_and_commit_release(self.release_version)
|
||||
prepare_release_service.write_and_commit_bump(self.bump_version)
|
||||
|
||||
def tag_and_push(self, version):
|
||||
git_repository = GitRepository()
|
||||
|
|
33
services.py
33
services.py
|
@ -1,3 +1,4 @@
|
|||
from pathlib import Path
|
||||
from version_repository import VersionRepository
|
||||
from release_type import ReleaseType
|
||||
from git_repository import GitRepository
|
||||
|
@ -31,28 +32,28 @@ class InitReleaseService():
|
|||
|
||||
class PrepareReleaseService():
|
||||
|
||||
def __init__(self, version_repo: VersionRepository):
|
||||
self.version_repo = version_repo
|
||||
|
||||
def __init__(self, version_repository: VersionRepository, git_repository: GitRepository, config_file: Path, main_branch: str):
|
||||
self.version_repository = version_repository
|
||||
self.git_repository = git_repository
|
||||
self.main_branch = main_branch
|
||||
self.config_file = config_file
|
||||
|
||||
def run_tests(self): # maybe auto?
|
||||
pass
|
||||
raise NotImplementedError
|
||||
|
||||
def prepare_release(self, version: Version):
|
||||
# self.version_repo.write_file(version.get_version_string()) # side effect
|
||||
pass
|
||||
def __write_and_commit_version(self, version: Version, commit_message: str):
|
||||
if self.main_branch != self.git_repository.get_current_branch():
|
||||
raise Exception('Trying to release while not on main branch')
|
||||
|
||||
def prepare_bump(self, version: Version):
|
||||
# self.version_repo.write_file(version.get_version_string()) # side effect
|
||||
pass
|
||||
self.version_repository.write_file(version.get_version_string())
|
||||
self.git_repository.add_file(self.config_file)
|
||||
self.git_repository.commit(commit_message)
|
||||
|
||||
def write_and_commit_release(self, release_version: Version):
|
||||
self.__write_and_commit_version(release_version, commit_message=f'Release {release_version.get_version_string()}')
|
||||
|
||||
# write
|
||||
|
||||
|
||||
# add
|
||||
# commit
|
||||
pass
|
||||
def write_and_commit_bump(self, bump_version: Version):
|
||||
self.__write_and_commit_version(bump_version, commit_message=f'Version bump')
|
||||
|
||||
class TagAndPushReleaseService():
|
||||
pass
|
||||
|
|
|
@ -56,7 +56,7 @@ def test_release_mixin(tmp_path):
|
|||
# init
|
||||
build = initialize(project, CONFIG_FILE)
|
||||
build.commit_string = "MAJOR bla"
|
||||
build.init()
|
||||
build.init_release()
|
||||
release_version = build.release_version
|
||||
|
||||
# test
|
||||
|
|
Loading…
Reference in a new issue