Add option to not fail on first build error
This commit is contained in:
parent
690e24ba44
commit
a85b480941
@ -1,2 +1,2 @@
|
|||||||
from .cloud_build import CB # noqa: F401
|
from .cloud_build import CB # noqa: F401
|
||||||
from .cloud_build import Error # noqa: F401
|
from .cloud_build import Error, BuildError, MultipleBuildErrors # noqa: F401
|
||||||
|
@ -25,6 +25,25 @@ class Error(Exception):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class BuildError(Error):
|
||||||
|
def __init__(self, target: str, arch: str):
|
||||||
|
self.target = target
|
||||||
|
self.arch = arch
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return f'Fail building of {self.target} {self.arch}'
|
||||||
|
|
||||||
|
|
||||||
|
class MultipleBuildErrors(Error):
|
||||||
|
def __init__(self, build_errors: List[BuildError]):
|
||||||
|
self.build_errors = build_errors
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
s = 'Fail building of the next targets:\n'
|
||||||
|
s += '\n'.join(f' {be.target} {be.arch}' for be in self.build_errors)
|
||||||
|
return s
|
||||||
|
|
||||||
|
|
||||||
class CB:
|
class CB:
|
||||||
"""class for building cloud images"""
|
"""class for building cloud images"""
|
||||||
|
|
||||||
@ -59,6 +78,7 @@ class CB:
|
|||||||
self.date = datetime.date.today().strftime('%Y%m%d')
|
self.date = datetime.date.today().strftime('%Y%m%d')
|
||||||
self.service_default_state = 'enabled'
|
self.service_default_state = 'enabled'
|
||||||
self.created_scripts: List[Path] = []
|
self.created_scripts: List[Path] = []
|
||||||
|
self._build_errors: List[BuildError] = []
|
||||||
|
|
||||||
self.ensure_dirs()
|
self.ensure_dirs()
|
||||||
logging.basicConfig(
|
logging.basicConfig(
|
||||||
@ -137,6 +157,8 @@ class CB:
|
|||||||
self._repository_url = cfg.get('repository_url',
|
self._repository_url = cfg.get('repository_url',
|
||||||
'file:///space/ALT/{branch}')
|
'file:///space/ALT/{branch}')
|
||||||
|
|
||||||
|
self.try_build_all = cfg.get('try_build_all', False)
|
||||||
|
|
||||||
self.bad_arches = cfg.get('bad_arches', [])
|
self.bad_arches = cfg.get('bad_arches', [])
|
||||||
|
|
||||||
self.external_files = cfg.get('external_files')
|
self.external_files = cfg.get('external_files')
|
||||||
@ -167,9 +189,13 @@ class CB:
|
|||||||
def debug(self, msg: str) -> None:
|
def debug(self, msg: str) -> None:
|
||||||
self.log.debug(msg)
|
self.log.debug(msg)
|
||||||
|
|
||||||
def error(self, msg: str) -> None:
|
def error(self, arg: Union[str, Error]) -> None:
|
||||||
self.log.error(msg)
|
if isinstance(arg, Error):
|
||||||
raise Error(msg)
|
err = arg
|
||||||
|
else:
|
||||||
|
err = Error(arg)
|
||||||
|
self.log.error(err)
|
||||||
|
raise err
|
||||||
|
|
||||||
def remote(self, branch: str) -> str:
|
def remote(self, branch: str) -> str:
|
||||||
return self._remote.format(branch=branch)
|
return self._remote.format(branch=branch)
|
||||||
@ -432,6 +458,12 @@ Dir::Etc::preferencesparts "/var/empty";
|
|||||||
self.service_default_state,
|
self.service_default_state,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def build_failed(self, target, arch):
|
||||||
|
if self.try_build_all:
|
||||||
|
self._build_errors.append(BuildError(target, arch))
|
||||||
|
else:
|
||||||
|
self.error(BuildError(target, arch))
|
||||||
|
|
||||||
def build_tarball(
|
def build_tarball(
|
||||||
self,
|
self,
|
||||||
target: str,
|
target: str,
|
||||||
@ -462,7 +494,8 @@ Dir::Etc::preferencesparts "/var/empty";
|
|||||||
if os.path.exists(tarball):
|
if os.path.exists(tarball):
|
||||||
self.info(f'End building of {full_target} {arch}')
|
self.info(f'End building of {full_target} {arch}')
|
||||||
else:
|
else:
|
||||||
self.error(f'Fail building of {full_target} {arch}')
|
self.build_failed(full_target, arch)
|
||||||
|
tarball = None
|
||||||
|
|
||||||
return tarball
|
return tarball
|
||||||
|
|
||||||
@ -518,6 +551,10 @@ Dir::Etc::preferencesparts "/var/empty";
|
|||||||
script.write_text(content)
|
script.write_text(content)
|
||||||
os.chmod(script, 0o755)
|
os.chmod(script, 0o755)
|
||||||
|
|
||||||
|
def ensure_build_success(self) -> None:
|
||||||
|
if self._build_errors:
|
||||||
|
self.error(MultipleBuildErrors(self._build_errors))
|
||||||
|
|
||||||
def create_images(self) -> None:
|
def create_images(self) -> None:
|
||||||
self.clear_images_dir()
|
self.clear_images_dir()
|
||||||
for branch in self.branches:
|
for branch in self.branches:
|
||||||
@ -534,6 +571,8 @@ Dir::Etc::preferencesparts "/var/empty";
|
|||||||
tarball = self.build_tarball(
|
tarball = self.build_tarball(
|
||||||
target, branch, arch, kind,
|
target, branch, arch, kind,
|
||||||
)
|
)
|
||||||
|
if tarball is None:
|
||||||
|
continue
|
||||||
image_path = self.image_path(image, branch, arch, kind)
|
image_path = self.image_path(image, branch, arch, kind)
|
||||||
self.copy_image(tarball, image_path)
|
self.copy_image(tarball, image_path)
|
||||||
if not self.no_tests:
|
if not self.no_tests:
|
||||||
@ -547,6 +586,7 @@ Dir::Etc::preferencesparts "/var/empty";
|
|||||||
):
|
):
|
||||||
self.error(f'Test for {image} failed')
|
self.error(f'Test for {image} failed')
|
||||||
|
|
||||||
|
self.ensure_build_success()
|
||||||
self.remove_old_tarballs()
|
self.remove_old_tarballs()
|
||||||
|
|
||||||
def copy_external_files(self):
|
def copy_external_files(self):
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
---
|
---
|
||||||
remote: remote:/pub/images/{branch}/cloud
|
remote: remote:/pub/images/{branch}/cloud
|
||||||
key: 0x00000000
|
key: 0x00000000
|
||||||
|
try_build_all: False
|
||||||
repository_url: file:///space/ALT/{branch}
|
repository_url: file:///space/ALT/{branch}
|
||||||
log_level: info
|
log_level: info
|
||||||
bad_arches:
|
bad_arches:
|
||||||
|
Loading…
Reference in New Issue
Block a user