Merge branch 'master' of github.com:coreos-inc/quay

This commit is contained in:
Jake Moshenko 2015-01-29 18:40:24 -05:00
commit fb533a1f4c
4 changed files with 22 additions and 13 deletions

View file

@ -116,9 +116,9 @@ class BuildComponent(BaseComponent):
status_dict['total_commands'] = len(parsed_dockerfile.commands) status_dict['total_commands'] = len(parsed_dockerfile.commands)
# Add the pull robot information, if any. # Add the pull robot information, if any.
if build_config.get('pull_credentials') is not None: if build_job.pull_credentials:
base_image_information['username'] = build_config['pull_credentials'].get('username', '') base_image_information['username'] = build_job.pull_credentials.get('username', '')
base_image_information['password'] = build_config['pull_credentials'].get('password', '') base_image_information['password'] = build_job.pull_credentials.get('password', '')
# Retrieve the repository's fully qualified name. # Retrieve the repository's fully qualified name.
repo = build_job.repo_build.repository repo = build_job.repo_build.repository
@ -244,7 +244,7 @@ class BuildComponent(BaseComponent):
def _build_failure(self, error_message, exception=None): def _build_failure(self, error_message, exception=None):
""" Handles and logs a failed build. """ """ Handles and logs a failed build. """
self._build_status.set_error(error_message, { self._build_status.set_error(error_message, {
'internal_error': exception.message if exception else None 'internal_error': str(exception) if exception else None
}) })
build_id = self._current_job.repo_build.uuid build_id = self._current_job.repo_build.uuid
@ -294,7 +294,7 @@ class BuildComponent(BaseComponent):
version) version)
raise trollius.Return(False) raise trollius.Return(False)
if self._component_status != 'waiting': if self._component_status != 'waiting5':
logger.warning('Build component (token "%s") is already connected', self.expected_token) logger.warning('Build component (token "%s") is already connected', self.expected_token)
raise trollius.Return(False) raise trollius.Return(False)
@ -334,7 +334,7 @@ class BuildComponent(BaseComponent):
# If the component is no longer running or actively building, nothing more to do. # If the component is no longer running or actively building, nothing more to do.
if (self._component_status != ComponentStatus.RUNNING and if (self._component_status != ComponentStatus.RUNNING and
self._component_status != ComponentStatus.BUILDING): self._component_status != ComponentStatus.BUILDING):
return raise trollius.Return()
# If there is an active build, write the heartbeat to its status. # If there is an active build, write the heartbeat to its status.
build_status = self._build_status build_status = self._build_status
@ -352,26 +352,26 @@ class BuildComponent(BaseComponent):
if (self._last_heartbeat and if (self._last_heartbeat and
self._last_heartbeat < datetime.datetime.utcnow() - HEARTBEAT_DELTA): self._last_heartbeat < datetime.datetime.utcnow() - HEARTBEAT_DELTA):
yield trollius.From(self._timeout()) yield trollius.From(self._timeout())
return raise trollius.Return()
yield trollius.From(trollius.sleep(HEARTBEAT_TIMEOUT)) yield trollius.From(trollius.sleep(HEARTBEAT_TIMEOUT))
@trollius.coroutine @trollius.coroutine
def _timeout(self): def _timeout(self):
if self._component_status == ComponentStatus.TIMED_OUT:
raise trollius.Return()
yield trollius.From(self._set_status(ComponentStatus.TIMED_OUT)) yield trollius.From(self._set_status(ComponentStatus.TIMED_OUT))
logger.warning('Build component with realm %s has timed out', self.builder_realm) logger.warning('Build component with realm %s has timed out', self.builder_realm)
self._dispose(timed_out=True)
def _dispose(self, timed_out=False):
# If we still have a running job, then it has not completed and we need to tell the parent # If we still have a running job, then it has not completed and we need to tell the parent
# manager. # manager.
if self._current_job is not None: if self._current_job is not None:
if timed_out: self._build_status.set_error('Build worker timed out', internal_error=True)
self._build_status.set_error('Build worker timed out', internal_error=True)
self.parent_manager.job_completed(self._current_job, BuildJobResult.INCOMPLETE, self) self.parent_manager.job_completed(self._current_job, BuildJobResult.INCOMPLETE, self)
self._build_status = None self._build_status = None
self._current_job = None self._current_job = None
# Unregister the current component so that it cannot be invoked again. # Unregister the current component so that it cannot be invoked again.
self.parent_manager.build_component_disposed(self, timed_out) self.parent_manager.build_component_disposed(self, True)

View file

@ -33,6 +33,11 @@ class BuildJob(object):
def repo_build(self): def repo_build(self):
return self._load_repo_build() return self._load_repo_build()
@property
def pull_credentials(self):
""" Returns the pull credentials for this job, or None if none. """
return self.job_details.get('pull_credentials')
@property @property
def build_config(self): def build_config(self):
try: try:

View file

@ -1,5 +1,6 @@
from data.database import BUILD_PHASE from data.database import BUILD_PHASE
from data import model from data import model
import datetime
class StatusHandler(object): class StatusHandler(object):
""" Context wrapper for writing status to build logs. """ """ Context wrapper for writing status to build logs. """
@ -20,6 +21,8 @@ class StatusHandler(object):
self.__exit__(None, None, None) self.__exit__(None, None, None)
def _append_log_message(self, log_message, log_type=None, log_data=None): def _append_log_message(self, log_message, log_type=None, log_data=None):
log_data = log_data or {}
log_data['datetime'] = str(datetime.datetime.now())
self._build_logs.append_log_message(self._uuid, log_message, log_type, log_data) self._build_logs.append_log_message(self._uuid, log_message, log_type, log_data)
def append_log(self, log_message, extra_data=None): def append_log(self, log_message, extra_data=None):

View file

@ -121,7 +121,7 @@ class BuilderServer(object):
def _job_heartbeat(self, build_job): def _job_heartbeat(self, build_job):
WorkQueue.extend_processing(build_job.job_item, seconds_from_now=JOB_TIMEOUT_SECONDS, WorkQueue.extend_processing(build_job.job_item, seconds_from_now=JOB_TIMEOUT_SECONDS,
retry_count=1, minimum_extension=MINIMUM_JOB_EXTENSION) minimum_extension=MINIMUM_JOB_EXTENSION)
def _job_complete(self, build_job, job_status): def _job_complete(self, build_job, job_status):
if job_status == BuildJobResult.INCOMPLETE: if job_status == BuildJobResult.INCOMPLETE:
@ -155,6 +155,7 @@ class BuilderServer(object):
except BuildJobLoadException as irbe: except BuildJobLoadException as irbe:
logger.exception(irbe) logger.exception(irbe)
self._queue.incomplete(job_item, restore_retry=False) self._queue.incomplete(job_item, restore_retry=False)
continue
logger.debug('Build job found. Checking for an avaliable worker.') logger.debug('Build job found. Checking for an avaliable worker.')
scheduled = yield From(self._lifecycle_manager.schedule(build_job)) scheduled = yield From(self._lifecycle_manager.schedule(build_job))