Update release_mixin methods
This commit is contained in:
parent
a07c23434e
commit
7d7347653e
1 changed files with 40 additions and 33 deletions
|
@ -6,12 +6,19 @@ from version_repository import VersionRepository
|
||||||
from services import InitReleaseService, PrepareReleaseService, TagAndPushReleaseService
|
from services import InitReleaseService, PrepareReleaseService, TagAndPushReleaseService
|
||||||
from git_repository import GitRepository
|
from git_repository import GitRepository
|
||||||
|
|
||||||
def create_release_mixin_config(config, release_type, config_file, main_branch):
|
def create_release_mixin_config(config_file, main_branch) -> dict:
|
||||||
config.update({'ReleaseMixin':
|
config = {}
|
||||||
{'main_branch': main_branch,
|
config.update(
|
||||||
'file': config_file}})
|
{'ReleaseMixin':
|
||||||
|
{'main_branch': main_branch,
|
||||||
|
'file': config_file}})
|
||||||
return config
|
return config
|
||||||
|
|
||||||
|
def add_versions(config, release_version, bump_version) -> dict:
|
||||||
|
config['ReleaseMixin'].update(
|
||||||
|
{'release_version': release_version,
|
||||||
|
'bump_version': bump_version})
|
||||||
|
return config
|
||||||
|
|
||||||
class ReleaseMixin(DevopsBuild):
|
class ReleaseMixin(DevopsBuild):
|
||||||
|
|
||||||
|
@ -21,40 +28,40 @@ class ReleaseMixin(DevopsBuild):
|
||||||
self.file = release_mixin_config['file']
|
self.file = release_mixin_config['file']
|
||||||
self.main_branch = release_mixin_config['main_branch']
|
self.main_branch = release_mixin_config['main_branch']
|
||||||
self.version_repo = VersionRepository(self.file)
|
self.version_repo = VersionRepository(self.file)
|
||||||
|
self.release_version = None
|
||||||
|
self.bump_version = None
|
||||||
|
|
||||||
def init(self): # returns versions
|
def init(self):
|
||||||
init_service = InitReleaseService(self.version_repo)
|
init_service = InitReleaseService(self.version_repo)
|
||||||
release_version = init_service.create_release_version()
|
self.release_version = init_service.create_release_version()
|
||||||
bump_version = release_version.create_bump_version()
|
self.bump_version = self.release_version.create_bump_version()
|
||||||
return release_version, bump_version
|
return self.release_version, self.bump_version
|
||||||
|
|
||||||
def prepare(self, release_version: Version, bump_version: Version): # writes into files, add. commit
|
def prepare(self, version):
|
||||||
git_repository = GitRepository()
|
git_repository = GitRepository()
|
||||||
if self.main_branch not in git_repository.get_current_branch():
|
if self.main_branch not in git_repository.get_current_branch():
|
||||||
raise Exception('Trying to release while not on main branch')
|
raise Exception('Trying to release while not on main branch')
|
||||||
|
|
||||||
self.version_repo.write_file(release_version.get_version_string())
|
|
||||||
git_repository.add_file(self.file)
|
|
||||||
git_repository.commit(f'Release {release_version.get_version_string()}')
|
|
||||||
|
|
||||||
self.version_repo.write_file(bump_version.get_version_string())
|
|
||||||
git_repository.add_file(self.file)
|
|
||||||
git_repository.commit(f'Version bump {bump_version.get_version_string()}')
|
|
||||||
|
|
||||||
|
self.version_repo.write_file(version.get_version_string())
|
||||||
|
git_repository.add_file(self.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()}')
|
||||||
|
|
||||||
def tag_and_push(): # correct tag and do push
|
def tag_and_push(self, version):
|
||||||
pass
|
git_repository = GitRepository()
|
||||||
|
match version.release_type:
|
||||||
|
case None:
|
||||||
|
raise Exception('Release type not set but trying to tag and push.')
|
||||||
|
case ReleaseType.BUMP:
|
||||||
|
annotation = 'v' + version.get_version_string()
|
||||||
|
message = 'Version bump'
|
||||||
|
case _:
|
||||||
|
annotation = 'v' + self.release_version.get_version_string()
|
||||||
|
message = 'Release' + annotation
|
||||||
|
git_repository.tag_annotated(annotation, message)
|
||||||
|
git_repository.push()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue