test(endpoints/api): ensure empty 202 resp

This commit is contained in:
EvB 2016-12-14 16:24:06 -05:00
parent 43aed7c6f4
commit 0a5d4990e6
2 changed files with 60 additions and 45 deletions

View file

@ -198,6 +198,12 @@ class ApiTestCase(unittest.TestCase):
self.assertEquals(rv.status_code, expected_code) self.assertEquals(rv.status_code, expected_code)
return rv.data return rv.data
def deleteEmptyResponse(self, resource_name, params={}, expected_code=204):
rv = self.app.delete(self.url_for(resource_name, params))
self.assertEquals(rv.status_code, expected_code)
self.assertEquals(rv.data, '') # ensure response body empty
return
def postJsonResponse(self, resource_name, params={}, data={}, def postJsonResponse(self, resource_name, params={}, data={},
expected_code=200): expected_code=200):
rv = self.app.post(self.url_for(resource_name, params), rv = self.app.post(self.url_for(resource_name, params),
@ -351,7 +357,7 @@ class TestUserStarredRepositoryList(ApiTestCase):
assert json['namespace'] == 'public' assert json['namespace'] == 'public'
assert json['repository'] == 'publicrepo' assert json['repository'] == 'publicrepo'
self.deleteResponse(StarredRepository, params=dict(repository='public/publicrepo'), self.deleteEmptyResponse(StarredRepository, params=dict(repository='public/publicrepo'),
expected_code=204) expected_code=204)
json = self.getJsonResponse(StarredRepositoryList) json = self.getJsonResponse(StarredRepositoryList)
@ -804,9 +810,9 @@ class TestDeleteNamespace(ApiTestCase):
# Delete the two orgs, checking in between. # Delete the two orgs, checking in between.
with check_transitive_deletes(): with check_transitive_deletes():
self.deleteResponse(Organization, params=dict(orgname=ORGANIZATION), expected_code=204) self.deleteEmptyResponse(Organization, params=dict(orgname=ORGANIZATION), expected_code=204)
self.deleteResponse(User, expected_code=400) # Should still fail. self.deleteResponse(User, expected_code=400) # Should still fail.
self.deleteResponse(Organization, params=dict(orgname='library'), expected_code=204) self.deleteEmptyResponse(Organization, params=dict(orgname='library'), expected_code=204)
# Add some queue items for the user. # Add some queue items for the user.
notification_queue.put([ADMIN_ACCESS_USER, 'somerepo', 'somename'], '{}') notification_queue.put([ADMIN_ACCESS_USER, 'somerepo', 'somename'], '{}')
@ -814,7 +820,7 @@ class TestDeleteNamespace(ApiTestCase):
# Now delete the user. # Now delete the user.
with check_transitive_deletes(): with check_transitive_deletes():
self.deleteResponse(User, expected_code=204) self.deleteEmptyResponse(User, expected_code=204)
# Ensure the queue items are gone. # Ensure the queue items are gone.
self.assertIsNone(notification_queue.get()) self.assertIsNone(notification_queue.get())
@ -828,12 +834,12 @@ class TestDeleteNamespace(ApiTestCase):
model.user.attach_federated_login(user, 'github', 'something', {}) model.user.attach_federated_login(user, 'github', 'something', {})
with check_transitive_deletes(): with check_transitive_deletes():
self.deleteResponse(User, expected_code=204) self.deleteEmptyResponse(User, expected_code=204)
def test_delete_prompted_user(self): def test_delete_prompted_user(self):
self.login('randomuser') self.login('randomuser')
with check_transitive_deletes(): with check_transitive_deletes():
self.deleteResponse(User, expected_code=204) self.deleteEmptyResponse(User, expected_code=204)
class TestSignin(ApiTestCase): class TestSignin(ApiTestCase):
@ -1215,8 +1221,8 @@ class TestDeleteOrganizationPrototypes(ApiTestCase):
pid = ids[0] pid = ids[0]
# Delete a prototype. # Delete a prototype.
self.deleteResponse(PermissionPrototype, self.deleteEmptyResponse(PermissionPrototype,
params=dict(orgname=ORGANIZATION, prototypeid=pid)) params=dict(orgname=ORGANIZATION, prototypeid=pid))
# Verify the prototype no longer exists. # Verify the prototype no longer exists.
json = self.getJsonResponse(PermissionPrototypeList, json = self.getJsonResponse(PermissionPrototypeList,
@ -1283,7 +1289,7 @@ class TestRemoveOrganizationMember(ApiTestCase):
assert ADMIN_ACCESS_USER in membernames assert ADMIN_ACCESS_USER in membernames
assert READ_ACCESS_USER in membernames assert READ_ACCESS_USER in membernames
self.deleteResponse(OrganizationMember, self.deleteEmptyResponse(OrganizationMember,
params=dict(orgname=ORGANIZATION, membername=READ_ACCESS_USER)) params=dict(orgname=ORGANIZATION, membername=READ_ACCESS_USER))
json = self.getJsonResponse(OrganizationMemberList, json = self.getJsonResponse(OrganizationMemberList,
@ -1313,7 +1319,7 @@ class TestRemoveOrganizationMember(ApiTestCase):
assert READ_ACCESS_USER in org_perms assert READ_ACCESS_USER in org_perms
# Remove the user from the org. # Remove the user from the org.
self.deleteResponse(OrganizationMember, self.deleteEmptyResponse(OrganizationMember,
params=dict(orgname=ORGANIZATION, membername=READ_ACCESS_USER)) params=dict(orgname=ORGANIZATION, membername=READ_ACCESS_USER))
# Verify that the user's permission on the org repo is gone, but it is still # Verify that the user's permission on the org repo is gone, but it is still
@ -1394,8 +1400,8 @@ class TestDeleteOrganizationTeam(ApiTestCase):
def test_deleteteam(self): def test_deleteteam(self):
self.login(ADMIN_ACCESS_USER) self.login(ADMIN_ACCESS_USER)
self.deleteResponse(OrganizationTeam, self.deleteEmptyResponse(OrganizationTeam,
params=dict(orgname=ORGANIZATION, teamname='readers')) params=dict(orgname=ORGANIZATION, teamname='readers'))
# Make sure the team was deleted # Make sure the team was deleted
json = self.getJsonResponse(Organization, json = self.getJsonResponse(Organization,
@ -1593,8 +1599,8 @@ class TestDeclineTeamMemberInvite(ApiTestCase):
invites = list(model.team.lookup_team_invites(user)) invites = list(model.team.lookup_team_invites(user))
self.assertEquals(1, len(invites)) self.assertEquals(1, len(invites))
self.deleteResponse(TeamMemberInvite, self.deleteEmptyResponse(TeamMemberInvite,
params=dict(code=invites[0].invite_token)) params=dict(code=invites[0].invite_token))
# Make sure the invite was deleted. # Make sure the invite was deleted.
self.deleteResponse(TeamMemberInvite, self.deleteResponse(TeamMemberInvite,
@ -1631,9 +1637,9 @@ class TestDeleteOrganizationTeamMember(ApiTestCase):
self.assertEquals(len(json['members']), 4) self.assertEquals(len(json['members']), 4)
# Delete the invite. # Delete the invite.
self.deleteResponse(TeamMember, self.deleteEmptyResponse(TeamMember,
params=dict(orgname=ORGANIZATION, teamname='readers', params=dict(orgname=ORGANIZATION, teamname='readers',
membername=membername)) membername=membername))
# Verify the user was removed from the team. # Verify the user was removed from the team.
@ -1648,7 +1654,7 @@ class TestDeleteOrganizationTeamMember(ApiTestCase):
def test_deletemember(self): def test_deletemember(self):
self.login(ADMIN_ACCESS_USER) self.login(ADMIN_ACCESS_USER)
self.deleteResponse(TeamMember, self.deleteEmptyResponse(TeamMember,
params=dict(orgname=ORGANIZATION, teamname='readers', params=dict(orgname=ORGANIZATION, teamname='readers',
membername=READ_ACCESS_USER)) membername=READ_ACCESS_USER))
@ -2046,7 +2052,7 @@ class TestDeleteRepository(ApiTestCase):
dockerfile_build_queue.put([ADMIN_ACCESS_USER, 'simple'], '{}') dockerfile_build_queue.put([ADMIN_ACCESS_USER, 'simple'], '{}')
# Delete the repository. # Delete the repository.
self.deleteResponse(Repository, params=dict(repository=self.SIMPLE_REPO)) self.deleteEmptyResponse(Repository, params=dict(repository=self.SIMPLE_REPO))
# Ensure the queue item is gone. # Ensure the queue item is gone.
self.assertIsNone(dockerfile_build_queue.get()) self.assertIsNone(dockerfile_build_queue.get())
@ -2068,7 +2074,7 @@ class TestDeleteRepository(ApiTestCase):
dockerfile_build_queue.put([ADMIN_ACCESS_USER, 'anotherrepo'], '{}', available_after=-1) dockerfile_build_queue.put([ADMIN_ACCESS_USER, 'anotherrepo'], '{}', available_after=-1)
# Delete the repository. # Delete the repository.
self.deleteResponse(Repository, params=dict(repository=self.SIMPLE_REPO)) self.deleteEmptyResponse(Repository, params=dict(repository=self.SIMPLE_REPO))
# Ensure the other queue item is still present. # Ensure the other queue item is still present.
self.assertIsNotNone(dockerfile_build_queue.get()) self.assertIsNotNone(dockerfile_build_queue.get())
@ -2080,7 +2086,7 @@ class TestDeleteRepository(ApiTestCase):
self.getResponse(Repository, self.getResponse(Repository,
params=dict(repository=self.COMPLEX_REPO)) params=dict(repository=self.COMPLEX_REPO))
self.deleteResponse(Repository, params=dict(repository=self.COMPLEX_REPO)) self.deleteEmptyResponse(Repository, params=dict(repository=self.COMPLEX_REPO))
# Verify the repo was deleted. # Verify the repo was deleted.
self.getResponse(Repository, self.getResponse(Repository,
@ -2150,7 +2156,7 @@ class TestDeleteRepository(ApiTestCase):
# Delete the repository. # Delete the repository.
with check_transitive_deletes(): with check_transitive_deletes():
self.deleteResponse(Repository, params=dict(repository=self.COMPLEX_REPO)) self.deleteEmptyResponse(Repository, params=dict(repository=self.COMPLEX_REPO))
# Verify the repo was deleted. # Verify the repo was deleted.
self.getResponse(Repository, self.getResponse(Repository,
@ -2625,7 +2631,7 @@ class TestRepositoryNotifications(ApiTestCase):
assert wid in ids assert wid in ids
# Delete the notification. # Delete the notification.
self.deleteResponse(RepositoryNotification, self.deleteEmptyResponse(RepositoryNotification,
params=dict(repository=ADMIN_ACCESS_USER + '/simple', uuid=wid), params=dict(repository=ADMIN_ACCESS_USER + '/simple', uuid=wid),
expected_code=204) expected_code=204)
@ -2786,7 +2792,7 @@ class TestListAndDeleteTag(ApiTestCase):
assert len(prod_images) == len(staging_images) + 1 assert len(prod_images) == len(staging_images) + 1
# Delete prod. # Delete prod.
self.deleteResponse(RepositoryTag, self.deleteEmptyResponse(RepositoryTag,
params=dict(repository=ADMIN_ACCESS_USER + '/complex', tag='prod'), params=dict(repository=ADMIN_ACCESS_USER + '/complex', tag='prod'),
expected_code=204) expected_code=204)
@ -2849,7 +2855,7 @@ class TestListAndDeleteTag(ApiTestCase):
assert len(prod_images) > 0 assert len(prod_images) > 0
# Delete staging. # Delete staging.
self.deleteResponse(RepositoryTag, self.deleteEmptyResponse(RepositoryTag,
params=dict(repository=ADMIN_ACCESS_USER + '/complex', tag='staging'), params=dict(repository=ADMIN_ACCESS_USER + '/complex', tag='staging'),
expected_code=204) expected_code=204)
@ -2989,7 +2995,7 @@ class TestRepoPermissions(ApiTestCase):
self.assertEquals('admin', permissions[NO_ACCESS_USER]['role']) self.assertEquals('admin', permissions[NO_ACCESS_USER]['role'])
# Delete the user's permission. # Delete the user's permission.
self.deleteResponse(RepositoryUserPermission, self.deleteEmptyResponse(RepositoryUserPermission,
params=dict(repository=ADMIN_ACCESS_USER + '/simple', params=dict(repository=ADMIN_ACCESS_USER + '/simple',
username=NO_ACCESS_USER)) username=NO_ACCESS_USER))
@ -3040,7 +3046,7 @@ class TestRepoPermissions(ApiTestCase):
self.assertEquals('admin', permissions['owners']['role']) self.assertEquals('admin', permissions['owners']['role'])
# Delete the team's permission. # Delete the team's permission.
self.deleteResponse(RepositoryTeamPermission, self.deleteEmptyResponse(RepositoryTeamPermission,
params=dict(repository=ORGANIZATION + '/' + ORG_REPO, teamname='owners')) params=dict(repository=ORGANIZATION + '/' + ORG_REPO, teamname='owners'))
# Verify. # Verify.
@ -3090,8 +3096,9 @@ class TestApiTokens(ApiTestCase):
self.assertEquals('write', json['role']) self.assertEquals('write', json['role'])
# Delete the token. # Delete the token.
self.deleteResponse(RepositoryToken, self.deleteEmptyResponse(RepositoryToken,
params=dict(repository=ADMIN_ACCESS_USER + '/simple', code=token_code)) params=dict(repository=ADMIN_ACCESS_USER + '/simple',
code=token_code))
# Verify. # Verify.
self.getResponse(RepositoryToken, self.getResponse(RepositoryToken,
@ -3219,7 +3226,7 @@ class TestUserRobots(ApiTestCase):
assert NO_ACCESS_USER + '+bender' in robots assert NO_ACCESS_USER + '+bender' in robots
# Delete the robot. # Delete the robot.
self.deleteResponse(UserRobot, self.deleteEmptyResponse(UserRobot,
params=dict(robot_shortname='bender')) params=dict(robot_shortname='bender'))
# Verify. # Verify.
@ -3328,7 +3335,7 @@ class TestOrgRobots(ApiTestCase):
model.log.log_action('pull_repo', ORGANIZATION, performer=pull_robot, repository=repo) model.log.log_action('pull_repo', ORGANIZATION, performer=pull_robot, repository=repo)
# Delete the robot and verify it works. # Delete the robot and verify it works.
self.deleteResponse(OrgRobot, self.deleteEmptyResponse(OrgRobot,
params=dict(orgname=ORGANIZATION, robot_shortname='bender')) params=dict(orgname=ORGANIZATION, robot_shortname='bender'))
# Verify the build is still present. # Verify the build is still present.
@ -3362,7 +3369,7 @@ class TestOrgRobots(ApiTestCase):
assert ORGANIZATION + '+bender' in robots assert ORGANIZATION + '+bender' in robots
# Delete the robot. # Delete the robot.
self.deleteResponse(OrgRobot, self.deleteEmptyResponse(OrgRobot,
params=dict(orgname=ORGANIZATION, robot_shortname='bender')) params=dict(orgname=ORGANIZATION, robot_shortname='bender'))
# Verify. # Verify.
@ -3515,7 +3522,7 @@ class TestOrganizationApplicationResource(ApiTestCase):
self.assertEquals(json, edit_json) self.assertEquals(json, edit_json)
# Delete the application. # Delete the application.
self.deleteResponse(OrganizationApplicationResource, self.deleteEmptyResponse(OrganizationApplicationResource,
params=dict(orgname=ORGANIZATION, client_id=FAKE_APPLICATION_CLIENT_ID)) params=dict(orgname=ORGANIZATION, client_id=FAKE_APPLICATION_CLIENT_ID))
# Make sure the application is gone. # Make sure the application is gone.
@ -3660,7 +3667,8 @@ class TestBuildTriggers(ApiTestCase):
trigger = json['triggers'][0] trigger = json['triggers'][0]
# Delete the trigger. # Delete the trigger.
self.deleteResponse(BuildTrigger, params=dict(repository=ADMIN_ACCESS_USER + '/building', self.deleteEmptyResponse(BuildTrigger,
params=dict(repository=ADMIN_ACCESS_USER + '/building',
trigger_uuid=trigger['id'])) trigger_uuid=trigger['id']))
# Verify it was deleted. # Verify it was deleted.
@ -3936,7 +3944,7 @@ class TestUserAuthorizations(ApiTestCase):
self.assertEquals(authorization, get_json) self.assertEquals(authorization, get_json)
# Delete the authorization. # Delete the authorization.
self.deleteResponse(UserAuthorization, params=dict(access_token_uuid=authorization['uuid'])) self.deleteEmptyResponse(UserAuthorization, params=dict(access_token_uuid=authorization['uuid']))
# Verify it has been deleted. # Verify it has been deleted.
self.getJsonResponse(UserAuthorization, params=dict(access_token_uuid=authorization['uuid']), self.getJsonResponse(UserAuthorization, params=dict(access_token_uuid=authorization['uuid']),
@ -4274,7 +4282,7 @@ class TestSuperUserKeyManagement(ApiTestCase):
with assert_action_logged('service_key_delete'): with assert_action_logged('service_key_delete'):
# Delete the key. # Delete the key.
self.deleteResponse(SuperUserServiceKey, params=dict(kid=key['kid'])) self.deleteEmptyResponse(SuperUserServiceKey, params=dict(kid=key['kid']))
# Ensure the key no longer exists. # Ensure the key no longer exists.
self.getResponse(SuperUserServiceKey, params=dict(kid=key['kid']), expected_code=404) self.getResponse(SuperUserServiceKey, params=dict(kid=key['kid']), expected_code=404)
@ -4425,7 +4433,7 @@ class TestRepositoryManifestLabels(ApiTestCase):
# Delete a label. # Delete a label.
with assert_action_logged('manifest_label_delete'): with assert_action_logged('manifest_label_delete'):
self.deleteResponse(ManageRepositoryManifestLabel, self.deleteEmptyResponse(ManageRepositoryManifestLabel,
params=dict(repository=repository, params=dict(repository=repository,
manifestref=tag_manifest.digest, manifestref=tag_manifest.digest,
labelid=label1['label']['id'])) labelid=label1['label']['id']))
@ -4528,7 +4536,7 @@ class TestSuperUserManagement(ApiTestCase):
self.assertEquals('freshuser', json['username']) self.assertEquals('freshuser', json['username'])
# Delete the user. # Delete the user.
self.deleteResponse(SuperUserManagement, params=dict(username='freshuser'), expected_code=204) self.deleteEmptyResponse(SuperUserManagement, params=dict(username='freshuser'), expected_code=204)
# Verify the user no longer exists. # Verify the user no longer exists.
self.getResponse(SuperUserManagement, params=dict(username='freshuser'), expected_code=404) self.getResponse(SuperUserManagement, params=dict(username='freshuser'), expected_code=404)
@ -4580,7 +4588,7 @@ class TestSuperUserManagement(ApiTestCase):
def test_delete_message(self): def test_delete_message(self):
self.login(ADMIN_ACCESS_USER) self.login(ADMIN_ACCESS_USER)
json = self.getJsonResponse(GlobalUserMessages) json = self.getJsonResponse(GlobalUserMessages)
self.deleteResponse(GlobalUserMessage, {"uuid": json['messages'][0]['uuid']}, 204) self.deleteEmptyResponse(GlobalUserMessage, {"uuid": json['messages'][0]['uuid']}, 204)
json = self.getJsonResponse(GlobalUserMessages) json = self.getJsonResponse(GlobalUserMessages)

View file

@ -89,13 +89,20 @@ class EndpointTestCase(unittest.TestCase):
self.assertEquals(rv.status_code, expected_code) self.assertEquals(rv.status_code, expected_code)
return rv.data return rv.data
def deleteResponse(self, resource_name, headers=None, expected_code=204, **kwargs): def deleteResponse(self, resource_name, headers=None, expected_code=200, **kwargs):
headers = headers or {} headers = headers or {}
rv = self.app.delete(url_for(resource_name, **kwargs), headers=headers) rv = self.app.delete(url_for(resource_name, **kwargs), headers=headers)
self.assertEquals(rv.status_code, expected_code) self.assertEquals(rv.status_code, expected_code)
return rv.data return rv.data
def putResponse(self, resource_name, headers=None, data=None, expected_code=204, **kwargs): def deleteEmptyResponse(self, resource_name, headers=None, expected_code=204, **kwargs):
headers = headers or {}
rv = self.app.delete(url_for(resource_name, **kwargs), headers=headers)
self.assertEquals(rv.status_code, expected_code)
self.assertEquals(rv.data, '') # ensure response body empty
return
def putResponse(self, resource_name, headers=None, data=None, expected_code=200, **kwargs):
headers = headers or {} headers = headers or {}
data = data or {} data = data or {}
rv = self.app.put(url_for(resource_name, **kwargs), headers=headers, data=py_json.dumps(data)) rv = self.app.put(url_for(resource_name, **kwargs), headers=headers, data=py_json.dumps(data))
@ -651,7 +658,7 @@ class KeyServerTestCase(EndpointTestCase):
model.service_keys.set_key_expiration('first', datetime.utcnow() + timedelta(seconds=100)) model.service_keys.set_key_expiration('first', datetime.utcnow() + timedelta(seconds=100))
with assert_action_logged('service_key_delete'): with assert_action_logged('service_key_delete'):
self.deleteResponse('key_server.delete_service_key', self.deleteEmptyResponse('key_server.delete_service_key',
headers={'Authorization': 'Bearer %s' % token}, headers={'Authorization': 'Bearer %s' % token},
expected_code=204, service='sample_service', kid='second') expected_code=204, service='sample_service', kid='second')
@ -671,7 +678,7 @@ class KeyServerTestCase(EndpointTestCase):
# Delete our unapproved key with itself. # Delete our unapproved key with itself.
with assert_action_logged('service_key_delete'): with assert_action_logged('service_key_delete'):
self.deleteResponse('key_server.delete_service_key', self.deleteEmptyResponse('key_server.delete_service_key',
headers={'Authorization': 'Bearer %s' % token}, headers={'Authorization': 'Bearer %s' % token},
expected_code=204, service='sample_service', kid='unapprovedkeyhere') expected_code=204, service='sample_service', kid='unapprovedkeyhere')
@ -699,7 +706,7 @@ class KeyServerTestCase(EndpointTestCase):
# Using the credentials of our approved key, delete our unapproved key # Using the credentials of our approved key, delete our unapproved key
with assert_action_logged('service_key_delete'): with assert_action_logged('service_key_delete'):
self.deleteResponse('key_server.delete_service_key', self.deleteEmptyResponse('key_server.delete_service_key',
headers={'Authorization': 'Bearer %s' % token}, headers={'Authorization': 'Bearer %s' % token},
expected_code=204, service='sample_service', kid='kid321') expected_code=204, service='sample_service', kid='kid321')
@ -712,7 +719,7 @@ class KeyServerTestCase(EndpointTestCase):
# Delete a self-signed, approved key # Delete a self-signed, approved key
with assert_action_logged('service_key_delete'): with assert_action_logged('service_key_delete'):
self.deleteResponse('key_server.delete_service_key', self.deleteEmptyResponse('key_server.delete_service_key',
headers={'Authorization': 'Bearer %s' % token}, headers={'Authorization': 'Bearer %s' % token},
expected_code=204, service='sample_service', kid='kid123') expected_code=204, service='sample_service', kid='kid123')