Skip to content

Commit

Permalink
add and improve tests
Browse files Browse the repository at this point in the history
  • Loading branch information
Johnetordoff committed Jul 16, 2018
1 parent d9155f5 commit 70441aa
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 11 deletions.
1 change: 0 additions & 1 deletion api/users/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -497,7 +497,6 @@ def get_object(self):

return {'_id': identity_id, 'external_id': identity.keys()[0], 'status': identity.values()[0]}


def perform_destroy(self, instance):
user = self.get_user()
identity_id = self.kwargs['identity_id']
Expand Down
45 changes: 35 additions & 10 deletions api_tests/users/views/test_user_external_identities.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,11 @@ def user():
return user


@pytest.fixture()
def unauthorized_user():
return AuthUserFactory()


@pytest.mark.django_db
class TestUserIdentitiesList:

Expand All @@ -29,22 +34,27 @@ def url(self, user):

def test_authorized_gets_200(self, app, user, url):
res = app.get(url, auth=user.auth)
print res.json['data']
assert res.status_code == 200
assert res.content_type == 'application/vnd.api+json'
assert res.json['data'] == {
'ORCID': {
'0000-0001-9143-4653': 'VERIFIED'
},
'LOTUS': {
'0000-0001-9143-4652': 'LINK'
}
}
assert res.json['data'][0]['attributes'] == {u'status': u'LINK', u'external_id': u'0000-0001-9143-4652'}
assert res.json['data'][0]['type'] == 'external-identities'
assert res.json['data'][0]['id'] == 'LOTUS'

assert res.json['data'][1]['attributes'] == {u'status': u'VERIFIED', u'external_id': u'0000-0001-9143-4653'}
assert res.json['data'][1]['type'] == 'external-identities'
assert res.json['data'][1]['id'] == 'ORCID'

def test_anonymous_gets_401(self, app, url):
res = app.get(url, expect_errors=True)
assert res.status_code == 401
assert res.content_type == 'application/vnd.api+json'

def test_unauthorized_gets_403(self, app, url, unauthorized_user):
res = app.get(url, auth=unauthorized_user.auth, expect_errors=True)
assert res.status_code == 403
assert res.content_type == 'application/vnd.api+json'


@pytest.mark.django_db
class TestUserIdentitiesDetail:
Expand All @@ -57,14 +67,24 @@ def test_authorized_gets_200(self, app, user, url):
res = app.get(url, auth=user.auth)
assert res.status_code == 200
assert res.content_type == 'application/vnd.api+json'
assert res.json['data'] == {'ORCID': {'0000-0001-9143-4653': 'VERIFIED'}}
assert res.json['data'] == {
u'attributes': {
u'external_id': u'0000-0001-9143-4653',
u'status': u'VERIFIED'
},
u'id': u'ORCID',
u'links': {
u'self': u'http://localhost:8000/v2/users/{}/settings/identities/ORCID/'.format(user._id)
},
u'type': u'external-identities'
}

def test_anonymous_gets_401(self, app, url):
res = app.get(url, expect_errors=True)
assert res.status_code == 401
assert res.content_type == 'application/vnd.api+json'

def test_authorized_delete_204(self, app, user, url):
def test_no_creds_delete_204(self, app, user, url):
res = app.delete(url, auth=user.auth)
assert res.status_code == 204

Expand All @@ -74,3 +94,8 @@ def test_authorized_delete_204(self, app, user, url):
'0000-0001-9143-4652': 'LINK'
}
}

def test_unauthorized_delete_403(self, app, url, unauthorized_user):
res = app.get(url, auth=unauthorized_user.auth, expect_errors=True)
assert res.status_code == 403
assert res.content_type == 'application/vnd.api+json'

0 comments on commit 70441aa

Please sign in to comment.