mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-04 08:28:11 +00:00
Revert "forbide sync move, copy to a different repo | update test cases (#3827)"
This reverts commit 4173eda251
.
This commit is contained in:
@@ -1333,11 +1333,6 @@ class ReposSyncBatchCopyItemView(APIView):
|
|||||||
error_msg = 'dst_parent_dir invalid.'
|
error_msg = 'dst_parent_dir invalid.'
|
||||||
return api_error(status.HTTP_400_BAD_REQUEST, error_msg)
|
return api_error(status.HTTP_400_BAD_REQUEST, error_msg)
|
||||||
|
|
||||||
# forbiden sync copy to a different repo
|
|
||||||
if src_repo_id != dst_repo_id:
|
|
||||||
error_msg = 'dst_repo_id should be the same as src_repo_id.'
|
|
||||||
return api_error(status.HTTP_400_BAD_REQUEST, error_msg)
|
|
||||||
|
|
||||||
# resource check
|
# resource check
|
||||||
if not seafile_api.get_repo(src_repo_id):
|
if not seafile_api.get_repo(src_repo_id):
|
||||||
error_msg = 'Library %s not found.' % src_repo_id
|
error_msg = 'Library %s not found.' % src_repo_id
|
||||||
@@ -1440,11 +1435,6 @@ class ReposSyncBatchMoveItemView(APIView):
|
|||||||
error_msg = 'dst_parent_dir invalid.'
|
error_msg = 'dst_parent_dir invalid.'
|
||||||
return api_error(status.HTTP_400_BAD_REQUEST, error_msg)
|
return api_error(status.HTTP_400_BAD_REQUEST, error_msg)
|
||||||
|
|
||||||
# forbiden sync move to a different repo
|
|
||||||
if src_repo_id != dst_repo_id:
|
|
||||||
error_msg = 'dst_repo_id should be the same as src_repo_id.'
|
|
||||||
return api_error(status.HTTP_400_BAD_REQUEST, error_msg)
|
|
||||||
|
|
||||||
# resource check
|
# resource check
|
||||||
if not seafile_api.get_repo(src_repo_id):
|
if not seafile_api.get_repo(src_repo_id):
|
||||||
error_msg = 'Library %s not found.' % src_repo_id
|
error_msg = 'Library %s not found.' % src_repo_id
|
||||||
|
@@ -1070,8 +1070,7 @@ class ReposSyncBatchCopyItemView(BaseTestCase):
|
|||||||
self.admin_name = self.admin.username
|
self.admin_name = self.admin.username
|
||||||
|
|
||||||
self.src_repo_id = self.repo.id
|
self.src_repo_id = self.repo.id
|
||||||
#self.dst_repo_id = self.create_new_repo(self.user_name)
|
self.dst_repo_id = self.create_new_repo(self.user_name)
|
||||||
self.dst_repo_id = self.repo.id
|
|
||||||
|
|
||||||
self.file_path = self.file
|
self.file_path = self.file
|
||||||
self.file_name = os.path.basename(self.file_path)
|
self.file_name = os.path.basename(self.file_path)
|
||||||
@@ -1089,22 +1088,13 @@ class ReposSyncBatchCopyItemView(BaseTestCase):
|
|||||||
|
|
||||||
self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# create a new dir /test
|
|
||||||
# copy /folder, /test.txt to /test/folder, /test/test.txt
|
|
||||||
dist_folder = '/test'
|
|
||||||
create_folder_url = reverse('DirView', kwargs={'repo_id':self.src_repo_id}) + '?p=' + dist_folder
|
|
||||||
data = {
|
|
||||||
'operation': 'mkdir',
|
|
||||||
}
|
|
||||||
self.client.post(create_folder_url, data)
|
|
||||||
|
|
||||||
data = {
|
data = {
|
||||||
"src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
"src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
"src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
|
|
||||||
"dst_repo_id": self.dst_repo_id,
|
"dst_repo_id": self.dst_repo_id,
|
||||||
"dst_parent_dir": dist_folder,
|
"dst_parent_dir": '/',
|
||||||
}
|
}
|
||||||
|
|
||||||
resp = self.client.post(self.url, json.dumps(data),
|
resp = self.client.post(self.url, json.dumps(data),
|
||||||
@@ -1116,8 +1106,8 @@ class ReposSyncBatchCopyItemView(BaseTestCase):
|
|||||||
assert seafile_api.get_file_id_by_path(self.src_repo_id, self.file_path) is not None
|
assert seafile_api.get_file_id_by_path(self.src_repo_id, self.file_path) is not None
|
||||||
|
|
||||||
# items in dst folder
|
# items in dst folder
|
||||||
assert seafile_api.get_file_id_by_path(self.dst_repo_id, dist_folder + self.file_path) is not None
|
assert seafile_api.get_file_id_by_path(self.dst_repo_id, self.file_path) is not None
|
||||||
assert seafile_api.get_dir_id_by_path(self.dst_repo_id, dist_folder + self.folder_path) is not None
|
assert seafile_api.get_dir_id_by_path(self.dst_repo_id, self.folder_path) is not None
|
||||||
|
|
||||||
def test_copy_with_invalid_parameter(self):
|
def test_copy_with_invalid_parameter(self):
|
||||||
|
|
||||||
@@ -1168,31 +1158,31 @@ class ReposSyncBatchCopyItemView(BaseTestCase):
|
|||||||
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
self.assertEqual(400, resp.status_code)
|
self.assertEqual(400, resp.status_code)
|
||||||
|
|
||||||
# def test_copy_with_repo_not_exist(self):
|
def test_copy_with_repo_not_exist(self):
|
||||||
|
|
||||||
# self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": invalid_repo_id,
|
"src_repo_id": invalid_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.dst_repo_id,
|
"dst_repo_id": self.dst_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(404, resp.status_code)
|
self.assertEqual(404, resp.status_code)
|
||||||
|
|
||||||
# invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": invalid_repo_id,
|
"dst_repo_id": invalid_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(404, resp.status_code)
|
self.assertEqual(404, resp.status_code)
|
||||||
|
|
||||||
def test_copy_with_folder_not_exist(self):
|
def test_copy_with_folder_not_exist(self):
|
||||||
|
|
||||||
@@ -1218,9 +1208,22 @@ class ReposSyncBatchCopyItemView(BaseTestCase):
|
|||||||
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
self.assertEqual(404, resp.status_code)
|
self.assertEqual(404, resp.status_code)
|
||||||
|
|
||||||
def test_forbide_copy_to_a_different_repo(self):
|
def test_copy_with_invalid_repo_permission(self):
|
||||||
|
|
||||||
|
tmp_repo_id = self.create_new_repo(self.admin_name)
|
||||||
|
|
||||||
self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
tmp_repo_id = self.create_new_repo(self.user_name)
|
|
||||||
|
data = {
|
||||||
|
"src_repo_id": tmp_repo_id,
|
||||||
|
"src_parent_dir": '/',
|
||||||
|
"src_dirents":[self.folder_name, self.file_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)
|
||||||
|
|
||||||
data = {
|
data = {
|
||||||
"src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
"src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
@@ -1228,128 +1231,97 @@ class ReposSyncBatchCopyItemView(BaseTestCase):
|
|||||||
"dst_repo_id": tmp_repo_id,
|
"dst_repo_id": tmp_repo_id,
|
||||||
"dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
}
|
}
|
||||||
resp = self.client.post(self.url, json.dumps(data),
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
'application/json')
|
self.assertEqual(403, resp.status_code)
|
||||||
self.assertEqual(400, resp.status_code)
|
|
||||||
json_resp = json.loads(resp.content)
|
|
||||||
assert json_resp['error_msg'] == 'dst_repo_id should be the same as src_repo_id.'
|
|
||||||
|
|
||||||
self.remove_repo(tmp_repo_id)
|
def test_copy_with_invalid_src_folder_permission(self):
|
||||||
|
|
||||||
# def test_copy_with_invalid_repo_permission(self):
|
if not LOCAL_PRO_DEV_ENV:
|
||||||
|
return
|
||||||
|
|
||||||
# tmp_repo_id = self.create_new_repo(self.admin_name)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# self.login_as(self.user)
|
# share admin's tmp repo to user with 'cloud-edit' permission
|
||||||
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
|
self.user_name, 'cloud-edit')
|
||||||
|
data = {
|
||||||
|
"src_repo_id": admin_repo_id,
|
||||||
|
"src_parent_dir": '/',
|
||||||
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
|
"dst_repo_id": self.src_repo_id,
|
||||||
|
"dst_parent_dir": '/',
|
||||||
|
}
|
||||||
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
|
self.assertEqual(403, resp.status_code)
|
||||||
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# data = {
|
# share admin's tmp repo to user with 'preivew' permission
|
||||||
# "src_repo_id": tmp_repo_id,
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# "src_parent_dir": '/',
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
self.user_name, 'preview')
|
||||||
# "dst_repo_id": self.dst_repo_id,
|
data = {
|
||||||
# "dst_parent_dir": '/',
|
"src_repo_id": admin_repo_id,
|
||||||
# }
|
"src_parent_dir": '/',
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# self.assertEqual(403, resp.status_code)
|
"dst_repo_id": self.src_repo_id,
|
||||||
|
"dst_parent_dir": '/',
|
||||||
|
}
|
||||||
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
|
self.assertEqual(403, resp.status_code)
|
||||||
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# data = {
|
def test_copy_with_invalid_dst_folder_permission(self):
|
||||||
# "src_repo_id": self.src_repo_id,
|
|
||||||
# "src_parent_dir": '/',
|
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
|
||||||
# "dst_repo_id": tmp_repo_id,
|
|
||||||
# "dst_parent_dir": '/',
|
|
||||||
# }
|
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
|
||||||
# self.assertEqual(403, resp.status_code)
|
|
||||||
|
|
||||||
# def test_copy_with_invalid_src_folder_permission(self):
|
self.login_as(self.user)
|
||||||
|
|
||||||
# if not LOCAL_PRO_DEV_ENV:
|
# share admin's tmp repo to user with 'r' permission
|
||||||
# return
|
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 = {
|
||||||
|
"src_repo_id": self.src_repo_id,
|
||||||
|
"src_parent_dir": '/',
|
||||||
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
|
"dst_repo_id": admin_repo_id,
|
||||||
|
"dst_parent_dir": '/',
|
||||||
|
}
|
||||||
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
|
self.assertEqual(403, resp.status_code)
|
||||||
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# self.login_as(self.user)
|
if not LOCAL_PRO_DEV_ENV:
|
||||||
|
return
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'cloud-edit' permission
|
# share admin's tmp repo to user with 'cloud-edit' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'cloud-edit')
|
self.user_name, 'cloud-edit')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.src_repo_id,
|
"dst_repo_id": admin_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# self.remove_repo(admin_repo_id)
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'preivew' permission
|
# share admin's tmp repo to user with 'preview' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'preview')
|
self.user_name, 'preivew')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.src_repo_id,
|
"dst_repo_id": admin_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# self.remove_repo(admin_repo_id)
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# def test_copy_with_invalid_dst_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 = {
|
|
||||||
# "src_repo_id": self.src_repo_id,
|
|
||||||
# "src_parent_dir": '/',
|
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
|
||||||
# "dst_repo_id": admin_repo_id,
|
|
||||||
# "dst_parent_dir": '/',
|
|
||||||
# }
|
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
|
||||||
# self.assertEqual(403, resp.status_code)
|
|
||||||
# self.remove_repo(admin_repo_id)
|
|
||||||
|
|
||||||
# if not LOCAL_PRO_DEV_ENV:
|
|
||||||
# return
|
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'cloud-edit' permission
|
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
|
||||||
# self.user_name, 'cloud-edit')
|
|
||||||
# data = {
|
|
||||||
# "src_repo_id": self.src_repo_id,
|
|
||||||
# "src_parent_dir": '/',
|
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
|
||||||
# "dst_repo_id": admin_repo_id,
|
|
||||||
# "dst_parent_dir": '/',
|
|
||||||
# }
|
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
|
||||||
# self.assertEqual(403, resp.status_code)
|
|
||||||
# self.remove_repo(admin_repo_id)
|
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'preview' permission
|
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
|
||||||
# self.user_name, 'preivew')
|
|
||||||
# data = {
|
|
||||||
# "src_repo_id": self.src_repo_id,
|
|
||||||
# "src_parent_dir": '/',
|
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
|
||||||
# "dst_repo_id": admin_repo_id,
|
|
||||||
# "dst_parent_dir": '/',
|
|
||||||
# }
|
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
|
||||||
# self.assertEqual(403, resp.status_code)
|
|
||||||
# self.remove_repo(admin_repo_id)
|
|
||||||
|
|
||||||
|
|
||||||
class ReposSyncBatchMoveItemView(BaseTestCase):
|
class ReposSyncBatchMoveItemView(BaseTestCase):
|
||||||
@@ -1365,8 +1337,7 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
|||||||
self.admin_name = self.admin.username
|
self.admin_name = self.admin.username
|
||||||
|
|
||||||
self.src_repo_id = self.repo.id
|
self.src_repo_id = self.repo.id
|
||||||
# self.dst_repo_id = self.create_new_repo(self.user_name)
|
self.dst_repo_id = self.create_new_repo(self.user_name)
|
||||||
self.dst_repo_id = self.repo.id
|
|
||||||
|
|
||||||
self.file_path = self.file
|
self.file_path = self.file
|
||||||
self.file_name = os.path.basename(self.file_path)
|
self.file_name = os.path.basename(self.file_path)
|
||||||
@@ -1384,22 +1355,13 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
|||||||
|
|
||||||
self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# create a new dir /test
|
|
||||||
# move /folder, /test.txt to /test/folder, /test/test.txt
|
|
||||||
dist_folder = '/test'
|
|
||||||
create_folder_url = reverse('DirView', kwargs={'repo_id':self.src_repo_id}) + '?p=' + dist_folder
|
|
||||||
data = {
|
|
||||||
'operation': 'mkdir',
|
|
||||||
}
|
|
||||||
self.client.post(create_folder_url, data)
|
|
||||||
|
|
||||||
data = {
|
data = {
|
||||||
"src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
"src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
"src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
|
|
||||||
"dst_repo_id": self.dst_repo_id,
|
"dst_repo_id": self.dst_repo_id,
|
||||||
"dst_parent_dir": dist_folder,
|
"dst_parent_dir": '/',
|
||||||
}
|
}
|
||||||
|
|
||||||
resp = self.client.post(self.url, json.dumps(data),
|
resp = self.client.post(self.url, json.dumps(data),
|
||||||
@@ -1411,8 +1373,8 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
|||||||
assert seafile_api.get_file_id_by_path(self.src_repo_id, self.file_path) is None
|
assert seafile_api.get_file_id_by_path(self.src_repo_id, self.file_path) is None
|
||||||
|
|
||||||
# items in dst folder
|
# items in dst folder
|
||||||
assert seafile_api.get_file_id_by_path(self.dst_repo_id, dist_folder + self.file_path) is not None
|
assert seafile_api.get_file_id_by_path(self.dst_repo_id, self.file_path) is not None
|
||||||
assert seafile_api.get_dir_id_by_path(self.dst_repo_id, dist_folder + self.folder_path) is not None
|
assert seafile_api.get_dir_id_by_path(self.dst_repo_id, self.folder_path) is not None
|
||||||
|
|
||||||
def test_move_with_invalid_parameter(self):
|
def test_move_with_invalid_parameter(self):
|
||||||
|
|
||||||
@@ -1463,49 +1425,31 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
|||||||
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
self.assertEqual(400, resp.status_code)
|
self.assertEqual(400, resp.status_code)
|
||||||
|
|
||||||
def test_forbide_move_to_a_different_repo(self):
|
def test_move_with_repo_not_exist(self):
|
||||||
|
|
||||||
self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
tmp_repo_id = self.create_new_repo(self.user_name)
|
|
||||||
|
invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
||||||
|
data = {
|
||||||
|
"src_repo_id": invalid_repo_id,
|
||||||
|
"src_parent_dir": '/',
|
||||||
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
|
"dst_repo_id": self.dst_repo_id,
|
||||||
|
"dst_parent_dir": '/',
|
||||||
|
}
|
||||||
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
|
self.assertEqual(404, resp.status_code)
|
||||||
|
|
||||||
|
invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
||||||
data = {
|
data = {
|
||||||
"src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
"src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
"src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
"dst_repo_id": tmp_repo_id,
|
"dst_repo_id": invalid_repo_id,
|
||||||
"dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
}
|
}
|
||||||
resp = self.client.post(self.url, json.dumps(data),
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
'application/json')
|
self.assertEqual(404, resp.status_code)
|
||||||
self.assertEqual(400, resp.status_code)
|
|
||||||
json_resp = json.loads(resp.content)
|
|
||||||
assert json_resp['error_msg'] == 'dst_repo_id should be the same as src_repo_id.'
|
|
||||||
|
|
||||||
self.remove_repo(tmp_repo_id)
|
|
||||||
|
|
||||||
# def test_move_with_repo_not_exist(self):
|
|
||||||
|
|
||||||
# self.login_as(self.user)
|
|
||||||
|
|
||||||
# invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
|
||||||
# data = {
|
|
||||||
# "src_repo_id": invalid_repo_id,
|
|
||||||
# "src_parent_dir": '/',
|
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
|
||||||
# "dst_repo_id": self.dst_repo_id,
|
|
||||||
# "dst_parent_dir": '/',
|
|
||||||
# }
|
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
|
||||||
# self.assertEqual(404, resp.status_code)
|
|
||||||
|
|
||||||
# invalid_repo_id = 'd53fe97e-919a-42f9-a29f-042d285ba6fb'
|
|
||||||
# data = {
|
|
||||||
# "src_repo_id": self.src_repo_id,
|
|
||||||
# "src_parent_dir": '/',
|
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
|
||||||
# "dst_repo_id": invalid_repo_id,
|
|
||||||
# "dst_parent_dir": '/',
|
|
||||||
# }
|
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
|
||||||
# self.assertEqual(404, resp.status_code)
|
|
||||||
|
|
||||||
def test_move_with_folder_not_exist(self):
|
def test_move_with_folder_not_exist(self):
|
||||||
|
|
||||||
@@ -1531,194 +1475,194 @@ class ReposSyncBatchMoveItemView(BaseTestCase):
|
|||||||
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
self.assertEqual(404, resp.status_code)
|
self.assertEqual(404, resp.status_code)
|
||||||
|
|
||||||
# def test_move_with_invalid_repo_permission(self):
|
def test_move_with_invalid_repo_permission(self):
|
||||||
|
|
||||||
# tmp_repo_id = self.create_new_repo(self.admin_name)
|
tmp_repo_id = self.create_new_repo(self.admin_name)
|
||||||
|
|
||||||
# self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": tmp_repo_id,
|
"src_repo_id": tmp_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.dst_repo_id,
|
"dst_repo_id": self.dst_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
|
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": tmp_repo_id,
|
"dst_repo_id": tmp_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
|
|
||||||
# def test_move_with_invalid_src_folder_permission(self):
|
def test_move_with_invalid_src_folder_permission(self):
|
||||||
|
|
||||||
# self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'r' permission
|
# share admin's tmp repo to user with 'r' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'r')
|
self.user_name, 'r')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": admin_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.src_repo_id,
|
"dst_repo_id": self.src_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# self.remove_repo(admin_repo_id)
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# if not LOCAL_PRO_DEV_ENV:
|
if not LOCAL_PRO_DEV_ENV:
|
||||||
# return
|
return
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'cloud-edit' permission
|
# share admin's tmp repo to user with 'cloud-edit' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'cloud-edit')
|
self.user_name, 'cloud-edit')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": admin_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.src_repo_id,
|
"dst_repo_id": self.src_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# self.remove_repo(admin_repo_id)
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'preivew' permission
|
# share admin's tmp repo to user with 'preivew' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'preview')
|
self.user_name, 'preview')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": admin_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": self.src_repo_id,
|
"dst_repo_id": self.src_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# self.remove_repo(admin_repo_id)
|
self.remove_repo(admin_repo_id)
|
||||||
|
|
||||||
# def test_move_with_invalid_dst_folder_permission(self):
|
def test_move_with_invalid_dst_folder_permission(self):
|
||||||
|
|
||||||
# self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'r' permission
|
# share admin's tmp repo to user with 'r' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'r')
|
self.user_name, 'r')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": admin_repo_id,
|
"dst_repo_id": admin_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
|
|
||||||
# if not LOCAL_PRO_DEV_ENV:
|
if not LOCAL_PRO_DEV_ENV:
|
||||||
# return
|
return
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'cloud-edit' permission
|
# share admin's tmp repo to user with 'cloud-edit' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'cloud-edit')
|
self.user_name, 'cloud-edit')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": admin_repo_id,
|
"dst_repo_id": admin_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'preview' permission
|
# share admin's tmp repo to user with 'preview' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'preview')
|
self.user_name, 'preview')
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": self.src_repo_id,
|
"src_repo_id": self.src_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[self.folder_name, self.file_name],
|
"src_dirents":[self.folder_name, self.file_name],
|
||||||
# "dst_repo_id": admin_repo_id,
|
"dst_repo_id": admin_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
|
|
||||||
# def test_move_with_locked_file(self):
|
def test_move_with_locked_file(self):
|
||||||
|
|
||||||
# if not LOCAL_PRO_DEV_ENV:
|
if not LOCAL_PRO_DEV_ENV:
|
||||||
# return
|
return
|
||||||
|
|
||||||
# self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'rw' permission
|
# share admin's tmp repo to user with 'rw' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'rw')
|
self.user_name, 'rw')
|
||||||
|
|
||||||
# # admin lock file
|
# admin lock file
|
||||||
# admin_file_name = randstring(6)
|
admin_file_name = randstring(6)
|
||||||
# seafile_api.post_empty_file(admin_repo_id, '/', admin_file_name,
|
seafile_api.post_empty_file(admin_repo_id, '/', admin_file_name,
|
||||||
# self.admin_name)
|
self.admin_name)
|
||||||
# seafile_api.lock_file(admin_repo_id, admin_file_name, self.admin_name, 0)
|
seafile_api.lock_file(admin_repo_id, admin_file_name, self.admin_name, 0)
|
||||||
|
|
||||||
# # user move locked file
|
# user move locked file
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": admin_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[admin_file_name],
|
"src_dirents":[admin_file_name],
|
||||||
# "dst_repo_id": self.dst_repo_id,
|
"dst_repo_id": self.dst_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# json_resp = json.loads(resp.content)
|
json_resp = json.loads(resp.content)
|
||||||
# assert json_resp['error_msg'] == 'File %s is locked.' % admin_file_name
|
assert json_resp['error_msg'] == 'File %s is locked.' % admin_file_name
|
||||||
|
|
||||||
# def test_move_with_r_permission_sub_folder(self):
|
def test_move_with_r_permission_sub_folder(self):
|
||||||
|
|
||||||
# if not LOCAL_PRO_DEV_ENV:
|
if not LOCAL_PRO_DEV_ENV:
|
||||||
# return
|
return
|
||||||
|
|
||||||
# self.login_as(self.user)
|
self.login_as(self.user)
|
||||||
|
|
||||||
# # share admin's tmp repo to user with 'rw' permission
|
# share admin's tmp repo to user with 'rw' permission
|
||||||
# admin_repo_id = self.create_new_repo(self.admin_name)
|
admin_repo_id = self.create_new_repo(self.admin_name)
|
||||||
# seafile_api.share_repo(admin_repo_id, self.admin_name,
|
seafile_api.share_repo(admin_repo_id, self.admin_name,
|
||||||
# self.user_name, 'rw')
|
self.user_name, 'rw')
|
||||||
|
|
||||||
# # admin set 'r' sub folder permission
|
# admin set 'r' sub folder permission
|
||||||
# admin_folder_name = randstring(6)
|
admin_folder_name = randstring(6)
|
||||||
# seafile_api.post_dir(admin_repo_id, '/', admin_folder_name, self.admin_name)
|
seafile_api.post_dir(admin_repo_id, '/', admin_folder_name, self.admin_name)
|
||||||
# seafile_api.add_folder_user_perm(admin_repo_id, '/' +
|
seafile_api.add_folder_user_perm(admin_repo_id, '/' +
|
||||||
# admin_folder_name, 'r', self.user_name)
|
admin_folder_name, 'r', self.user_name)
|
||||||
|
|
||||||
# # user move r permission folder
|
# user move r permission folder
|
||||||
# data = {
|
data = {
|
||||||
# "src_repo_id": admin_repo_id,
|
"src_repo_id": admin_repo_id,
|
||||||
# "src_parent_dir": '/',
|
"src_parent_dir": '/',
|
||||||
# "src_dirents":[admin_folder_name],
|
"src_dirents":[admin_folder_name],
|
||||||
# "dst_repo_id": self.dst_repo_id,
|
"dst_repo_id": self.dst_repo_id,
|
||||||
# "dst_parent_dir": '/',
|
"dst_parent_dir": '/',
|
||||||
# }
|
}
|
||||||
# resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
resp = self.client.post(self.url, json.dumps(data), 'application/json')
|
||||||
# self.assertEqual(403, resp.status_code)
|
self.assertEqual(403, resp.status_code)
|
||||||
# json_resp = json.loads(resp.content)
|
json_resp = json.loads(resp.content)
|
||||||
# assert json_resp['error_msg'] == "Can't move folder %s, please check its permission." % admin_folder_name
|
assert json_resp['error_msg'] == "Can't move folder %s, please check its permission." % admin_folder_name
|
||||||
|
|
||||||
class ReposBatchDeleteItemView(BaseTestCase):
|
class ReposBatchDeleteItemView(BaseTestCase):
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user