Start recording the commit sha and other metadata about github triggered builds. We'll eventually show this information in the UI
This commit is contained in:
parent
4cf18c4591
commit
7c81d90cda
5 changed files with 22 additions and 9 deletions
|
@ -415,13 +415,13 @@ class ActivateBuildTrigger(RepositoryParamResource):
|
||||||
try:
|
try:
|
||||||
run_parameters = request.get_json()
|
run_parameters = request.get_json()
|
||||||
specs = handler.manual_start(trigger.auth_token, config_dict, run_parameters=run_parameters)
|
specs = handler.manual_start(trigger.auth_token, config_dict, run_parameters=run_parameters)
|
||||||
dockerfile_id, tags, name, subdir = specs
|
dockerfile_id, tags, name, subdir, metadata = specs
|
||||||
|
|
||||||
repo = model.get_repository(namespace, repository)
|
repo = model.get_repository(namespace, repository)
|
||||||
pull_robot_name = model.get_pull_robot_name(trigger)
|
pull_robot_name = model.get_pull_robot_name(trigger)
|
||||||
|
|
||||||
build_request = start_build(repo, dockerfile_id, tags, name, subdir, True,
|
build_request = start_build(repo, dockerfile_id, tags, name, subdir, True,
|
||||||
pull_robot_name=pull_robot_name)
|
pull_robot_name=pull_robot_name, trigger_metadata=metadata)
|
||||||
except TriggerStartException as tse:
|
except TriggerStartException as tse:
|
||||||
raise InvalidRequest(tse.message)
|
raise InvalidRequest(tse.message)
|
||||||
|
|
||||||
|
|
|
@ -211,7 +211,7 @@ def check_repository_usage(user_or_org, plan_found):
|
||||||
|
|
||||||
|
|
||||||
def start_build(repository, dockerfile_id, tags, build_name, subdir, manual,
|
def start_build(repository, dockerfile_id, tags, build_name, subdir, manual,
|
||||||
trigger=None, pull_robot_name=None):
|
trigger=None, pull_robot_name=None, trigger_metadata=None):
|
||||||
host = urlparse.urlparse(request.url).netloc
|
host = urlparse.urlparse(request.url).netloc
|
||||||
repo_path = '%s/%s/%s' % (host, repository.namespace_user.username, repository.name)
|
repo_path = '%s/%s/%s' % (host, repository.namespace_user.username, repository.name)
|
||||||
|
|
||||||
|
@ -223,7 +223,8 @@ def start_build(repository, dockerfile_id, tags, build_name, subdir, manual,
|
||||||
job_config = {
|
job_config = {
|
||||||
'docker_tags': tags,
|
'docker_tags': tags,
|
||||||
'registry': host,
|
'registry': host,
|
||||||
'build_subdir': subdir
|
'build_subdir': subdir,
|
||||||
|
'trigger_metadata': trigger_metadata or {}
|
||||||
}
|
}
|
||||||
|
|
||||||
with app.config['DB_TRANSACTION_FACTORY'](db):
|
with app.config['DB_TRANSACTION_FACTORY'](db):
|
||||||
|
|
|
@ -345,8 +345,10 @@ class GithubBuildTrigger(BuildTrigger):
|
||||||
# compute the tag(s)
|
# compute the tag(s)
|
||||||
branch = ref.split('/')[-1]
|
branch = ref.split('/')[-1]
|
||||||
tags = {branch}
|
tags = {branch}
|
||||||
|
|
||||||
if branch == repo.default_branch:
|
if branch == repo.default_branch:
|
||||||
tags.add('latest')
|
tags.add('latest')
|
||||||
|
|
||||||
logger.debug('Pushing to tags: %s' % tags)
|
logger.debug('Pushing to tags: %s' % tags)
|
||||||
|
|
||||||
# compute the subdir
|
# compute the subdir
|
||||||
|
@ -354,7 +356,14 @@ class GithubBuildTrigger(BuildTrigger):
|
||||||
joined_subdir = os.path.join(tarball_subdir, repo_subdir)
|
joined_subdir = os.path.join(tarball_subdir, repo_subdir)
|
||||||
logger.debug('Final subdir: %s' % joined_subdir)
|
logger.debug('Final subdir: %s' % joined_subdir)
|
||||||
|
|
||||||
return dockerfile_id, list(tags), build_name, joined_subdir
|
# compute the metadata
|
||||||
|
metadata = {
|
||||||
|
'commit_sha': commit_sha,
|
||||||
|
'ref': ref,
|
||||||
|
'default_branch': repo.default_branch
|
||||||
|
}
|
||||||
|
|
||||||
|
return dockerfile_id, list(tags), build_name, joined_subdir, metadata
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_display_name(sha):
|
def get_display_name(sha):
|
||||||
|
|
|
@ -91,7 +91,7 @@ def build_trigger_webhook(trigger_uuid, **kwargs):
|
||||||
try:
|
try:
|
||||||
specs = handler.handle_trigger_request(request, trigger.auth_token,
|
specs = handler.handle_trigger_request(request, trigger.auth_token,
|
||||||
config_dict)
|
config_dict)
|
||||||
dockerfile_id, tags, name, subdir = specs
|
dockerfile_id, tags, name, subdir, metadata = specs
|
||||||
|
|
||||||
except ValidationRequestException:
|
except ValidationRequestException:
|
||||||
# This was just a validation request, we don't need to build anything
|
# This was just a validation request, we don't need to build anything
|
||||||
|
@ -104,7 +104,7 @@ def build_trigger_webhook(trigger_uuid, **kwargs):
|
||||||
pull_robot_name = model.get_pull_robot_name(trigger)
|
pull_robot_name = model.get_pull_robot_name(trigger)
|
||||||
repo = model.get_repository(namespace, repository)
|
repo = model.get_repository(namespace, repository)
|
||||||
start_build(repo, dockerfile_id, tags, name, subdir, False, trigger,
|
start_build(repo, dockerfile_id, tags, name, subdir, False, trigger,
|
||||||
pull_robot_name=pull_robot_name)
|
pull_robot_name=pull_robot_name, trigger_metadata=metadata)
|
||||||
|
|
||||||
return make_response('Okay')
|
return make_response('Okay')
|
||||||
|
|
||||||
|
|
|
@ -2276,7 +2276,7 @@ class FakeBuildTrigger(BuildTriggerBase):
|
||||||
return [auth_token, 'foo', 'bar', config['somevalue']]
|
return [auth_token, 'foo', 'bar', config['somevalue']]
|
||||||
|
|
||||||
def handle_trigger_request(self, request, auth_token, config):
|
def handle_trigger_request(self, request, auth_token, config):
|
||||||
return ('foo', ['bar'], 'build-name', 'subdir')
|
return ('foo', ['bar'], 'build-name', 'subdir', {'foo': 'bar'})
|
||||||
|
|
||||||
def is_active(self, config):
|
def is_active(self, config):
|
||||||
return 'active' in config and config['active']
|
return 'active' in config and config['active']
|
||||||
|
@ -2290,7 +2290,7 @@ class FakeBuildTrigger(BuildTriggerBase):
|
||||||
return config
|
return config
|
||||||
|
|
||||||
def manual_start(self, auth_token, config, run_parameters=None):
|
def manual_start(self, auth_token, config, run_parameters=None):
|
||||||
return ('foo', ['bar'], 'build-name', 'subdir')
|
return ('foo', ['bar'], 'build-name', 'subdir', {'foo': 'bar'})
|
||||||
|
|
||||||
def dockerfile_url(self, auth_token, config):
|
def dockerfile_url(self, auth_token, config):
|
||||||
return 'http://some/url'
|
return 'http://some/url'
|
||||||
|
@ -2501,6 +2501,9 @@ class TestBuildTriggers(ApiTestCase):
|
||||||
self.assertEquals("build-name", start_json['display_name'])
|
self.assertEquals("build-name", start_json['display_name'])
|
||||||
self.assertEquals(['bar'], start_json['job_config']['docker_tags'])
|
self.assertEquals(['bar'], start_json['job_config']['docker_tags'])
|
||||||
|
|
||||||
|
# Verify the metadata was added.
|
||||||
|
build_obj = database.RepositoryBuild.get(database.RepositoryBuild.uuid == start_json['id'])
|
||||||
|
self.assertEquals('bar', py_json.loads(build_obj.job_config)['trigger_metadata']['foo'])
|
||||||
|
|
||||||
def test_invalid_robot_account(self):
|
def test_invalid_robot_account(self):
|
||||||
self.login(ADMIN_ACCESS_USER)
|
self.login(ADMIN_ACCESS_USER)
|
||||||
|
|
Reference in a new issue