mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-01 23:20:51 +00:00
new admin groups page
This commit is contained in:
104
tests/api/endpoints/admin/test_groups.py
Normal file
104
tests/api/endpoints/admin/test_groups.py
Normal file
@@ -0,0 +1,104 @@
|
||||
import json
|
||||
from django.core.urlresolvers import reverse
|
||||
from seahub.test_utils import BaseTestCase
|
||||
|
||||
class GroupsTest(BaseTestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.user_name = self.user.username
|
||||
self.admin_name = self.admin.username
|
||||
|
||||
def tearDown(self):
|
||||
self.remove_group()
|
||||
|
||||
def test_can_get(self):
|
||||
self.login_as(self.admin)
|
||||
url = reverse('api-v2.1-admin-groups')
|
||||
resp = self.client.get(url)
|
||||
|
||||
json_resp = json.loads(resp.content)
|
||||
assert len(json_resp['groups']) > 0
|
||||
|
||||
def test_get_with_invalid_user_permission(self):
|
||||
self.login_as(self.user)
|
||||
url = reverse('api-v2.1-admin-groups')
|
||||
resp = self.client.get(url)
|
||||
self.assertEqual(403, resp.status_code)
|
||||
|
||||
class GroupTest(BaseTestCase):
|
||||
|
||||
def setUp(self):
|
||||
self.user_name = self.user.username
|
||||
self.admin_name = self.admin.username
|
||||
self.group_id = self.group.id
|
||||
|
||||
def test_can_transfer_group(self):
|
||||
|
||||
self.login_as(self.admin)
|
||||
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'old_owner=%s&new_owner=%s' % (self.user_name, self.admin_name)
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
|
||||
self.assertEqual(200, resp.status_code)
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['owner'] == self.admin_name
|
||||
|
||||
def test_transfer_group_invalid_user_permission(self):
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'old_owner=%s&new_owner=%s' % (self.user_name, self.admin_name)
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
|
||||
self.assertEqual(403, resp.status_code)
|
||||
|
||||
def test_transfer_group_invalid_args(self):
|
||||
|
||||
self.login_as(self.admin)
|
||||
|
||||
# invalid old owner
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'invalid_old_owner=%s&new_owner=%s' % (self.user_name, self.admin_name)
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
# invalid new owner
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'old_owner=%s&invalid_new_owner=%s' % (self.user_name, self.admin_name)
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
# new_owner is the same as old_owner
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'old_owner=%s&new_owner=%s' % (self.user_name, self.user_name)
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
# old_owner is not group owner.
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'old_owner=%s&new_owner=%s' % (self.admin_name, self.admin_name)
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
# new owner not exist
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
data = 'old_owner=%s&new_owner=%s' % (self.user_name, 'invalid@user.com')
|
||||
resp = self.client.put(url, data, 'application/x-www-form-urlencoded')
|
||||
self.assertEqual(404, resp.status_code)
|
||||
|
||||
def test_can_delete(self):
|
||||
self.login_as(self.admin)
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
resp = self.client.delete(url)
|
||||
self.assertEqual(200, resp.status_code)
|
||||
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['success'] is True
|
||||
|
||||
def test_delete_with_invalid_user_permission(self):
|
||||
self.login_as(self.user)
|
||||
url = reverse('api-v2.1-admin-group', args=[self.group_id])
|
||||
resp = self.client.delete(url)
|
||||
self.assertEqual(403, resp.status_code)
|
Reference in New Issue
Block a user