mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-02 23:48:47 +00:00
update repo batch api
1, add batch delete item api 2, check sub folder permission when batch delte/move item
This commit is contained in:
@@ -1025,6 +1025,38 @@ class ReposAsyncBatchMoveItemView(BaseTestCase):
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['error_msg'] == 'File %s is locked.' % admin_file_name
|
||||
|
||||
def test_move_with_r_permission_sub_folder(self):
|
||||
|
||||
if not LOCAL_PRO_DEV_ENV:
|
||||
return
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
# share admin's tmp repo to user with 'rw' permission
|
||||
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||
self.user_name, 'rw')
|
||||
|
||||
# admin set 'r' sub folder permission
|
||||
admin_folder_name = randstring(6)
|
||||
seafile_api.post_dir(admin_repo_id, '/', admin_folder_name, self.admin_name)
|
||||
seafile_api.add_folder_user_perm(admin_repo_id, '/' +
|
||||
admin_folder_name, 'r', self.user_name)
|
||||
|
||||
# user move r permission folder
|
||||
data = {
|
||||
"src_repo_id": admin_repo_id,
|
||||
"src_parent_dir": '/',
|
||||
"src_dirents":[admin_folder_name],
|
||||
"dst_repo_id": self.dst_repo_id,
|
||||
"dst_parent_dir": '/',
|
||||
}
|
||||
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(403, resp.status_code)
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['error_msg'] == "Can't move folder %s, please check its permission." % admin_folder_name
|
||||
|
||||
|
||||
class ReposSyncBatchCopyItemView(BaseTestCase):
|
||||
|
||||
def create_new_repo(self, username):
|
||||
@@ -1577,7 +1609,7 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
# share admin's tmp repo to user with 'r' permission
|
||||
# share admin's tmp repo to user with 'rw' permission
|
||||
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||
self.user_name, 'rw')
|
||||
@@ -1600,3 +1632,220 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
||||
self.assertEqual(403, resp.status_code)
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['error_msg'] == 'File %s is locked.' % admin_file_name
|
||||
|
||||
def test_move_with_r_permission_sub_folder(self):
|
||||
|
||||
if not LOCAL_PRO_DEV_ENV:
|
||||
return
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
# share admin's tmp repo to user with 'rw' permission
|
||||
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||
self.user_name, 'rw')
|
||||
|
||||
# admin set 'r' sub folder permission
|
||||
admin_folder_name = randstring(6)
|
||||
seafile_api.post_dir(admin_repo_id, '/', admin_folder_name, self.admin_name)
|
||||
seafile_api.add_folder_user_perm(admin_repo_id, '/' +
|
||||
admin_folder_name, 'r', self.user_name)
|
||||
|
||||
# user move r permission folder
|
||||
data = {
|
||||
"src_repo_id": admin_repo_id,
|
||||
"src_parent_dir": '/',
|
||||
"src_dirents":[admin_folder_name],
|
||||
"dst_repo_id": self.dst_repo_id,
|
||||
"dst_parent_dir": '/',
|
||||
}
|
||||
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(403, resp.status_code)
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['error_msg'] == "Can't move folder %s, please check its permission." % admin_folder_name
|
||||
|
||||
class ReposBatchDeleteItemView(BaseTestCase):
|
||||
|
||||
def create_new_repo(self, username):
|
||||
new_repo_id = seafile_api.create_repo(name=randstring(10),
|
||||
desc='', username=username, passwd=None)
|
||||
|
||||
return new_repo_id
|
||||
|
||||
def setUp(self):
|
||||
self.user_name = self.user.username
|
||||
self.admin_name = self.admin.username
|
||||
|
||||
self.repo_id = self.repo.id
|
||||
|
||||
self.file_path = self.file
|
||||
self.file_name = os.path.basename(self.file_path)
|
||||
|
||||
self.folder_path = self.folder
|
||||
self.folder_name = os.path.basename(self.folder)
|
||||
|
||||
self.url = reverse('api-v2.1-repos-batch-delete-item')
|
||||
|
||||
def tearDown(self):
|
||||
self.remove_repo(self.repo_id)
|
||||
|
||||
def test_can_delete(self):
|
||||
|
||||
# items in parent folder
|
||||
assert seafile_api.get_dir_id_by_path(self.repo_id, self.folder_path) != None
|
||||
assert seafile_api.get_file_id_by_path(self.repo_id, self.file_path) != None
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
data = {
|
||||
"repo_id": self.repo_id,
|
||||
"parent_dir": '/',
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
|
||||
resp = self.client.delete(self.url, json.dumps(data),
|
||||
'application/json')
|
||||
self.assertEqual(200, resp.status_code)
|
||||
|
||||
# items NOT in parent folder
|
||||
assert seafile_api.get_dir_id_by_path(self.repo_id, self.folder_path) is None
|
||||
assert seafile_api.get_file_id_by_path(self.repo_id, self.file_path) is None
|
||||
|
||||
def test_delete_with_invalid_parameter(self):
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
data = {
|
||||
"parent_dir": '/',
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
data = {
|
||||
"repo_id": self.repo_id,
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
data = {
|
||||
"repo_id": self.repo_id,
|
||||
"parent_dir": '/',
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(400, resp.status_code)
|
||||
|
||||
def test_delete_with_repo_not_exist(self):
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
||||
data = {
|
||||
"repo_id": invalid_repo_id,
|
||||
"parent_dir": '/',
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(404, resp.status_code)
|
||||
|
||||
def test_delete_with_folder_not_exist(self):
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
data = {
|
||||
"repo_id": self.repo_id,
|
||||
"parent_dir": 'invalid_folder',
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(404, resp.status_code)
|
||||
|
||||
def test_delete_with_invalid_repo_permission(self):
|
||||
|
||||
tmp_repo_id = self.create_new_repo(self.admin_name)
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
data = {
|
||||
"repo_id": tmp_repo_id,
|
||||
"parent_dir": '/',
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(403, resp.status_code)
|
||||
|
||||
def test_delete_with_invalid_parent_folder_permission(self):
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
# share admin's tmp repo to user with 'r' permission
|
||||
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||
self.user_name, 'r')
|
||||
data = {
|
||||
"repo_id": admin_repo_id,
|
||||
"parent_dir": '/',
|
||||
"dirents":[self.folder_name, self.file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(403, resp.status_code)
|
||||
self.remove_repo(admin_repo_id)
|
||||
|
||||
def test_delete_with_locked_file(self):
|
||||
|
||||
if not LOCAL_PRO_DEV_ENV:
|
||||
return
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
# share admin's tmp repo to user with 'r' permission
|
||||
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||
self.user_name, 'rw')
|
||||
|
||||
# admin lock file
|
||||
admin_file_name = randstring(6)
|
||||
seafile_api.post_empty_file(admin_repo_id, '/', admin_file_name,
|
||||
self.admin_name)
|
||||
seafile_api.lock_file(admin_repo_id, admin_file_name, self.admin_name, 0)
|
||||
|
||||
# user move locked file
|
||||
data = {
|
||||
"repo_id": admin_repo_id,
|
||||
"parent_dir": '/',
|
||||
"dirents":[admin_file_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(403, resp.status_code)
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['error_msg'] == 'File %s is locked.' % admin_file_name
|
||||
|
||||
def test_delete_with_r_permission_sub_folder(self):
|
||||
|
||||
if not LOCAL_PRO_DEV_ENV:
|
||||
return
|
||||
|
||||
self.login_as(self.user)
|
||||
|
||||
# share admin's tmp repo to user with 'r' permission
|
||||
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||
self.user_name, 'rw')
|
||||
|
||||
# admin set 'r' sub folder permission
|
||||
admin_folder_name = randstring(6)
|
||||
seafile_api.post_dir(admin_repo_id, '/', admin_folder_name, self.admin_name)
|
||||
seafile_api.add_folder_user_perm(admin_repo_id, '/' +
|
||||
admin_folder_name, 'r', self.user_name)
|
||||
|
||||
# user move locked file
|
||||
data = {
|
||||
"repo_id": admin_repo_id,
|
||||
"parent_dir": '/',
|
||||
"dirents":[admin_folder_name],
|
||||
}
|
||||
resp = self.client.delete(self.url, json.dumps(data), 'application/json')
|
||||
self.assertEqual(403, resp.status_code)
|
||||
json_resp = json.loads(resp.content)
|
||||
assert json_resp['error_msg'] == "Can't delete folder %s, please check its permission." % admin_folder_name
|
||||
|
Reference in New Issue
Block a user