1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-07-05 11:17:36 +00:00
seahub/tests/api/endpoints/admin/test_libraries.py
2018-09-27 17:07:23 +08:00

215 lines
6.4 KiB
Python

import json
from django.core.urlresolvers import reverse
from seahub.test_utils import BaseTestCase
from tests.common.utils import randstring
from seahub.share.models import FileShare, UploadLinkShare
class AdminLibrariesTest(BaseTestCase):
def setUp(self):
self.libraries_url = reverse('api-v2.1-admin-libraries')
def tearDown(self):
self.remove_repo()
def test_can_get(self):
self.login_as(self.admin)
resp = self.client.get(self.libraries_url)
json_resp = json.loads(resp.content)
assert len(json_resp['repos']) > 0
def test_can_search_by_name(self):
self.login_as(self.admin)
repo_name = self.repo.repo_name
searched_args = repo_name[0:1]
url = self.libraries_url + '?name=%s' % searched_args
resp = self.client.get(url)
json_resp = json.loads(resp.content)
assert json_resp['name'] == searched_args
assert searched_args in json_resp['repos'][0]['name']
def test_get_with_invalid_user_permission(self):
self.login_as(self.user)
resp = self.client.get(self.libraries_url)
self.assertEqual(403, resp.status_code)
def test_can_create(self):
self.login_as(self.admin)
repo_name = randstring(6)
repo_owner = self.user.username
data = {
'name': repo_name,
'owner': repo_owner,
}
resp = self.client.post(self.libraries_url, data)
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp['name'] == repo_name
assert json_resp['owner'] == repo_owner
self.remove_repo(json_resp['id'])
def test_can_create_without_owner_parameter(self):
self.login_as(self.admin)
repo_name = randstring(6)
data = {
'name': repo_name,
}
resp = self.client.post(self.libraries_url, data)
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp['name'] == repo_name
assert json_resp['owner'] == self.admin.username
self.remove_repo(json_resp['id'])
def test_create_with_invalid_user_permission(self):
self.login_as(self.user)
repo_name = randstring(6)
repo_owner = self.user.username
data = {
'name': repo_name,
'owner': repo_owner,
}
resp = self.client.post(self.libraries_url, data)
self.assertEqual(403, resp.status_code)
def test_create_with_invalid_name_parameter(self):
self.login_as(self.admin)
repo_name = randstring(6)
repo_owner = self.user.username
data = {
'invalid_name': repo_name,
'owner': repo_owner,
}
resp = self.client.post(self.libraries_url, data)
self.assertEqual(400, resp.status_code)
def test_create_with_unexisted_user(self):
self.login_as(self.admin)
repo_name = randstring(6)
repo_owner = '%s@email.com' % randstring(6)
data = {
'name': repo_name,
'owner': repo_owner,
}
resp = self.client.post(self.libraries_url, data)
self.assertEqual(404, resp.status_code)
class AdminLibraryTest(BaseTestCase):
def setUp(self):
self.user_name = self.user.username
self.admin_name = self.admin.username
self.repo_id= self.repo.repo_id
self.library_url = reverse('api-v2.1-admin-library', args=[self.repo_id])
self.fs_share = FileShare.objects.create_dir_link(self.user.username,
self.repo_id, self.folder, None, None)
self.fs_upload = UploadLinkShare.objects.create_upload_link_share(self.user.username,
self.repo_id, self.folder, None, None)
def test_can_get(self):
self.login_as(self.admin)
resp = self.client.get(self.library_url)
self.assertEqual(200, resp.status_code)
json_resp = json.loads(resp.content)
assert json_resp['owner'] == self.user_name
assert json_resp['name'] == self.repo.repo_name
def test_get_with_invalid_user_permission(self):
self.login_as(self.user)
resp = self.client.get(self.library_url)
self.assertEqual(403, resp.status_code)
def test_can_transfer(self):
self.login_as(self.admin)
data = 'owner=%s' % self.admin_name
resp = self.client.put(self.library_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)
data = 'owner=%s' % self.admin_name
resp = self.client.put(self.library_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)
# new owner not exist
data = 'owner=invalid@email.com'
resp = self.client.put(self.library_url, data, 'application/x-www-form-urlencoded')
self.assertEqual(404, resp.status_code)
def test_can_delete(self):
self.login_as(self.admin)
resp = self.client.delete(self.library_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)
resp = self.client.delete(self.library_url)
self.assertEqual(403, resp.status_code)
def test_reshare_to_share_links_after_transfer_repo(self):
self.login_as(self.admin)
assert len(UploadLinkShare.objects.all()) == 1
data = 'owner=%s' % self.admin_name
resp = self.client.put(self.library_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_reshare_to_upload_links_after_transfer_repo(self):
self.login_as(self.admin)
assert len(UploadLinkShare.objects.all()) == 1
data = 'owner=%s' % self.admin_name
resp = self.client.put(self.library_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