Merge pull request #2126 from coreos-inc/github-empty

Fix github trigger when submitting a webhook without a head_commit
This commit is contained in:
josephschorr 2016-11-17 12:01:59 -05:00 committed by GitHub
commit c4b73318c0
3 changed files with 136 additions and 1 deletions

View file

@ -29,7 +29,7 @@ GITHUB_WEBHOOK_PAYLOAD_SCHEMA = {
'type': 'string', 'type': 'string',
}, },
'head_commit': { 'head_commit': {
'type': 'object', 'type': ['object', 'null'],
'properties': { 'properties': {
'id': { 'id': {
'type': 'string', 'type': 'string',
@ -98,6 +98,9 @@ def get_transformed_webhook_payload(gh_payload, default_branch=None, lookup_user
payload = JSONPathDict(gh_payload) payload = JSONPathDict(gh_payload)
if payload['head_commit'] is None:
raise SkipRequestException
config = SafeDictSetter() config = SafeDictSetter()
config['commit'] = payload['head_commit.id'] config['commit'] = payload['head_commit.id']
config['ref'] = payload['ref'] config['ref'] = payload['ref']

View file

@ -443,5 +443,11 @@ class TestPrepareTrigger(unittest.TestCase):
self.assertSchema('github_webhook_deletedcommit', expected, gh_webhook, lookup_user=lookup_user) self.assertSchema('github_webhook_deletedcommit', expected, gh_webhook, lookup_user=lookup_user)
def test_github_webhook_known_issue(self):
def lookup_user(_):
return None
self.assertSkipped('github_webhook_knownissue', gh_webhook, lookup_user=lookup_user)
if __name__ == '__main__': if __name__ == '__main__':
unittest.main() unittest.main()

View file

@ -0,0 +1,126 @@
{
"ref": "refs/heads/1.2.6",
"before": "76a309ed96c72986eddffc02d2f4dda3fe689f10",
"after": "0000000000000000000000000000000000000000",
"created": false,
"deleted": true,
"forced": false,
"base_ref": null,
"compare": "https://github.com/coreos/clair-jwt-docker/compare/76a309ed96c7...000000000000",
"commits": [
],
"head_commit": null,
"repository": {
"id": 56698571,
"name": "clair-jwt-docker",
"full_name": "coreos/clair-jwt-docker",
"owner": {
"name": "coreos",
"email": "partners@coreos.com"
},
"private": true,
"html_url": "https://github.com/coreos/clair-jwt-docker",
"description": "Dockerfile for Clair running behind jwtproxy",
"fork": false,
"url": "https://github.com/coreos/clair-jwt-docker",
"forks_url": "https://api.github.com/repos/coreos/clair-jwt-docker/forks",
"keys_url": "https://api.github.com/repos/coreos/clair-jwt-docker/keys{/key_id}",
"collaborators_url": "https://api.github.com/repos/coreos/clair-jwt-docker/collaborators{/collaborator}",
"teams_url": "https://api.github.com/repos/coreos/clair-jwt-docker/teams",
"hooks_url": "https://api.github.com/repos/coreos/clair-jwt-docker/hooks",
"issue_events_url": "https://api.github.com/repos/coreos/clair-jwt-docker/issues/events{/number}",
"events_url": "https://api.github.com/repos/coreos/clair-jwt-docker/events",
"assignees_url": "https://api.github.com/repos/coreos/clair-jwt-docker/assignees{/user}",
"branches_url": "https://api.github.com/repos/coreos/clair-jwt-docker/branches{/branch}",
"tags_url": "https://api.github.com/repos/coreos/clair-jwt-docker/tags",
"blobs_url": "https://api.github.com/repos/coreos/clair-jwt-docker/git/blobs{/sha}",
"git_tags_url": "https://api.github.com/repos/coreos/clair-jwt-docker/git/tags{/sha}",
"git_refs_url": "https://api.github.com/repos/coreos/clair-jwt-docker/git/refs{/sha}",
"trees_url": "https://api.github.com/repos/coreos/clair-jwt-docker/git/trees{/sha}",
"statuses_url": "https://api.github.com/repos/coreos/clair-jwt-docker/statuses/{sha}",
"languages_url": "https://api.github.com/repos/coreos/clair-jwt-docker/languages",
"stargazers_url": "https://api.github.com/repos/coreos/clair-jwt-docker/stargazers",
"contributors_url": "https://api.github.com/repos/coreos/clair-jwt-docker/contributors",
"subscribers_url": "https://api.github.com/repos/coreos/clair-jwt-docker/subscribers",
"subscription_url": "https://api.github.com/repos/coreos/clair-jwt-docker/subscription",
"commits_url": "https://api.github.com/repos/coreos/clair-jwt-docker/commits{/sha}",
"git_commits_url": "https://api.github.com/repos/coreos/clair-jwt-docker/git/commits{/sha}",
"comments_url": "https://api.github.com/repos/coreos/clair-jwt-docker/comments{/number}",
"issue_comment_url": "https://api.github.com/repos/coreos/clair-jwt-docker/issues/comments{/number}",
"contents_url": "https://api.github.com/repos/coreos/clair-jwt-docker/contents/{+path}",
"compare_url": "https://api.github.com/repos/coreos/clair-jwt-docker/compare/{base}...{head}",
"merges_url": "https://api.github.com/repos/coreos/clair-jwt-docker/merges",
"archive_url": "https://api.github.com/repos/coreos/clair-jwt-docker/{archive_format}{/ref}",
"downloads_url": "https://api.github.com/repos/coreos/clair-jwt-docker/downloads",
"issues_url": "https://api.github.com/repos/coreos/clair-jwt-docker/issues{/number}",
"pulls_url": "https://api.github.com/repos/coreos/clair-jwt-docker/pulls{/number}",
"milestones_url": "https://api.github.com/repos/coreos/clair-jwt-docker/milestones{/number}",
"notifications_url": "https://api.github.com/repos/coreos/clair-jwt-docker/notifications{?since,all,participating}",
"labels_url": "https://api.github.com/repos/coreos/clair-jwt-docker/labels{/name}",
"releases_url": "https://api.github.com/repos/coreos/clair-jwt-docker/releases{/id}",
"deployments_url": "https://api.github.com/repos/coreos/clair-jwt-docker/deployments",
"created_at": 1461165926,
"updated_at": "2016-11-03T18:20:01Z",
"pushed_at": 1479313569,
"git_url": "git://github.com/coreos/clair-jwt-docker.git",
"ssh_url": "git@github.com:coreos/clair-jwt-docker.git",
"clone_url": "https://github.com/coreos/clair-jwt-docker.git",
"svn_url": "https://github.com/coreos/clair-jwt-docker",
"homepage": "",
"size": 3114,
"stargazers_count": 0,
"watchers_count": 0,
"language": "Shell",
"has_issues": true,
"has_downloads": true,
"has_wiki": true,
"has_pages": false,
"forks_count": 0,
"mirror_url": null,
"open_issues_count": 0,
"forks": 0,
"open_issues": 0,
"watchers": 0,
"default_branch": "master",
"stargazers": 0,
"master_branch": "master",
"organization": "coreos"
},
"pusher": {
"name": "jzelinskie",
"email": "jimmy.zelinskie+git@gmail.com"
},
"organization": {
"login": "coreos",
"id": 3730757,
"url": "https://api.github.com/orgs/coreos",
"repos_url": "https://api.github.com/orgs/coreos/repos",
"events_url": "https://api.github.com/orgs/coreos/events",
"hooks_url": "https://api.github.com/orgs/coreos/hooks",
"issues_url": "https://api.github.com/orgs/coreos/issues",
"members_url": "https://api.github.com/orgs/coreos/members{/member}",
"public_members_url": "https://api.github.com/orgs/coreos/public_members{/member}",
"avatar_url": "https://avatars.githubusercontent.com/u/3730757?v=3",
"description": "Open Source Projects for Linux Containers"
},
"sender": {
"login": "jzelinskie",
"id": 343539,
"avatar_url": "https://avatars.githubusercontent.com/u/343539?v=3",
"gravatar_id": "",
"url": "https://api.github.com/users/jzelinskie",
"html_url": "https://github.com/jzelinskie",
"followers_url": "https://api.github.com/users/jzelinskie/followers",
"following_url": "https://api.github.com/users/jzelinskie/following{/other_user}",
"gists_url": "https://api.github.com/users/jzelinskie/gists{/gist_id}",
"starred_url": "https://api.github.com/users/jzelinskie/starred{/owner}{/repo}",
"subscriptions_url": "https://api.github.com/users/jzelinskie/subscriptions",
"organizations_url": "https://api.github.com/users/jzelinskie/orgs",
"repos_url": "https://api.github.com/users/jzelinskie/repos",
"events_url": "https://api.github.com/users/jzelinskie/events{/privacy}",
"received_events_url": "https://api.github.com/users/jzelinskie/received_events",
"type": "User",
"site_admin": false
}
}