redash/tests/handlers/test_permissions.py
Arik Fraimovich 2dff8b9a00
Black support for the Python codebase (#4297)
* Apply black formatting

* Add auto formatting when committing to master

* Update CONTRIBUTING.md re. Black & Prettier
2019-12-11 13:54:29 +02:00

227 lines
7.5 KiB
Python

from tests import BaseTestCase
from redash.models import AccessPermission
from redash.permissions import ACCESS_TYPE_MODIFY
class TestObjectPermissionsListGet(BaseTestCase):
def test_returns_empty_list_when_no_permissions(self):
query = self.factory.create_query()
user = self.factory.user
rv = self.make_request("get", "/api/queries/{}/acl".format(query.id), user=user)
self.assertEqual(rv.status_code, 200)
self.assertEqual({}, rv.json)
def test_returns_permissions(self):
query = self.factory.create_query()
user = self.factory.user
AccessPermission.grant(
obj=query,
access_type=ACCESS_TYPE_MODIFY,
grantor=self.factory.user,
grantee=self.factory.user,
)
rv = self.make_request("get", "/api/queries/{}/acl".format(query.id), user=user)
self.assertEqual(rv.status_code, 200)
self.assertIn("modify", rv.json)
self.assertEqual(user.id, rv.json["modify"][0]["id"])
def test_returns_404_for_outside_of_organization_users(self):
query = self.factory.create_query()
user = self.factory.create_user(org=self.factory.create_org())
rv = self.make_request("get", "/api/queries/{}/acl".format(query.id), user=user)
self.assertEqual(rv.status_code, 404)
class TestObjectPermissionsListPost(BaseTestCase):
def test_creates_permission_if_the_user_is_an_owner(self):
query = self.factory.create_query()
other_user = self.factory.create_user()
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": other_user.id}
rv = self.make_request(
"post", "/api/queries/{}/acl".format(query.id), user=query.user, data=data
)
self.assertEqual(200, rv.status_code)
self.assertTrue(AccessPermission.exists(query, ACCESS_TYPE_MODIFY, other_user))
def test_returns_403_if_the_user_isnt_owner(self):
query = self.factory.create_query()
other_user = self.factory.create_user()
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": other_user.id}
rv = self.make_request(
"post", "/api/queries/{}/acl".format(query.id), user=other_user, data=data
)
self.assertEqual(403, rv.status_code)
def test_returns_400_if_the_grantee_isnt_from_organization(self):
query = self.factory.create_query()
other_user = self.factory.create_user(org=self.factory.create_org())
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": other_user.id}
rv = self.make_request(
"post", "/api/queries/{}/acl".format(query.id), user=query.user, data=data
)
self.assertEqual(400, rv.status_code)
def test_returns_404_if_the_user_from_different_org(self):
query = self.factory.create_query()
other_user = self.factory.create_user(org=self.factory.create_org())
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": other_user.id}
rv = self.make_request(
"post", "/api/queries/{}/acl".format(query.id), user=other_user, data=data
)
self.assertEqual(404, rv.status_code)
def test_accepts_only_correct_access_types(self):
query = self.factory.create_query()
other_user = self.factory.create_user()
data = {"access_type": "random string", "user_id": other_user.id}
rv = self.make_request(
"post", "/api/queries/{}/acl".format(query.id), user=query.user, data=data
)
self.assertEqual(400, rv.status_code)
class TestObjectPermissionsListDelete(BaseTestCase):
def test_removes_permission(self):
query = self.factory.create_query()
user = self.factory.user
other_user = self.factory.create_user()
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": other_user.id}
AccessPermission.grant(
obj=query,
access_type=ACCESS_TYPE_MODIFY,
grantor=self.factory.user,
grantee=other_user,
)
rv = self.make_request(
"delete", "/api/queries/{}/acl".format(query.id), user=user, data=data
)
self.assertEqual(rv.status_code, 200)
self.assertFalse(AccessPermission.exists(query, ACCESS_TYPE_MODIFY, other_user))
def test_removes_permission_created_by_another_user(self):
query = self.factory.create_query()
other_user = self.factory.create_user()
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": other_user.id}
AccessPermission.grant(
obj=query,
access_type=ACCESS_TYPE_MODIFY,
grantor=self.factory.user,
grantee=other_user,
)
rv = self.make_request(
"delete",
"/api/queries/{}/acl".format(query.id),
user=self.factory.create_admin(),
data=data,
)
self.assertEqual(rv.status_code, 200)
self.assertFalse(AccessPermission.exists(query, ACCESS_TYPE_MODIFY, other_user))
def test_returns_404_for_outside_of_organization_users(self):
query = self.factory.create_query()
user = self.factory.create_user(org=self.factory.create_org())
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": user.id}
rv = self.make_request(
"delete", "/api/queries/{}/acl".format(query.id), user=user, data=data
)
self.assertEqual(rv.status_code, 404)
def test_returns_403_for_non_owner(self):
query = self.factory.create_query()
user = self.factory.create_user()
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": user.id}
rv = self.make_request(
"delete", "/api/queries/{}/acl".format(query.id), user=user, data=data
)
self.assertEqual(rv.status_code, 403)
def test_returns_200_even_if_there_is_no_permission(self):
query = self.factory.create_query()
user = self.factory.create_user()
data = {"access_type": ACCESS_TYPE_MODIFY, "user_id": user.id}
rv = self.make_request(
"delete", "/api/queries/{}/acl".format(query.id), user=query.user, data=data
)
self.assertEqual(rv.status_code, 200)
class TestCheckPermissionsGet(BaseTestCase):
def test_returns_true_for_existing_permission(self):
query = self.factory.create_query()
other_user = self.factory.create_user()
AccessPermission.grant(
obj=query,
access_type=ACCESS_TYPE_MODIFY,
grantor=self.factory.user,
grantee=other_user,
)
rv = self.make_request(
"get",
"/api/queries/{}/acl/{}".format(query.id, ACCESS_TYPE_MODIFY),
user=other_user,
)
self.assertEqual(rv.status_code, 200)
self.assertEqual(True, rv.json["response"])
def test_returns_false_for_existing_permission(self):
query = self.factory.create_query()
other_user = self.factory.create_user()
rv = self.make_request(
"get",
"/api/queries/{}/acl/{}".format(query.id, ACCESS_TYPE_MODIFY),
user=other_user,
)
self.assertEqual(rv.status_code, 200)
self.assertEqual(False, rv.json["response"])
def test_returns_404_for_outside_of_org_users(self):
query = self.factory.create_query()
other_user = self.factory.create_user(org=self.factory.create_org())
rv = self.make_request(
"get",
"/api/queries/{}/acl/{}".format(query.id, ACCESS_TYPE_MODIFY),
user=other_user,
)
self.assertEqual(rv.status_code, 404)