mirror of
https://github.com/getredash/redash.git
synced 2026-03-23 04:00:09 -04:00
The issue is, if you try to revoke the permission of a user from an object, all the permissions on this object get removed. The fix is assigning filtered query object to it's own reference. According to SQLAlchemy documentation, `filter` method applies to the **copy** of the query object which means calling filter doesn't affect the object receiving filter call. For more information; http://docs.sqlalchemy.org/en/latest/orm/query.html#sqlalchemy.orm.query.Query.filter
82 lines
3.5 KiB
Python
82 lines
3.5 KiB
Python
from tests import BaseTestCase
|
|
from redash.models import AccessPermission
|
|
from redash.permissions import ACCESS_TYPE_MODIFY, ACCESS_TYPE_VIEW
|
|
|
|
|
|
class TestAccessPermissionGrant(BaseTestCase):
|
|
def test_creates_correct_object(self):
|
|
q = self.factory.create_query()
|
|
permission = AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=self.factory.user)
|
|
|
|
self.assertEqual(permission.object, q)
|
|
self.assertEqual(permission.grantor, self.factory.user)
|
|
self.assertEqual(permission.grantee, self.factory.user)
|
|
self.assertEqual(permission.access_type, ACCESS_TYPE_MODIFY)
|
|
|
|
def test_returns_existing_object_if_exists(self):
|
|
q = self.factory.create_query()
|
|
permission1 = AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=self.factory.user)
|
|
|
|
permission2 = AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=self.factory.user)
|
|
|
|
self.assertEqual(permission1.id, permission2.id)
|
|
|
|
|
|
class TestAccessPermissionRevoke(BaseTestCase):
|
|
def test_deletes_nothing_when_no_permission_exists(self):
|
|
q = self.factory.create_query()
|
|
self.assertEqual(0, AccessPermission.revoke(q, self.factory.user, ACCESS_TYPE_MODIFY))
|
|
|
|
def test_deletes_permission(self):
|
|
q = self.factory.create_query()
|
|
permission = AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=self.factory.user)
|
|
self.assertEqual(1, AccessPermission.revoke(q, self.factory.user, ACCESS_TYPE_MODIFY))
|
|
|
|
def test_deletes_permission_for_only_given_grantee_on_given_grant_type(self):
|
|
q = self.factory.create_query()
|
|
first_user = self.factory.create_user()
|
|
second_user = self.factory.create_user()
|
|
|
|
AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=first_user)
|
|
|
|
AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=second_user)
|
|
|
|
AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_VIEW,
|
|
grantor=self.factory.user,
|
|
grantee=second_user)
|
|
|
|
self.assertEqual(1, AccessPermission.revoke(q, second_user, ACCESS_TYPE_VIEW))
|
|
|
|
def test_deletes_all_permissions_if_no_type_given(self):
|
|
q = self.factory.create_query()
|
|
|
|
permission = AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_MODIFY,
|
|
grantor=self.factory.user,
|
|
grantee=self.factory.user)
|
|
|
|
permission = AccessPermission.grant(obj=q, access_type=ACCESS_TYPE_VIEW,
|
|
grantor=self.factory.user,
|
|
grantee=self.factory.user)
|
|
|
|
self.assertEqual(2, AccessPermission.revoke(q, self.factory.user))
|
|
|
|
|
|
class TestAccessPermissionFind(BaseTestCase):
|
|
pass
|
|
|
|
|
|
class TestAccessPermissionExists(BaseTestCase):
|
|
pass
|